1 | Revision history for Perl extension Coro. |
1 | Revision history for Perl extension Coro. |
2 | |
2 | |
3 | TODO: should explore PerlIO::coroaio (perl leaks like hell). |
3 | TODO: should explore PerlIO::coroaio (perl leaks like hell). |
4 | TODO: channel->maxsize(newsize)? |
4 | TODO: channel->maxsize(newsize)? |
5 | TODO: __GCC_HAVE_DWARF2_CFI_ASM |
5 | TODO: __GCC_HAVE_DWARF2_CFI_ASM |
|
|
6 | TODO: swap_sv, maybe add scope_swap_sv, andallow to unswap by repeat? |
|
|
7 | TODO: swap_sv not undone in pool |
6 | |
8 | |
|
|
9 | 6.36 Tue Mar 4 07:11:59 CET 2014 |
|
|
10 | - semaphores would not clear the destroy hook when interrupted |
|
|
11 | by ->throw, causing segfaults or worse. |
|
|
12 | - ->throw on a thread waiting for a semaphore did not acquire |
|
|
13 | the semaphore, but also didn't wake up other waiters, |
|
|
14 | possibly causing a deadlock. |
|
|
15 | - "FATAL: $Coro::IDLE blocked itself" will now use Carp::confess |
|
|
16 | to report a full stacktrace, which should help find out |
|
|
17 | where the actual call is. |
|
|
18 | - "atomically" destroy data in slf_destroy, because it is |
|
|
19 | the right thing to do, just in case. |
|
|
20 | - disable ecb.h libm dependency, to compile on ancient systems |
|
|
21 | or under adverse conditions. |
|
|
22 | |
|
|
23 | 6.33 Mon Nov 18 11:26:27 CET 2013 |
|
|
24 | - do not crash when freeing padlists with holes (in 5.18). |
|
|
25 | - tentative SVt_BIND 5.19 port/fix. |
|
|
26 | |
|
|
27 | 6.32 Tue Nov 5 15:35:35 CET 2013 |
|
|
28 | - use a new algorithm to derive padlists for perl 5.18. The old |
|
|
29 | one could lead to 0-pointer accesses inside perl (reported |
|
|
30 | by Darin McBride). |
|
|
31 | |
|
|
32 | 6.31 Thu May 9 07:39:48 CEST 2013 |
|
|
33 | - Coro::AIO requests would crash if the thread was ready'd |
|
|
34 | while the request was ongoing. |
|
|
35 | |
|
|
36 | 6.29 Wed May 8 02:55:18 CEST 2013 |
|
|
37 | - when an on_destroy handler destructs the coro currently being |
|
|
38 | destructed a perl scalar could be accessed after being freed, |
|
|
39 | likely causing a crash. |
|
|
40 | |
|
|
41 | 6.28 Wed Mar 6 06:58:02 CET 2013 |
|
|
42 | - clean remnants of existing __DIE__ and __WARN__ handlers so |
|
|
43 | they lose their magic and will not cause segfaults later |
|
|
44 | (testcase by Andrey Sagulin). |
7 | - improved Coro::State documentation a bit. |
45 | - improved Coro::State documentation a bit. |
8 | - Coro::Debug::command now flushes the output. |
46 | - Coro::Debug::command now flushes the output. |
9 | - add hack detection code for x32 abi, because the braindead slugs |
47 | - add hack detection code for x32 abi, because the braindead slugs |
10 | who designed that made it look exactly like x86_64 without |
48 | who designed that made it look exactly like x86_64 without |
11 | providing proper compile time symbols to test for it. as a result, |
49 | providing proper compile time symbols to test for it. as a result, |
… | |
… | |
460 | - ->throw is now supported on Coro::State objects. |
498 | - ->throw is now supported on Coro::State objects. |
461 | - clean up cctx creation code a bit. |
499 | - clean up cctx creation code a bit. |
462 | - entersub is actually a UNOP, not a LOGOP (not a bugfix). |
500 | - entersub is actually a UNOP, not a LOGOP (not a bugfix). |
463 | |
501 | |
464 | 4.9 Sat Nov 8 17:45:27 CET 2008 |
502 | 4.9 Sat Nov 8 17:45:27 CET 2008 |
465 | - (libcoro) did not preserve rbp with CORO_ASM (we are getting there). |
503 | - (libcoro) did not preserve rbp with CORO_ASM (we are getting there). |
466 | - (libcoro) no longer leak threads in the experimental pthread backend, |
504 | - (libcoro) no longer leak threads in the experimental pthread backend, |
467 | also speed it up considerably. |
505 | also speed it up considerably. |
468 | - (libcoro) do not rely on makecontext passing void *'s unscathed. |
506 | - (libcoro) do not rely on makecontext passing void *'s unscathed. |
469 | - fix compiletime dependencies on libcoro in the Makefile. |
507 | - fix compiletime dependencies on libcoro in the Makefile. |
470 | - cctx_count wasn't always updated properly. |
508 | - cctx_count wasn't always updated properly. |
… | |
… | |
532 | - remove debugging code related to MgPV_nolen_const, also try to |
570 | - remove debugging code related to MgPV_nolen_const, also try to |
533 | make it compile with perl 5.8.6 (yes, apple apparently loves |
571 | make it compile with perl 5.8.6 (yes, apple apparently loves |
534 | outdated software). Reported by John S. |
572 | outdated software). Reported by John S. |
535 | |
573 | |
536 | 4.744 Tue Jul 8 22:06:35 CEST 2008 |
574 | 4.744 Tue Jul 8 22:06:35 CEST 2008 |
537 | - correctly provide default DIE/WARN handlers as documented. |
575 | - correctly provide default DIE/WARN handlers as documented. |
538 | - also overwrite PL_vtbl_sigelem.svt_clear, even though current |
576 | - also overwrite PL_vtbl_sigelem.svt_clear, even though current |
539 | implementations inside perl work fine for us. |
577 | implementations inside perl work fine for us. |
540 | |
578 | |
541 | 4.743 Mon Jun 16 00:21:57 CEST 2008 |
579 | 4.743 Mon Jun 16 00:21:57 CEST 2008 |
542 | - when using Coro::EV without running EV::loop it could |
580 | - when using Coro::EV without running EV::loop it could |
… | |
… | |
564 | - sprinkle "no warnings" freely over everything, also suppress |
602 | - sprinkle "no warnings" freely over everything, also suppress |
565 | warnings for some other modules. |
603 | warnings for some other modules. |
566 | - fix typo in WSAEWOULDBLOCK. |
604 | - fix typo in WSAEWOULDBLOCK. |
567 | |
605 | |
568 | 4.72 Sun May 25 05:14:36 CEST 2008 |
606 | 4.72 Sun May 25 05:14:36 CEST 2008 |
569 | - tweak META.yaml a bit, unfortunately, there is no documented way |
607 | - tweak META.yaml a bit, unfortunately, there is no documented way |
570 | to have optional dependencies with CPAN. doh :( |
608 | to have optional dependencies with CPAN. doh :( |
571 | - avoid running some tests on windows because they would fail due to |
609 | - avoid running some tests on windows because they would fail due to |
572 | perl bug (broken fork, broken pipes...). |
610 | perl bug (broken fork, broken pipes...). |
573 | - work around perl on windows bugs where perl returns undocumented |
611 | - work around perl on windows bugs where perl returns undocumented |
574 | error codes for sysread, syswrite etc. by taking advantage |
612 | error codes for sysread, syswrite etc. by taking advantage |
… | |
… | |
578 | - use unix domain sockets in testsuite to work around |
616 | - use unix domain sockets in testsuite to work around |
579 | common perl implementation bugs on widows (they are emulated by |
617 | common perl implementation bugs on widows (they are emulated by |
580 | tcp sockets on windows. ugh.) |
618 | tcp sockets on windows. ugh.) |
581 | |
619 | |
582 | 4.71 Sat May 24 20:01:27 CEST 2008 |
620 | 4.71 Sat May 24 20:01:27 CEST 2008 |
583 | - fix a bug in Coro::AnyEvent ("Usage: Coro::AnyEvent::_schedule()"). |
621 | - fix a bug in Coro::AnyEvent ("Usage: Coro::AnyEvent::_schedule()"). |
584 | - take advantage of async name resolution of AnyEvent::Util. |
622 | - take advantage of async name resolution of AnyEvent::Util. |
585 | - work around brutal inet_aton override in Coro::LWP. |
623 | - work around brutal inet_aton override in Coro::LWP. |
586 | - take advantage of the readyhook in Coro::EV, for smoother |
624 | - take advantage of the readyhook in Coro::EV, for smoother |
587 | scheduling. |
625 | scheduling. |
588 | |
626 | |
589 | 4.7 Sun May 11 00:32:19 CEST 2008 |
627 | 4.7 Sun May 11 00:32:19 CEST 2008 |
590 | - completely reworked the Coro manpage. |
628 | - completely reworked the Coro manpage. |
591 | - added Coro::AnyEvent, generic event loop integration. |
629 | - added Coro::AnyEvent, generic event loop integration. |
592 | - implement cancel, ready and kill commands in Coro::Debug. |
630 | - implement cancel, ready and kill commands in Coro::Debug. |
593 | - document find_coro in Coro::Debug. |
631 | - document find_coro in Coro::Debug. |
594 | - incompatible change: rename has_stack to has_cctx. |
632 | - incompatible change: rename has_stack to has_cctx. |
595 | - Coro::AIO and Coro::BDB no longer force event model detection, |
633 | - Coro::AIO and Coro::BDB no longer force event model detection, |
596 | use AnyEvent::AIO and AnyEvent::BDB. |
634 | use AnyEvent::AIO and AnyEvent::BDB. |
… | |
… | |
720 | |
758 | |
721 | 4.11 Thu Oct 11 02:40:24 CEST 2007 |
759 | 4.11 Thu Oct 11 02:40:24 CEST 2007 |
722 | - port to threaded perls. |
760 | - port to threaded perls. |
723 | |
761 | |
724 | 4.1 Thu Oct 11 02:38:16 CEST 2007 |
762 | 4.1 Thu Oct 11 02:38:16 CEST 2007 |
725 | - incompatible change: $SIG{__DIE__} and $SIG{__WARN__} will now |
763 | - incompatible change: $SIG{__DIE__} and $SIG{__WARN__} will now |
726 | be local to each coro (see Coro::State). |
764 | be local to each coro (see Coro::State). |
727 | - incompatible change: for very deep reasons, cede and cede_notself |
765 | - incompatible change: for very deep reasons, cede and cede_notself |
728 | cannot return anything, so nothing will be returned. |
766 | cannot return anything, so nothing will be returned. |
729 | - possibly bring back 5.10 compatibility (untested). |
767 | - possibly bring back 5.10 compatibility (untested). |
730 | - work around stupid (and wrong) warning on 5.10 :(. |
768 | - work around stupid (and wrong) warning on 5.10 :(. |
… | |
… | |
802 | but stateful semantics. |
840 | but stateful semantics. |
803 | - fixed a lot of typos in Coro.pm (patch submitted by David |
841 | - fixed a lot of typos in Coro.pm (patch submitted by David |
804 | Steinbrunner, which applied flawlessly). |
842 | Steinbrunner, which applied flawlessly). |
805 | |
843 | |
806 | 3.6 Sat Apr 14 17:13:31 CEST 2007 |
844 | 3.6 Sat Apr 14 17:13:31 CEST 2007 |
807 | - added some bugfixes to get eg/myhttpd working again. |
845 | - added some bugfixes to get eg/myhttpd working again. |
808 | - added Coro::Storable for often-cede'ing freeze/thaw. |
846 | - added Coro::Storable for often-cede'ing freeze/thaw. |
809 | - try to do a clean exit when a coroutine calls exit |
847 | - try to do a clean exit when a coroutine calls exit |
810 | (EXPERIMENTAL). |
848 | (EXPERIMENTAL). |
811 | - got rid of indirect call through _coro_init. |
849 | - got rid of indirect call through _coro_init. |
812 | - updated the partly antique examples in eg/ to |
850 | - updated the partly antique examples in eg/ to |