ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/Coro/Changes
(Generate patch)

Comparing Coro/Changes (file contents):
Revision 1.498 by root, Tue Jun 23 00:56:14 2009 UTC vs.
Revision 1.570 by root, Tue Jun 14 06:17:42 2011 UTC

1Revision history for Perl extension Coro. 1Revision history for Perl extension Coro.
2 2
3TODO: should explore PerlIO::coroaio (perl leaks like hell). 3TODO: should explore PerlIO::coroaio (perl leaks like hell).
4TODO: maybe implement a default message channel, very much like Erlang's
5 actor model (which is cool in a lot of important aspects (failures!),
6 but very lacking in others (higher level ipc)).
7TODO: unready_all
8TODO: myhttpd header parsing
9TODO: channel->maxsize(newsize)? 4TODO: channel->maxsize(newsize)?
5TODO: http://www.microsoft.com/msj/archive/s2ce.aspx
10 6
7TODO: tutorial
8TODO: in_eval, PL_tained
9 - INCOMPATIBLE CHANGE: unreferenced coro objects will now be
10 destroyed and cleaned up automatically (e.g. async { schedule }).
11 - implement a JIT compiler for part of the thread switch code,
12 which gives a 50% speed improvement on threaded perls, and
13 about 4% on non-thraeded perls (so threaded perls now finally
14 reach about half the speed of non-threaded perls).
15 - avoid DEFSV and ERRSV, giving another 10% improvement
16 in thread switching.
17 - Coro::State->is_destroyed is now called is_zombie.
18 - implement a Coro->safe_cancel method that might fail, but
19 cancels in a "safer" way if it succeeds.
20 - get rid of two hash-accesses when initialising a new Coro - this
21 speeds up coro creation by almost a factor of two.
22 - croak when a coro that is being cancelled tries to block
23 (e.g. while executing a guard block), instead of crashing or
24 deadlocking.
25 - use a more robust and also faster method to identify Coro::State
26 objects - speeds up everything a bit.
27 - implement Coro->cancel in XS for a 20% speed improvement, and to
28 be able to implement mutual cancellation.
29 - speed up context switches by a percent or two by more efficiently
30 allocating context stack entries.
31 - implement Coro->join and Coro->on_destroy in XS for a speedup and
32 a reduction in memory use.
33 - cancelling a coro while it itself is cancelling another coro is
34 now supported and working, instead of triggering an assertion.
35 - be a bit more crash-resistant when calling (buggy) on_destroy
36 callbacks (best effort).
37 - move on_destroy into the slf_frame, to allow extension slf
38 functions to have destructors.
39 - get rid if coro refcounting - simply crash in other interpreter
40 threads by nulling the pointers on clone.
41 - simplify warn/die hook handling when loading Coro - the convoluted
42 logic seems to be no longer neccessary.
43 - use libecb instead of our own home-grown gcc hacks.
44 - document alternatives to Coro::LWP. Please use them :)
45
465.372 Wed Feb 23 06:14:30 CET 2011
47 - apparently mingw doesn't provide a working gettimeofday, try to
48 work around that by relying on Time::HiRes (indirectly brought to
49 my attention by Max Maischein).
50 - fix some portability issues when Time::HiRes was used.
51
525.371 Mon Feb 21 14:36:08 CET 2011
53 - backport to windows process emulation code again.
54
555.37 Sat Feb 19 07:49:44 CET 2011
56 - add a big "Coro thread life cycle" section to "man Coro".
57 - try a tentative workaround against the breakage that 5.13 has
58 introduced without depreciation period. sigh.
59 - no longer use Time::HiRes if gettimeofday is available, which
60 saves quite a lot of memory.
61
625.36 Sun Feb 13 05:33:41 CET 2011
63 - automatically load Coro::Channel, Coro::RWLock, Coro::Semaphore,
64 Coro::SemaphoreSet, Coro::Signal and Coro::Specific on first "new"
65 method call.
66 - undocument Coro::Timer::sleep and obsolete whole module.
67 - optimise Coro::Timer::timeout memory and cpu usage.
68 - slightly updated Coro::Intro for recent changes.
69 - do not initialise PL_dirty anymore.
70
715.25 Thu Nov 11 01:08:39 CET 2010
72 - try a different approach on netbsd - netbsd 5 finally has marginally
73 working pthreads, but still broken ucontext/sigaltstack.
74 - openbsd 4.8 finally got their act together, Coro works out of the box
75 with asm, setjmp and pthreads (no change, just informational).
76
775.24 Sat Oct 23 11:27:12 CEST 2010
78 - port to the EV 4.0 API.
79 - work around bugs in mingw32, making strawberry perl work
80 out of the box.
81 - correctly modify Coro::AIO function prototypes
82 so that they reflect the "no optional parameters" rule.
83 - "ported" libcoro to C++.
84
855.23 Mon May 17 18:50:42 CEST 2010
86 - be more resistant to ordering changes when initialising
87 Coro::AnyEvent, Coro::EV and Coro::Event (reported by Matthias
88 Waldorf).
89 - document that perl 5.12 deliberately removed support for cloning.
90
915.22 Wed Apr 14 03:55:35 CEST 2010
92 - correctly return udnef on errors in Coro::Handle::read/write
93 (testcase by Marc Mims).
94 - convert Coro::Util into a "perl compatibility wrapper" - the functions
95 are less useful now, but are drop-in replacements for existing
96 functions, listing better alternatives in the documentation. This also
97 fixes a bug in Coro::LWP which naively substituted Socket::inet_aton
98 with Coro::Util::inet_aton.
99 - do not override $Coro::idle unconditionally in Coro.pm, as other
100 modules could have provided their own idle coro already
101 (for exmaple, Coro::AnyEvent).
102 - fix Coro::Util::gethost* functions.
103 - Coro::Timer corretcly exports it's symbols (reported by Hideki Yamamura).
104
1055.21 Wed Dec 16 07:19:51 CET 2009
106 - automatically load Coro::AnyEvent when AnyEvent and Coro are used
107 together.
108 - add some examples on how to combine other event loops with Coro in
109 Coro::AnyEvent, and how to run it (and not to block). Seems to be
110 the most common source of confusion.
111 - try to catch people naively blocking in an event callback.
112 - work around the perl filehandle bug issue in conjunction with
113 older common::sense (as indirectly pointed out by ZSystem).
114 - clarify the "not from signal handlers" section.
115
1165.2 Sun Oct 4 14:54:24 CEST 2009
117 - Coro::Storable destroyed the prototypes of the functions it wrapped.
118 - export rouse_cb and rouse_wait by default now.
119 - fix various prototype mismatches in Coro::AnyEvent and Coro::Handle.
120 - new method $state->swap_sv.
121 - added section on "windows process emulation" to the manpage,
122 after a not-so-fruitful (nor-friendly) "discussion" with chip
123 salzenberg (discussion implies arguments, but his only arguments
124 were ad-hominems, one wonders why he started it in the first
125 place). I hope this explains it well enough for him to understand,
126 and maybe well enough for others to understand.
127 - use common::sense everywhere now.
128 - idle callbacks are no longer supported, use idle coros instead.
129 - print a thread listing when a deadlock is detected.
130
1315.17 Sat Aug 22 23:09:31 CEST 2009
132 - work around a bug in the perl debugger causing crashes
133 when running under the debugger by marking _pool_handler as nodebug.
134 - speed up Coro::async considerably.
135 - try some hacks to get netbsd to work "more often" - their broken
136 setjmp/longjmp, ucontext *and* phtreads are really hard on Coro.
137 - convert Coro to AE 5.0 API.
138
1395.162 Tue Jul 28 04:04:03 CEST 2009
140 - perl 5.8.2 is now minimum requirement.
141 - skip t/19_handle.t on broken windows perls.
142
1435.161 Wed Jul 22 04:47:38 CEST 2009
144 - Coro::AnyEvent::poll could have a different prototype when EV was
145 used as backend (analyzed by Tatsuhiko Miyagawa).
146 - Coro::AnyEvent errornously initialised the event loop when loaded,
147 not on demand.
148 - try to workaround rare */t/01_unblock.t failures.
149
1505.16 Tue Jul 21 01:44:37 CEST 2009
151 - Coro::AnyEvent failed to hook into the event loop
152 when no threads had been readied between detecting
153 the event loop and actually running it.
154 - considerably speed up Coro::Select by taking avdantage
155 of AnyEvent > 4.8 and some other optimisations.
156 - implement paragraph readline mode in Coro::Handle
157 (based on patches by Zsbán Ambrus).
158 - replace WSAEINPROGRESS by WSAEWOULDBLOCK (reported
159 and analyzed by Yasuhiro MATSUMOTO).
160 - clarified libcoro license and copyright.
161 - someone stole my EXTRA_META!!!
162 - implement Coro::Select::patch_pp_sselect and it's brother,
163 for hardcode select overriding.
164
1655.151 Mon Jul 6 05:41:57 CEST 2009
166 - backport to windows process emulation code again (patch by
167 Yasuhiro MATSUMOTO).
168 - slightly update Coro::MakeMaker.
169
1705.15 Tue Jun 30 10:28:06 CEST 2009
171 - deprecate Coro::Socket, document how to get ipv6 support via
172 AnyEvent::Socket instead.
173 - implement signal->wait ($cb) interface, similar to semaphores.
174 - work around SvOK not supporting getmagic, so we have to getmagic
175 to test for undef :/ (reported by Matthias Waldorf).
176 - load Coro::AnyEvent in all modules using AnyEvent.
177 - work around perl corrupting our internal data structures,
178 reported by Tokuhiro Matsuno.
179 - enable per-coroutine real and cpu time gathering
180 (Coro::State::enable_times).
181
1825.14 Wed Jun 24 01:37:48 CEST 2009
11 - provide explicit functions to "cede" to the event loop in Coro::AnyEvent, 183 - provide explicit functions to "cede" to the event loop in Coro::AnyEvent,
12 as this seems to have been a difficult concept (poll, sleep, idle, 184 as this seems to have been a difficult concept (poll, sleep, idle,
13 idle_upto). 185 idle_upto).
14 - add Coro::AnyEvent::readable/writable functions. 186 - add Coro::AnyEvent::readable/writable functions.
15 - clarify Coro::EV/Event/AnyEvent manpages. 187 - clarify Coro::EV/Event/AnyEvent manpages.
16 - free per-thread global scalars in the thread calling ->cancel, to 188 - free per-thread global scalars in the thread calling ->cancel, to
17 avoid crashes when $_, $@ etc., are magical but some of those 189 avoid crashes when $_, $@ etc., are magical but some of those
18 had already been freed. 190 had already been freed.
19 - "unexperimentalize" the callback interface for Coro::Semaphore. 191 - "unexperimentalise" the callback interface for Coro::Semaphore.
20 - speed up ready queue management/context switching by using a linked 192 - speed up ready queue management/context switching by using a linked
21 list instead of an array (~5-10%). 193 list instead of an array (~5-10%).
22 - implement "watch" command in Coro::Debug shells. 194 - implement "watch" command in Coro::Debug shells.
23 - for fun, implement time-slicing as an example in the manpage. 195 - for fun, implement time-slicing as an example in the manpage.
24 - if AnyEvent detects EV or Event, but we don't have Coro::EV or 196 - if AnyEvent detects EV or Event, but we don't have Coro::EV or

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines