1 | Revision history for Perl extension Coro. |
1 | Revision history for Perl extension Coro. |
2 | |
2 | |
3 | TODO: check wether stack-sharing is still effective |
3 | 3.0 |
4 | TODO: more effective stack sharing by having one "default stack" for "simple" coroutines? |
4 | - the "FINALLY COMPLETELY STABLE" release (coming soon: |
5 | TODO: verify exception frame changes and force stack copies? |
5 | the "FAMOUS LAST WORDS" release). |
6 | #2 0x00002ac4a63f2622 in api_schedule () at State.xs:895 |
6 | - implement a new stack sharing algorithm, which uses a stack |
7 | #3 0x00002ac4a63f26a9 in XS_Coro_schedule (cv=0x911700) at State.xs:1095 |
7 | pool (size currently hardcoded). |
8 | #4 0x00000000004941b8 in Perl_pp_entersub () at pp_hot.c:2869 |
8 | - make stack sharing mandatory (it no longer uses a heuristic). |
9 | #5 0x0000000000489fee in Perl_runops_standard () at run.c:37 |
9 | - eval/die no longer cause weird problems under heavy use. |
10 | #6 0x000000000041dec7 in Perl_call_sv (sv=0xbfd8ea0, flags=<value optimized out>) at perl.c:2806 |
10 | - Coro::Event could cause livelocks if it was used but |
11 | #7 0x00002ac4a6606ad3 in pe_event_invoke (ev=0x1ada6e0) at c/ev.c:308 |
11 | no Coro::Event watchers were used. |
12 | #8 0x00002ac4a6608878 in one_event (tm=60) at c/queue.c:91 |
12 | - Coro::Event now uses asynccheck as prepare does not |
13 | #9 0x00002ac4a6608f4f in XS_Event_one_event (cv=<value optimized out>) at c/queue.c:234 |
13 | check for changed watchers. |
14 | #10 0x00000000004941b8 in Perl_pp_entersub () at pp_hot.c:2869 |
14 | - Coro::Event should be cleaner and more efficient now. |
15 | #11 0x0000000000489fee in Perl_runops_standard () at run.c:37 |
15 | - new utility function Coro::unblock_sub. |
16 | #12 0x00000000004c4287 in S_docatch (o=<value optimized out>) at pp_ctl.c:2566 |
16 | - document the sad fact that Event is no longer reentrant. |
17 | #13 0x0000000000489fee in Perl_runops_standard () at run.c:37 |
17 | - putting a coroutine into the ready queue twice could under |
18 | #14 0x00000000004c4287 in S_docatch (o=<value optimized out>) at pp_ctl.c:2566 |
18 | some circumstances lead to stack corruption. |
19 | #15 0x0000000000489fee in Perl_runops_standard () at run.c:37 |
19 | - minor incompatibility: subclassing Coro::State is supported |
20 | #16 0x000000000041e38c in Perl_call_sv (sv=<value optimized out>, flags=140) at perl.c:2806 |
20 | directly now without going through a _coro_state member. |
21 | #17 0x00002ac4a63f1d72 in setup_coro (arg=0x881d80) at State.xs:620 |
21 | - state/coro switching is much faster now. |
22 | #18 0x00002ac4a63f28b7 in coro_init () at libcoro/coro.c:78 |
|
|
23 | #19 0x0000000000000000 in ?? () |
|
|
24 | |
|
|
25 | - minor documentation cleanup. |
|
|
26 | - verys minor optimisations and cleanups. |
22 | - very minor optimisations and code/documentation cleanup. |
|
|
23 | - avoid problems due to compiler inlining. |
|
|
24 | - removed timers from Coro::Timer -> use AnyEvent instead. |
|
|
25 | - replaced Coro::idle coroutine by (cleaner) idle handler. |
|
|
26 | - updated to newest libcoro. |
|
|
27 | - implement enhanced support for valgrind. |
|
|
28 | - implement is_ready and return value for ready. |
|
|
29 | - removed Coro::Cont, it was a misnomer (it's generators), |
|
|
30 | and it was somewhat annoying to get it right. Will come back |
|
|
31 | if somebody asks for it :) |
|
|
32 | - many ->wait methods and Coro::Event could return |
|
|
33 | spuriously without the event having happened. |
27 | |
34 | |
28 | 2.5 Tue Nov 7 12:22:33 CET 2006 |
35 | 2.5 Tue Nov 7 12:22:33 CET 2006 |
29 | - made Coro::Util, Coro::Select, Coro::Handle and Coro::Socket |
36 | - made Coro::Util, Coro::Select, Coro::Handle and Coro::Socket |
30 | use AnyEvent, moved them to Coro/. |
37 | use AnyEvent, moved them to Coro/. |
31 | - added Coro::LWP which contains all the uglyness required to |
38 | - added Coro::LWP which contains all the uglyness required to |