ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/Coro/Changes
Revision: 1.391
Committed: Fri Nov 7 16:39:35 2008 UTC (15 years, 6 months ago) by root
Branch: MAIN
Changes since 1.390: +2 -0 lines
Log Message:
*** empty log message ***

File Contents

# User Rev Content
1 root 1.1 Revision history for Perl extension Coro.
2 root 1.113
3 root 1.382 TODO: should explore PerlIO::coroaio (perl leaks like hell).
4 root 1.328 TODO: 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 root 1.247 but very lacking in others (higher level ipc)).
7 root 1.173
8 root 1.391 - libcoro did not preserve rbp with CORO_ASM.
9    
10 root 1.390 4.804 Wed Nov 5 16:36:00 CET 2008
11 root 1.389 - Coro::Debug::new_unix_server would not create a non-blocking listening
12 root 1.390 socket, sometimes causing freezes.
13 root 1.389 - fix misaligned stack points for setjmp and assembly methods, which
14 root 1.390 can cause crashes on x86/x86_64 with a sufficiently aggressive compiler.
15 root 1.389 - new function: Coro::Debug::new_tcp_server.
16 root 1.388 - move ->throw into the Coro class because it only works on coro objects.
17    
18 root 1.387 4.803 Mon Nov 3 17:16:12 CET 2008
19 root 1.386 - use a global asm statement to become independent of gcc otpimisations
20     for CORO_ASM (thanks to pippijn for the idea).
21 root 1.387 - try to workaround yet another broken bsd, this time dragonfly.
22 root 1.386
23 root 1.385 4.802 Thu Oct 30 10:56:12 CET 2008
24     - support -fno-omit-frame-pointer on x86 with the assembly method.
25 root 1.383 - tune 01_unblock.t tests a bit.
26    
27 root 1.382 4.801 Wed Oct 22 18:33:37 CEST 2008
28 root 1.381 - improve readline speed for very long "lines".
29 root 1.382 - backport to 5.8.8.
30 root 1.381
31 root 1.380 4.8 Thu Oct 2 13:34:40 CEST 2008
32 root 1.378 - new function Coro::AIO::aio_wait.
33     - Coro.:AIO and Coro::BDB now "use Coro::AnyEvent".
34     - greatly speed up and reduce memory usage of Coro::AIO requests.
35 root 1.379 - implement some other µ-optimisations.
36 root 1.378
37 root 1.377 4.749 Mon Sep 29 14:40:12 CEST 2008
38     - port to slow and broken pseudo-threaded perls. (courtesy pippijn).
39    
40 root 1.376 4.748 Sat Sep 27 14:03:19 CEST 2008
41 root 1.374 - implement, but do not document, PerlIO::cede(granularity).
42 root 1.372 - Coro::Storable forgot to wrap Storable::pstore.
43 root 1.374 - work around the multitude of leaks and memory corruption
44 root 1.375 bugs in PerlIO::via by using our own C-level perliol. As a side
45     effect, Coro::Storable is now much, much, much faster.
46 root 1.372
47 root 1.371 4.747 Tue Sep 23 01:59:41 CEST 2008
48 root 1.369 - fix a per-cv memleak (one empty array was leaked per
49     code reference).
50 root 1.370 - avoid a crash in coro->call|rss when the coroutine was already
51     destroyed (most noticably when using Coro::Debug::ps :)
52     - also protect *Storable::FILE.
53 root 1.371 - push up default storable granularity to 20ms.
54 root 1.369
55 root 1.368 4.746 Sun Sep 21 03:22:20 CEST 2008
56     - be more insistent on locking Storable against reentrancy
57     in Coro::Storable.
58 root 1.366 - move swap_def?v and throw to Coro::State, as documented.
59    
60 root 1.365 4.745 Thu Jul 24 00:14:38 CEST 2008
61 root 1.364 - remove debugging code related to MgPV_nolen_const, also try to
62     make it compile with perl 5.8.6 (yes, apple apparently loves
63     outdated software). Reported by John S.
64 root 1.363
65 root 1.362 4.744 Tue Jul 8 22:06:35 CEST 2008
66 root 1.361 - correctly provide default DIE/WARN handlers as documented.
67     - also overwrite PL_vtbl_sigelem.svt_clear, even though current
68     implementations inside perl work fine for us.
69    
70 root 1.360 4.743 Mon Jun 16 00:21:57 CEST 2008
71     - when using Coro::EV without running EV::loop it could
72     result in busy-waiting for events, this has been fixed.
73     - reduce codesize and improve performance by using EV_DEFAULT_UC.
74    
75 root 1.359 4.742 Sat May 31 14:10:21 CEST 2008
76     - implement a workaround for (some) perl <5.8.8 versions.
77     - require EV 3.3+.
78    
79 root 1.358 4.741 Fri May 30 23:33:09 CEST 2008
80     - tell netbsd how utterly broken their imitation of an OS is
81     and refuse to build by default if pthreads are in use.
82     - switch to "s" method on all bsd's by default, as their ucontext
83     stuff seems just too broken.
84     - fix a bug in Coro::Select.
85    
86 root 1.357 4.74 Thu May 29 20:05:31 CEST 2008
87     - do not test Coro::LWP for lack of dependencies.
88     - do not test Coro::Select for lack of working perls.
89    
90     4.73 Thu May 29 2008
91 root 1.356 - fix a bug in Coro::EV which would cause it to block despite
92     there being runnable coroutines.
93 root 1.354 - sprinkle "no warnings" freely over everything, also suppress
94     warnings for some other modules.
95 root 1.355 - fix typo in WSAEWOULDBLOCK.
96 root 1.354
97 root 1.353 4.72 Sun May 25 05:14:36 CEST 2008
98 root 1.351 - tweak META.yaml a bit, unfortunately, there is no documented way
99     to have optional dependencies with CPAN. doh :(
100 root 1.350 - avoid running some tests on windows because they would fail due to
101 root 1.351 perl bug (broken fork, broken pipes...).
102     - work around perl on windows bugs where perl returns undocumented
103     error codes for sysread, syswrite etc. by taking advantage
104     of AnyEvent's workaround for that problem.
105 root 1.350 - use AnyEvent::Util::fh_nonblocking in Coro::Handle to work around
106     a common perl implementation bug on windows.
107     - use unix domain sockets in testsuite to work around
108 root 1.351 common perl implementation bugs on widows (they are emulated by
109     tcp sockets on windows. ugh.)
110 root 1.350
111 root 1.349 4.71 Sat May 24 20:01:27 CEST 2008
112 root 1.348 - fix a bug in Coro::AnyEvent ("Usage: Coro::AnyEvent::_schedule()").
113 root 1.347 - take advantage of async name resolution of AnyEvent::Util.
114     - work around brutal inet_aton override in Coro::LWP.
115 root 1.348 - take advantage of the readyhook in Coro::EV, for smoother
116     scheduling.
117 root 1.347
118 root 1.346 4.7 Sun May 11 00:32:19 CEST 2008
119 root 1.342 - completely reworked the Coro manpage.
120     - added Coro::AnyEvent, generic event loop integration.
121 root 1.341 - implement cancel, ready and kill commands in Coro::Debug.
122     - document find_coro in Coro::Debug.
123 root 1.343 - incompatible change: rename has_stack to has_cctx.
124 root 1.346 - Coro::AIO and Coro::BDB no longer force event model detection,
125     use AnyEvent::AIO and AnyEvent::BDB.
126 root 1.341
127 root 1.340 4.6 Sat Apr 26 10:05:14 CEST 2008
128 root 1.336 - INCOMPATIBLE CHANGE: sub/code attributes are no longer supported
129 root 1.339 by the Coro module. It was a mistake to have it in the first place.
130     - (experimental) support for activestate perl 5.10 (method "w").
131     - (experimental) support for strawberry perl (method "a").
132 root 1.337 - coro_sigelem_set did not return a value although it had to,
133     actual impact unknown.
134 root 1.336
135 root 1.335 4.51 Mon Apr 14 13:28:27 CEST 2008
136     - make it compile again on 5.8.
137    
138 root 1.334 4.50 Thu Apr 10 09:43:17 CEST 2008
139     - I did it twice! (see 4.49).
140    
141 root 1.333 4.49 Sun Apr 6 21:23:31 CEST 2008
142     - grr, instead of compiling the recent changes on 5.10 only they
143     were compiled on 5.8 only.
144    
145 root 1.332 4.48 Sun Apr 6 20:36:46 CEST 2008
146 root 1.331 - allow coroutine switches during eval's under 5.10.x, as it seems
147     the parser is a per-interpreter option now, so this is safe
148     (this might fix the odd crashing bug).
149 root 1.332 - drop support for 5.9.x versions: they are dead, jim.
150 root 1.331
151 root 1.330 4.47 Sun Apr 6 00:37:52 CEST 2008
152 root 1.329 - force cctx allocation on API calls: we know we need to force one
153     and gcc actually manages to confuse our heuristic nowadays,
154     leading to crashes and worse.
155 root 1.330 - document force_cctx.
156 root 1.329
157 root 1.328 4.46 Fri Apr 4 22:05:43 CEST 2008
158     - upgrade libcoro, resulting in pthread-backend (which was only created
159     to fulfill the rules of the programming languages shootout).
160    
161 root 1.327 4.45 Thu Mar 13 11:55:36 CET 2008
162 root 1.322 - fix a file leaking bug in eg/mhyttpd that would allow
163     downloading of any file (reported by oesi).
164 root 1.325 - fix deadlock bug in Coro::Channel (reported by Richard Hundt)
165     (also add testcase).
166 root 1.323 - support Broadcast option in Coro::Socket (patch by Richard Hundt,
167     apparently having loads of fun with that).
168 root 1.324 - implement $state->swap_defsv, ->swap_defav and document ->throw.
169 root 1.322
170 root 1.321 4.4 Wed Feb 13 16:44:29 CET 2008
171 root 1.319 - only assume .cfi pseudo isns exist on GNU/Linux.
172 root 1.320 - add get_timed method to Coro::Channels.
173 root 1.321 - fixed Coro::Debug manpage.
174     - perl 5.11 compatbility improvement based on patch by
175     Andreas König.
176 root 1.319
177 root 1.318 4.37 Sun Jan 20 11:25:23 CET 2008
178 root 1.317 - soften the check for an active parser for perl 5.10 (avoiding
179     "Coro::State::transfer called while parsing" in many cases).
180 root 1.316
181 root 1.315 4.36 Sun Jan 13 10:53:56 CET 2008
182 root 1.314 - reset diehook when terminating from an async_pool as to not
183     trigger any __DIE__ handlers.
184    
185 root 1.313 4.35 Sun Jan 13 04:14:13 CET 2008
186 root 1.308 - "bt" debug command now displays any exceptions
187 root 1.311 from longmess and also skips the innermost
188     stackframes, giving more useufl output.
189 root 1.309 - allow backtraces in coroutines blocked in Coro::EV,
190 root 1.310 at a <1% speed hit.
191 root 1.312 - handle localising of $SIG{__WARN__} and __DIE__
192 root 1.314 properly (with a proper amount of dirty hacking).
193 root 1.308
194 root 1.307 4.34 Sat Dec 22 17:49:53 CET 2007
195 root 1.306 - upgrade to EV version 2.0 API.
196    
197 root 1.305 4.33 Mon Dec 17 08:36:12 CET 2007
198     - make Coro::AIO etc. loadable in the absence of EV.
199    
200 root 1.304 4.32 Mon Dec 17 07:46:02 CET 2007
201 root 1.301 - majorly improved Coro::Handle's performance with Coro::EV.
202 root 1.302 - implemented the until now mythical Coro::BDB module.
203 root 1.304 - specialcase EV in Coro::AIO and Coro::BDB for extra speed.
204 root 1.301
205 root 1.300 4.31 Wed Dec 5 12:32:39 CET 2007
206     - remove warn statement form Coro::Util.
207    
208 root 1.299 4.3 Tue Dec 4 20:33:14 CET 2007
209     - calls to the idle function could cause stack corruption
210     when the stack changed.
211 root 1.295 - do no longer rely on the presence of EV::DNS if EV is used
212     (because it is gone), but instead take avdantage of EV::ADNS
213     if available.
214 root 1.296 - add ($) prototypes to all functions in Coro::Storable.
215 root 1.297 - use a conventional (safer) idle callback in Coro::EV.
216 root 1.298 - do accept quickly in Coro::Debug to avoid endless loops.
217 root 1.295
218 root 1.294 4.22 Fri Nov 30 16:04:04 CET 2007
219 root 1.293 - really use optimised versions for Event and EV in Coro::Util
220     and Coro::Handle.
221    
222 root 1.292 4.21 Sun Nov 25 10:48:59 CET 2007
223 root 1.290 - fix a spurious memory read.
224 root 1.291 - Coro::EV no longer keeps the eventloop "alive".
225 root 1.290
226 root 1.289 4.2 Fri Nov 9 20:47:05 CET 2007
227 root 1.282 - enable/disable tracing from a new coroutine, not a pooled one.
228 root 1.283 - fix a memleak in Coro::Event.
229 root 1.284 - removed killall call from fork_eval.
230     - made sure store_fd is already loaded so that fork_eval
231     does not have to parse autoload in each subprocess.
232 root 1.288 - only use assembly method if -O switch is in $Config{optimize}.
233 root 1.289 - add (optional) Coro::EV module, so far the best event loop module
234     directly supported by Coro.
235     - if the event model is EV, use EV::DNS to resolve
236     stuff in Coro::Util.
237 root 1.286 - don't get confused by multiple event notifications in Coro::Handle.
238 root 1.287 - initial support for EV (libevent interface).
239 root 1.289 - require Event and EV using configure_requires, to force their existance.
240 root 1.282
241 root 1.281 4.13 Wed Oct 24 07:26:45 CEST 2007
242 root 1.277 - add Coro::Storable::blocking_thaw.
243 root 1.278 - use a vastly more complicated technique to localise
244     $SIG{__WARN/DIE__} that also works on perls <= 5.8.8.
245 root 1.279 - use a coroutine for the idle callback Coro::Event,
246     instead of running Event in the current coroutine context.
247     This also catches recursive invocations.
248 root 1.280 - actually report fork errors in gethostbyname and inet_aton.
249 root 1.277
250 root 1.276 4.11 Thu Oct 11 02:40:24 CEST 2007
251     - port to threaded perls.
252    
253 root 1.275 4.1 Thu Oct 11 02:38:16 CEST 2007
254 root 1.264 - incompatible change: $SIG{__DIE__} and $SIG{__WARN__} will now
255     be local to each coro (see Coro::State).
256 root 1.274 - incompatible change: for very deep reasons, cede and cede_notself
257     cannot return anything, so nothing will be returned.
258 root 1.264 - possibly bring back 5.10 compatibility (untested).
259     - work around stupid (and wrong) warning on 5.10 :(.
260     - overlay the saved state over the context stack. This saves
261     a few hundred bytes per coroutine on average and also
262     speeds up context switching a bit.
263 root 1.265 - further tune default stack sizes.
264 root 1.264 - (more) correctly calculate stack usage in coro_rss.
265 root 1.267 - Coro::Storable::blocking_* did not properly lock
266     resulting in races between coroutines.
267     - added Coro::Storable::guard.
268 root 1.268 - stopping to trace a coroutine could destroy the cctx of
269     an unrelated coroutine.
270 root 1.269 - explain the relationship between Perl and C coroutines in
271     more detail in Coro::State.
272 root 1.270 - Coro::Util::inet_aton did not short-circuit dotted quad forms,
273     causing a fork per resolve. This also affected Coro::Socket.
274 root 1.272 - switch to a separate stack in $coro->call/eval to avoid
275     invalidating pointers.
276 root 1.264
277 root 1.263 4.03 Sat Oct 6 21:24:00 CEST 2007
278 root 1.262 - added Coro::throw method.
279     - minor code cleanups.
280    
281 root 1.261 4.02 Sat Oct 6 02:36:47 CEST 2007
282 root 1.258 - fix a very minor per-coroutine memleak (a single codereference).
283 root 1.259 - fixed a bug where the currently in-use c context would be freed
284     prematurely (can happen only when programs change the stacksize
285     or use tracing).
286     - tracing can no longer keep a coro alive after it terminated.
287 root 1.260 - do static branch prediction in the common path for gcc. gives
288     about 2-5% speed improvement here.
289 root 1.258
290 root 1.256 4.01 Fri Oct 5 22:10:49 CEST 2007
291 root 1.257 - instead of recreating *a* standard output handle we simply
292     use STDOUT, which is faster and hopefully more robust.
293 root 1.255
294 root 1.254 4.0 Fri Oct 5 12:56:00 CEST 2007
295 root 1.238 - incompatibly changed Coro::Storable::freeze.
296 root 1.244 - major new feature: added Coro::Debug, for interactive coroutine
297     debugging, tracing and much more.
298 root 1.252 - major bug fix: unbelievable, but true: $_, $/ and many other
299     "saved" variables actually weren't being saved. This has been fixed,
300     of course, while increasing performance while losing all the save
301     flags.
302 root 1.251 - save flags are gone, and all the api functions dealing with them.
303 root 1.232 - added Coro::Semaphore::adjust.
304 root 1.233 - added Coro::Util::fork_eval.
305     - added Coro::Storable::{nfreeze,blocking_{freeze,nfreeze}}.
306 root 1.248 - added Coro::killall.
307 root 1.236 - reduce initial stack sizes to allow for "micro-coroutines".
308 root 1.239 - better async_pool resource management, moved parts of async_pool
309 root 1.240 handling to XS (major speed improvement).
310 root 1.245 - actually croak before modifying important data structures.
311     - refuse to transfer while compiling.
312     - possibly support eval EXPR better now.
313 root 1.249 - enable assembly per default on linux+bsd x86+amd64.
314 root 1.253 - all internal members were renamed _something for easier subclassing.
315 root 1.237 - many minor tweaks.
316 root 1.232
317 root 1.231 3.63 Wed May 16 14:10:06 CEST 2007
318 root 1.230 - implement handcoded assembly for x86/amd64 SVR ABI.
319    
320 root 1.229 3.62 Fri Apr 27 21:36:06 CEST 2007
321     - upgrade libcoro (which might set unwind info correctly).
322 root 1.228 - change default on linux to setjmp/longjmp.
323 root 1.227
324 root 1.226 3.61 Thu Apr 19 12:36:18 CEST 2007
325 root 1.225 - Coro::Storable caused an endless loop when thawing invalid
326     pst's sometimes.
327 root 1.223 - use a Semaphore in Coro::Storable, as Storable doesn't
328 root 1.224 seem to be reentrant (although it is documented to
329     be threadsafe...).
330     - fix Coro::Signal to bring back the original unreliable
331     but stateful semantics.
332 root 1.226 - fixed a lot of typos in Coro.pm (patch submitted by David
333     Steinbrunner, which applied flawlessly).
334 root 1.223
335     3.6 Sat Apr 14 17:13:31 CEST 2007
336 root 1.217 - added some bugfixes to get eg/myhttpd working again.
337 root 1.218 - added Coro::Storable for often-cede'ing freeze/thaw.
338 root 1.219 - try to do a clean exit when a coroutine calls exit
339     (EXPERIMENTAL).
340 root 1.220 - got rid of indirect call through _coro_init.
341     - updated the partly antique examples in eg/ to
342     work again and be a bit less magic, too.
343     - fixed Coro::Signal semantics to work as documented again.
344 root 1.217
345 root 1.216 3.55 Sun Mar 25 01:20:47 CET 2007
346 root 1.215 - add SAVE_DEFFH to save the default filehandle and enable
347     it by default.
348     - finally move socket-operations from Coro::Socket to Coro::Handle
349     to be able to unblock foreign sockets.
350     - add Coro::State::save_also and guarded_save.
351 root 1.211 - add count accessor to Coro::Semaphore.
352 root 1.212 - add Coro::State::cctx_stacksize.
353 root 1.213 - just for the fun of it, do not rely on implicit context,
354     which can dramatically improve performance, but people
355     using windows-process-emulation perls do not care much about
356     performance.
357 root 1.211
358 root 1.210 3.51 Sun Mar 4 14:18:04 CET 2007
359 root 1.209 - fixed a problem when you weakened references to Coro::State's
360     (patch by Yuval Kogman).
361    
362 root 1.208 3.501 Wed Feb 28 12:44:07 CET 2007
363     - rename some global symbols as macosx from hell redefines
364     them without asking.
365    
366 root 1.207 3.5 Tue Feb 13 20:22:53 CET 2007
367 root 1.204 - do AnyEvent model detection earlier, avoiding problems
368     caused by first using AnyEvent and later Coro::Event.
369 root 1.205 - implement and document Coro::Event event objects.
370     - fix a potential problem in Coro::Event causing crashes.
371 root 1.206 - initialise PL_comppad when creating a new coroutine,
372     avoids crashes on early coro destruction.
373 root 1.204
374 root 1.203 3.41 Mon Jan 22 19:19:49 CET 2007
375 root 1.202 - readline on Coro::Handle did not support undefined $/,
376     nor did it deliver partial lines on EOF or error.
377 root 1.203 - implement malloc fallback for stack allocation because
378     stupid broken idiotic OSX has a stupid broken
379     idiotic fits-the-whole-os mmap "implementation" and
380     my dick feels longer if Coro is portable even to
381     obsolete platforms.
382 root 1.202
383 root 1.201 3.4 Fri Jan 19 21:52:54 CET 2007
384 root 1.197 - remove t/09_timer.t, as it isn't really testing much
385     but was rather flaky in practise.
386 root 1.198 - async_pool coro would keep arguments and callback alive until
387     it was reused.
388 root 1.199 - cancellation of a coroutine could cause spurious idle calls
389     in cede_notself.
390 root 1.197
391 root 1.196 3.3 Sat Jan 6 03:45:00 CET 2007
392 root 1.187 - implement $coro->on_destroy.
393 root 1.188 - Coro::Event blocking semantics have been changed,
394     documented and - hopefully - improved.
395 root 1.184 - fix nice adding, not subtracting, from priority.
396 root 1.185 - fix ->prio and api_is_ready (patch by Mark Hinds).
397 root 1.190 - fixed an assert ("... == prev__cctx->idle_te")
398     that could errronously trigger.
399 root 1.192 - fix various large and small memleaks.
400 root 1.191 - use a (hopefully) more stable cancel implementation
401     that immediately frees the coroutine data.
402 root 1.194 - cede/cede_notself return a status now.
403 root 1.191 - added Coro::guard function.
404 root 1.193 - added a global coroutine pool for jobs (on my machine,
405     I can create and execute 48k simple coros/s with async,
406     and 128k coros with async_pool).
407 root 1.195 - Coro::AIO now uses the coroutine priority as io priority.
408 root 1.184
409 root 1.183 3.2 Fri Dec 22 05:07:09 CET 2006
410 root 1.179 - improve portability to slightly older perls.
411 root 1.180 - use cleaner coroutine destruction.
412 root 1.182 - simplify configuration for users.
413     - optionally (unrecommended) prefer perl functions over
414     their coro replacements.
415 root 1.179
416 root 1.178 3.11 Tue Dec 5 13:11:24 CET 2006
417     - fixed some bogus assert's, but as perl.h disables assert even
418     without NDEBUG (thank you very much), not too many people should
419     notice (that did include myself). Andreas König noticed, though :)
420     - do not save/restore PL_sortcxix on >= 5.9.x, it doesn't seem to have
421     it. Also noticed by Andreas König :)
422     - save/restore tainted status.
423     - verified to pass the testsuite on my 5.9.5.
424    
425 root 1.177 3.1 Mon Dec 4 23:03:40 CET 2006
426     - INCOMPATIBLE CHANGE: $/ is now per-coroutine (but slow).
427 root 1.175 - incompatible change: transfer flags are now per-state.
428 root 1.173 - give a better error message on deadlock.
429 root 1.175 - document Coro::nready.
430 root 1.174 - enhanced testsuite.
431 root 1.169
432 root 1.172 3.01 Sun Dec 3 23:47:42 CET 2006
433     - forgot to include Coro::Timer.
434    
435 root 1.171 3.0 Sun Dec 3 22:57:25 CET 2006
436 root 1.163 - the "FINALLY COMPLETELY STABLE" release (coming soon:
437     the "FAMOUS LAST WORDS" release).
438 root 1.166 - implement a new stack sharing algorithm, which uses a stack
439     pool (size currently hardcoded).
440 root 1.155 - make stack sharing mandatory (it no longer uses a heuristic).
441 root 1.157 - eval/die no longer cause weird problems under heavy use.
442 root 1.152 - Coro::Event could cause livelocks if it was used but
443 root 1.161 no Coro::Event watchers were used.
444 root 1.167 - Coro::Event now uses asynccheck as prepare does not
445     check for changed watchers.
446 root 1.170 - Coro::Event allows multiple waiting coros and will wake up one
447     per event.
448 root 1.152 - Coro::Event should be cleaner and more efficient now.
449 root 1.165 - new utility function Coro::unblock_sub.
450 root 1.164 - document the sad fact that Event is no longer reentrant.
451 root 1.163 - putting a coroutine into the ready queue twice could under
452     some circumstances lead to stack corruption.
453 root 1.161 - minor incompatibility: subclassing Coro::State is supported
454     directly now without going through a _coro_state member.
455 root 1.156 - state/coro switching is much faster now.
456 root 1.154 - very minor optimisations and code/documentation cleanup.
457 root 1.153 - avoid problems due to compiler inlining.
458 root 1.154 - removed timers from Coro::Timer -> use AnyEvent instead.
459     - replaced Coro::idle coroutine by (cleaner) idle handler.
460 root 1.156 - updated to newest libcoro.
461 root 1.159 - implement enhanced support for valgrind.
462 root 1.162 - implement is_ready and return value for ready.
463 root 1.168 - removed Coro::Cont, it was a misnomer (it's generators),
464     and it was somewhat annoying to get it right. Will come back
465     if somebody asks for it :)
466 root 1.163 - many ->wait methods and Coro::Event could return
467     spuriously without the event having happened.
468 root 1.146
469 root 1.145 2.5 Tue Nov 7 12:22:33 CET 2006
470 root 1.143 - made Coro::Util, Coro::Select, Coro::Handle and Coro::Socket
471     use AnyEvent, moved them to Coro/.
472 root 1.140 - added Coro::LWP which contains all the uglyness required to
473     make LWP non-blocking.
474     - should work with perl 5.9.x now (Andreas König made me do it).
475 root 1.141 - fixed another bug in Coro::Select when the timeout was undef.
476 root 1.136 - reuse PL_start_env for all coros, saves some memory per coroutine.
477     - manage PL_top_env differently, hopefully to avoid panic: top_env.
478 root 1.137 - timeout argument was not properly used in Coro::Socket.
479     - allow limited forms of subclassing in Coro::Handle/Coro::Socket.
480 root 1.138 - emulate undocumented(!) functionality of IO::Socket required
481     by LWP(!!).
482     - updated eg/lwp to work with newer lwp's.
483 root 1.140 - remove "FATAL: uncaught exception" prefix. Coroutines that die
484     kill the whole process, just as exceptions in the main "coroutine"
485     did already.
486 root 1.135
487 root 1.134 2.1 Wed Nov 1 23:01:13 CET 2006
488     - fix a long-standing bug in Coro::Select where select with
489     zero timeout would instead change the current default filehandle.
490 root 1.132 - use a simpler and hopefully more robust way to clone padlists
491     (uses less memory and a perl function instead of our own).
492     - coro can now create a stack guard area on many architectures.
493 root 1.134 - Coro::AIO properly reexports additional functions from IO::AIO.
494 root 1.132 - updated libcoro with a workaround for OS X,
495 root 1.134 pach and testing by Michael Schwern.
496 root 1.130
497 root 1.129 2.0 Tue Oct 24 05:47:17 CEST 2006
498 root 1.128 - support additional aio requests in Coro::AIO.
499    
500 root 1.129 1.9 (never properly released due to a glitch)
501    
502 root 1.127 1.8 Thu Feb 2 00:59:06 CET 2006
503 root 1.125 - applied suggested patch by SAMV to avoid problems during stupid
504     mark & sweep gc run.
505 root 1.126 - applied patch by Scott Walters for 5.9.3 compatibility.
506 root 1.125
507 root 1.124 1.7 Tue Dec 27 01:41:58 CET 2005
508 root 1.123 - added Coro::AIO, a thin wrapper around IO::AIO.
509 root 1.122 - improved Makefile.PL explanations.
510    
511 root 1.119 1.6 Mon Dec 12 21:30:05 CET 2005
512 root 1.117 - additionally save PM_curpm might fix as-of-yet
513 root 1.121 unseen problems with regex matches being attributed to the
514 root 1.117 wrong package.
515 root 1.118 - add t/10_bugs.t, which currently checks against imho broken
516     perls that use 0.26MB of stack space per Perl_magic_get
517 root 1.121 invocation (newer linuxes) as opposed to the 0.0002MB perl
518     normally uses.
519 root 1.120 - make stacksize configurable for the ultimate debian experience.
520 root 1.117
521 root 1.116 1.51 Mon Dec 12 18:48:36 CET 2005
522     - remove debugging warn() accidentally left in Coro::Select.
523    
524 root 1.115 1.5 Tue Nov 29 13:32:44 CET 2005
525 root 1.114 - use Coro::Event inside Coro::Select to avoid spurious deadlocks.
526 root 1.115 - fix Coro::Select 'select'.
527     - strict'ify some modules.
528 root 1.112 - libcoro errornously restored the SIGUSR2 handler to SIGUSR1.
529 root 1.115 - use XSLoader in selected modules.
530     - remove some 5.6 compatibility cruft.
531 root 1.112
532 root 1.111 1.4 Tue Sep 6 00:11:05 CEST 2005
533     - libcoro did not take into account the trampoline on amd64,
534     when 'l'inux method was used.
535    
536 root 1.110 1.31 Tue Aug 30 23:31:33 CEST 2005
537     - some portability fixes/workarounds.
538    
539 root 1.107 1.3 Sat Aug 20 03:08:56 CEST 2005
540 root 1.108 - no code changes. module seems to work fine.
541 root 1.106 - improve Coro::State docs, remove reference to nonexisting
542     Coro::State::flush method.
543 root 1.107 - no longer autodetect windows, present it as an option instead.
544 root 1.106
545 root 1.105 1.2 Mon May 16 02:00:55 CEST 2005
546 root 1.100 - included libcoro.c earlier in State.xs, might improve portability.
547 root 1.101 - use a faster and possibly more stable Coro::Cont implementation.
548 root 1.102 - accept x86_64 in addition to amd64 for optimized linux-amd64 support.
549 root 1.104 - fix bugs Coro::SemaphoreSet that could cause locks never to be freed.
550 root 1.105 - fix bugs in CoroAPI.h and document it in Coro::MakeMaker.
551 root 1.100
552 root 1.99 1.11 Thu Mar 3 18:00:52 CET 2005
553     - change of contact address.
554    
555 root 1.98 1.1 Tue Feb 22 20:51:16 CET 2005
556 root 1.97 - support [l]inux method on amd64.
557 root 1.109 - allow some context switches while compiling/eval'ing.
558 root 1.97
559 root 1.96 1.0 Tue Aug 10 03:47:27 CEST 2004
560 root 1.95 - Event 0.89 fixes the bug again.
561 root 1.96 - fix the remaining(??) memleak. I didn't free the cache-AV for
562     padlists, so one AV per created anon-sub leaked.
563 root 1.95
564 pcg 1.94 0.97 Fri May 14 15:23:32 CEST 2004
565     - remove stupid gcc extension that was an experiment only anyway.
566    
567 pcg 1.93 0.96 Thu May 13 18:09:29 CEST 2004
568 root 1.103 - tell people if they have yet another broken Event variant.
569 pcg 1.91 - made Coro to work _better_ with threads (it seems that, as long
570     as you use Coros in one thread only everything will work fine.
571     Looking at the perl source the problem might be missing locking
572     between Coro and some perl internal routines. That's not easily
573     fixable).
574 pcg 1.92 - (hopefully) got rid of the static xnext inside transfer.
575 pcg 1.91
576 pcg 1.90 0.95 Sun Feb 15 03:20:28 CET 2004
577 pcg 1.86 - removed Coro::State::flush, implemented a new and much
578     faster caching mechanism by attaching magic to the CV.
579 pcg 1.87 - a memleak with (real) closures remains.
580 pcg 1.88 - dramatically reduced size of stacks to 65536 (linux/x86), after
581     observing that even myhttpd never had more than a kilobyte
582     of stack in use (stack is still only physically allocated in
583     pagesize increments for systems suporting mmap).
584 pcg 1.89 - fix for a "cygwin-64" architecture added, proposed by Stefan Traby.
585 pcg 1.90 - fix for threaded perl.
586 pcg 1.86
587 pcg 1.85 0.9 Sun Nov 23 04:32:39 CET 2003
588 pcg 1.84 - fix a few very hard to track down but (of course) stupid
589     memory leaks.
590     - stringify version number to avoid locale problems :(.
591 pcg 1.85 - perl 5.9.0 does not have SvPADBUSY, reported by Scott Walters,
592     hopefully ignoring it "just works".
593 pcg 1.84
594 pcg 1.83 0.8 Wed Nov 5 19:38:40 CET 2003
595     - port to perl5.005_03, but only 5.8.x+ is supported!
596 pcg 1.82 - honor LocalAddr even without LocalPort in Coro::Socket.
597    
598 root 1.81 0.7 Tue May 27 03:12:38 CEST 2003
599     - the version jump indicates some level of testing, not gobs
600     of new features.
601 root 1.80 - uh... I found the prompt function in ExtUtils::MakeMaker.
602     Highly correct stuff, that is...
603 root 1.81 - fixed(?) a bug with die's in coroutines causing "panic: top_env".
604     the fix is not well understood by the author, so beware :(.
605 root 1.80
606 root 1.79 0.652 Thu May 8 02:54:46 CEST 2003
607 root 1.76 - Applied patch by Slaven Rezic to set default to "s" on FreeBSD,
608 root 1.78 cause version 4 doesn't have ucontext.
609 root 1.77 - Benjamin Reed reported that setjmp works fine on darwin,
610     so preselect it.
611 root 1.76
612 root 1.75 0.651 Sat Mar 29 15:00:23 CET 2003
613     - fix a bug in Coro::Handle where some bytes could get lost
614     on reading, reported by jason@nichego.net.
615 root 1.74
616 root 1.73 0.65 Sun Mar 23 00:08:26 CET 2003
617 root 1.72 - added a README.linux-glibc.
618     - new module Coro::Select.
619     - also save/restore PL_comppad, fixes segfaults with 5.8.1.
620     (I never claimed that I know what I am doing ;).
621 root 1.73 - set default to setjmp/longjmp on non-x86-linux.
622 root 1.72
623 root 1.71 0.6 Thu Nov 21 11:09:06 CET 2002
624     - made lazy context switching the default.
625     - fixed the bug where SemaphoreSet::guard
626     was the same as timed_guard and timed_guard was missing.
627     - fix a memleak in Coro::Timer.
628     - reclassified context sharing as not experimental.
629    
630 root 1.70 0.534 Sun Apr 14 03:05:12 CEST 2002
631 root 1.69 - fixed backspace => tab in header parsing (myhttpd).
632 root 1.70 - added eg/readline, for elmex.
633     - Coro::Event now calls ->start on first call instead of
634     ->again, which created wrong timeouts for the first ->next.
635     - fixed a bug where Coro::Socket returned a closed socket instead
636     of nothing on ECONNREFUSED and similar error conditions.
637 root 1.69
638 root 1.68 0.533 Mon Feb 18 18:49:40 CET 2002
639     - adapt to finally working Event-0.85.
640     - fixed buggy event initialization (trapped under windows, but how
641     could it possibly have worked anywhere?)
642    
643 root 1.67 0.532 Wed Jan 16 02:45:32 CET 2002
644 root 1.66 - removed the reference to pp_entersub, might work on
645     (some) win32 perls now (testsuite works under cygwin,
646     without Event, which freezes).
647 root 1.65
648 root 1.64 0.531 Mon Dec 10 22:18:44 CET 2001
649 root 1.63 - Fixed a bug in SemaphoreSet::timed_down.
650    
651 root 1.64 0.53 Tue Nov 27 21:11:13 CET 2001
652 root 1.60 - some tests for Event.
653 root 1.61 - slightly different internal architecture to get refcnt into the object
654     and not the reference. might fix a few bugs, certainly did introduce
655     new ones.
656     - Coro::Timer (independent of Event).
657 root 1.62 - new timed_wait functions for Coro::Signal, Semaphore, SemaphoreSet.
658 root 1.60
659 root 1.64 0.52 Tue Nov 6 21:36:18 CET 2001
660 root 1.58 - ported to cygwin (trivial).
661     patch by Gerrit P. Haase <gp@familiehaase.de>.
662     - small setjmp code fix by Sullivan.DanielJ@epamail.epa.gov.
663    
664 root 1.64 0.51 Thu Nov 1 20:39:01 CET 2001
665 root 1.54 - terminate/cancel now work properly (otherwise termination
666     could cause a "next coroutine is not and contains not..."
667     error.
668 root 1.55 - added Coro::Socket::shutdown.
669 root 1.56 - Coro::Event::loop no is the same as Event::loop.
670     - implemented terminate with args + join.
671 root 1.54
672 root 1.64 0.5 Fri Sep 28 16:15:35 CEST 2001
673 root 1.53 - fixed "print" on a Coro::Handle. The print method worked.
674 root 1.50 - small tweaks (seem to reduce memory consumption a lot)
675     in various modules.
676     - splendid use of "no warnings" scattered throughout.
677 root 1.52 - added Coro::Handle::rbuf, fixed Coro::Handle::fh.
678 root 1.48
679 root 1.47 0.49 Sun Sep 16 02:42:45 CEST 2001
680 root 1.43 - changed some method calls to function calls for speed
681     inside Coro::Handle.
682 root 1.44 - make Coro::Handle use an array instead of a hash for
683     speed reasons.
684     - IRIX mystery solved: it's SGI's NT, after all: "standard, huh?".
685     sjlj and ucontext should now work.
686     - IRIX-specific port for libcoro.
687 root 1.45 - swapped order of accept results to match IO::Socket.
688 root 1.46 - changed getsock/peername to sock/peername to match IO::Socket.
689     - fixed a bug that caused segfault when returning to main task
690     under some circumstances.
691     - other bugfixes.
692 root 1.43
693 root 1.42 0.45 Sun Sep 2 02:54:01 CEST 2001
694 root 1.36 - new method Coro::Handle::timeout.
695     - corrected speling of set...name to get...name in Coro::Socket.
696     - Coro::Socket::accept now returns a Coro::Socket, not a Coro::Handle.
697     - Coro::Handle now supports fileno and FILENO.
698     - added eg/myhttpd, a web server.
699 root 1.37 - Coro::Socket now accepts numeric ports as well as "port(number)"
700     syntax.
701 root 1.38 - moved some scheduling primitives into xs code. more to come.
702 root 1.39 - new simple priority system.
703 root 1.40 - implemented Coro::Event using XS, almost four times faster!
704 root 1.41 - small memory corruption problem fixed (boy that was difficult).
705 root 1.36
706 root 1.35 0.13 Wed Aug 8 16:53:07 CEST 2001
707 root 1.31 - new method Coro::Handle::readline.
708 root 1.34 - added eg/lwp and Coro::Handle::autoflush, to make LWP work.
709     (see eg/lwp on how to make LWP non-blocking).
710 root 1.31 - renamed Coro::Socket::new_inet to new.
711 root 1.32 - added Coro::Util, some utility functions.
712 root 1.33 - die/eval now works better (still get annoying (but true ;)
713     "Callback called exit" messages).
714 root 1.34 - Coro::Handle now supports timeout, and Coro::Socket Timeout.
715     - much better Coro::Socket support.
716 root 1.31
717     0.12 Fri Jul 27 04:19:01 CEST 2001
718 root 1.29 - do not use mmap if neither MAP_ANON nor MAP_ANONYMOUS is defined.
719 root 1.34 - very experimental stack sharing algorithm. not 100% safe but
720 root 1.28 should work well in practise ;)
721 root 1.30 - added Coro::RWLock.
722 root 1.31 - Coro::Specific now works.
723 root 1.28
724     0.11 Tue Jul 24 22:49:21 CEST 2001
725 root 1.27 - added specialized hack for newer and older linux versions (fast).
726     - renamed Coro::Event::IO to Coro::Handle.
727     - new module Coro::Socket.
728    
729 root 1.26 0.1 Tue Jul 24 01:47:53 CEST 2001
730 root 1.23 - release candidate 3. A rather new internal structure :(
731 root 1.24 - the great renaming: Damian Conway gave me a suitable replacement
732     for yield.
733 root 1.23 - added Coro/libcoro, a portable coroutine implementation for C
734 root 1.22 (not even perl-dependent!!!), which can be used by Coro::State.
735 root 1.20 - renamed SAVE_DEFSV (on xs-level only) to avoid symbol clash in
736     perl-5.6.
737 root 1.16 - new function Coro::Event::idle.
738     - the idle process is now overriden
739     by default in Coro::Event.
740 root 1.17 - Coro::Channel now enforces the size.
741 root 1.18 - canceling events now works in all cases.
742 root 1.19 - Coro state now include $_ and $@.
743     - yet another bug workaround that I do not really understand :(
744 root 1.21 - new module Coro::Event::IO (very undocumented) to do
745     non-blocking i/o.
746 root 1.25 - performance tuning.
747 root 1.16
748 root 1.15 0.08 Thu Jul 19 06:13:25 CEST 2001
749 root 1.14 - release candidate 2 (new functionality).
750 root 1.13 - add Coro::State::flush function.
751     - transfer now supports a flags value (mostly for speed ATM).
752     - might compile and work in the presence of threads now.
753 root 1.14 - continuations have a saner syntax.
754 root 1.19 - no more memleaks.
755 root 1.13
756 root 1.12 0.07 Tue Jul 17 17:40:18 CEST 2001
757     - release candidate 1 ;)
758     - slightly nicer code.
759     - fixed a scheduling bug in Coro::Event.
760    
761 root 1.11 0.06 Tue Jul 17 04:23:24 CEST 2001
762     - ok, I found the showstopper - the same sub must not be
763 root 1.9 re-entered in two different coroutines, otherwise => crash. I
764     see no easy solution to this problem, except by walking the call
765     chaing and saving/restoring the cv's, which is what I do now.
766 root 1.11 - memory leaks still latent, especially at thread termination.
767     - Coro::Event now works (haha).
768 root 1.9
769 root 1.8 0.05 Sun Jul 15 17:32:20 CEST 2001
770     - fixed a few issues in Coro::Event.
771     - I forgot to include Coro::Event in 0.04 :(:(:(
772    
773 root 1.7 0.04 Sun Jul 15 05:24:59 CEST 2001
774 root 1.5 - @_ is now properly localized.
775 root 1.4 - Coro::State is now easier subclassable.
776     - Coro::Cont now coroutine-aware.
777     - Coro::Specific is a low-overhead module to create
778     coroutine-specific vars.
779 root 1.6 - Coro::Event provides a simple interface to Event.
780 root 1.4
781 root 1.3 0.03 Fri Jul 13 14:51:52 CEST 2001
782 root 1.4 - transfer() now implemented in XS (beware).
783     - new module Coro::Cont for really faked continuations.
784     - big internal architecture changes: Coro::State is now
785 root 1.3 really low-level and can thus be used to implement other
786 root 1.4 interesting things, While "Coro::" implements a process-like
787     model. Still crude and subject to change.
788 root 1.3 - $_ and $@ are no longer being localized.
789    
790 root 1.2 0.02 Tue Jul 10 01:38:17 CEST 2001
791     - implemented "async" attribute.
792     - $_ and $@ are now localized.
793     - added Coro::Channel.
794     - more testcases, still no docs.
795    
796 root 1.1 0.01 Tue Jul 3 02:18:41 CEST 2001
797     - original version; copied from Convert::Scalar.
798