ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/AnyEvent/Changes
Revision: 1.161
Committed: Thu Jul 3 02:03:33 2008 UTC (15 years, 10 months ago) by root
Branch: MAIN
CVS Tags: rel-4_160
Changes since 1.160: +1 -1 lines
Log Message:
4.160

File Contents

# User Rev Content
1 root 1.1 Revision history for Perl extension AnyEvent.
2    
3 root 1.161 4.160 Thu Jul 3 04:02:21 CEST 2008
4 root 1.160 - re-registering signal watchers after unregistering one did
5     not work if a backend falls back on AnyEvent's default
6     implementation (also affected child watchers).
7 root 1.159 - new AnyEvent::Handle options: autocork and no_delay.
8    
9 root 1.158 4.152 Sun Jun 22 14:15:44 CEST 2008
10 root 1.159 - allow for 32-bit perls that implement shifts differently
11     on different architectures in parse_ipv4 (reported and
12 root 1.158 analysed by Keiichi DAIBA).
13    
14 root 1.157 4.151 Fri Jun 6 17:34:24 CEST 2008
15     - make sure specifying _only_ on_read and never pushing reads
16     works.
17    
18 root 1.155 4.15 Fri Jun 6 13:00:46 CEST 2008
19 root 1.154 - the pure perl backend would keep some watchers alive when more than
20     one watcher was registered for the same fd.
21 root 1.155 - new "packstring" and "storable" read and write types
22     for AnyEvent::Handle.
23 root 1.156 - allow on_eof handler to be called after on_error with EPIPE returns.
24 root 1.153 - do not immediately call on_read callback in handle constructor.
25    
26 root 1.152 4.14 Thu Jun 5 20:29:31 CEST 2008
27 elmex 1.149 - Fixed a bug in DNS SRV priority sorting.
28 root 1.150 - AnyEvent::Util::guard now reports runtime errors while
29     executing the guard block as warnings.
30 root 1.152 - handle 0-byte-reads just before EOF correctly in AnyEvent::Handle.
31 elmex 1.149
32 root 1.148 4.13 Thu Jun 5 00:47:59 CEST 2008
33 root 1.146 - AnyEvent::DNS only followed cname chains with length 2,
34     contrary to documentation. bumped it up to 10, thanks to
35     microsoft, the current broken-dns-config-king.
36 root 1.147 - AnyEvent::DNS didn't check for socket return status
37     but instead relied on perl not creating filehandles in that
38     case - too bad it gives you a bogus file handle (reported
39     and analysed by Vladimir Timofeev).
40 root 1.145 - fix queue management logic in AnyEvent::Handle:
41     when on_read was registered, the queue was empty
42     and no progress could be made AnyEvent::Handle would
43     enter an endless loop.
44     - correctly start reading again when the handle became
45     busy again after idling.
46 root 1.146 - correctly treat tls shut-downs as EOF condition
47     (for the time being, would be nice to have a callback for that).
48 root 1.145 - correctly call eof callback under all conditions
49     (hopefully).
50 root 1.146 - the timeout callback did not expect that $self can go
51     away any time.
52 root 1.145
53 root 1.144 4.12 Tue Jun 3 10:58:04 CEST 2008
54     - include AnyEvent::Intro, a tutorial for anyevent,
55     anyevent::socket and anyevent::handle.
56 root 1.143 - allow more options in on_error.
57 root 1.142
58 root 1.141 4.11 Fri May 30 23:42:25 CEST 2008
59 root 1.135 - INCOMPATIBLE CHANGE: replace ptr by real PTR lookup, provide
60     reverse_lookup and reverse_verify to replace it, support
61     v4mapped and v4compat addresses.
62 root 1.129 - provide more documentation for the resolver class.
63 root 1.130 - really replace longest run of :0: by :: in format_address,
64     also properly convert :: and ::1 again.
65 root 1.134 - support NAPTR record name and decode it.
66 root 1.133 - implement random weight sampling for SRV records, as per
67     rfc 2782.
68 root 1.137 - correctly abort on srv-record targets of ".".
69     - added AnyEvent::DNS::wait_for_slot.
70 root 1.138 - in the unlikely event of a virtual circuit connection
71     being invalidated by a delayed udp reply, AnyEvent::DNS
72     could die. this has been fixed.
73     - plug a probable memleak in the DNS vc code.
74     - use configured timeout also for VC request phase.
75 root 1.139 - implement timeout and max_outstanding methods
76     for resolver class.
77 root 1.140 - update version numbers in all modules.
78 root 1.129
79 root 1.128 4.1 Thu May 29 05:45:40 CEST 2008
80 root 1.123 - INCOMPATIBLE CHANGE: renamed xxx_ip functions to xxx_address
81     which mirrors their purpose better (old names still available
82     for a while). Also moved AnyEvent::DNS::addr to
83     AnyEvent::Socket::resolve_sockaddr.
84 root 1.127 - implement AnyEvent->time and AnyEvent->now.
85 root 1.124 - fix IPv6 support in pack_sockaddr.
86 root 1.123 - officially un-experimentalise all newly introduced code.
87     - support unix domain sockets everywhere by specifying
88     a host of "unix/" and the pathname as service.
89 root 1.126 - implement an activity timeout in AnyEvent::Handle.
90 root 1.122 - added a regex read type to AnyEvent::Handle.
91     - added a json read/write type to AnyEvent::Handle.
92 root 1.118 - always croak in on_error in AnyEvent::Handle.
93     - document how to subclass AnyEvent::Handle.
94 root 1.120 - implement AnyEvent::Util::fork_call.
95 root 1.127 - add support for IPv6 nameservers and nameserver statements.
96 root 1.121 - work around _yet_ _another_ windows perl bug in where empty
97     select masks cause errors in the pure perl backend (this
98     workaround cannot be implemented for the other event loops,
99     but EV also works around this).
100 root 1.123 - supply AnyEvent::Socket::address_type and make good use of it.
101 root 1.122 - clarify and fix the Handle documentation w.r.t $self vs. $handle
102     vs. callback arguments.
103 root 1.127 - add some recommends to the META.yml.
104 root 1.117
105 root 1.116 4.05 Mon May 26 19:44:06 CEST 2008
106     - some platforms ignore the rfc and prepend an extra sa_len member to
107     the sockaddr structure, cater for those. also use sockaddr_family,
108     didn't know it was there, but comes in handy for the workaround.
109 root 1.114 - undo the import WIN32 hack.
110    
111 root 1.113 4.04 Mon May 26 08:03:31 CEST 2008
112 root 1.109 - try to work around yet another windows bug: failed connects are reported
113 root 1.110 as if it were out-of-band data. windows users: you suck. Only
114     EV, Glib, Event and the pure perl backend can handle this condition.
115 root 1.111 - optimize write algorithm in AnyEvent::Handle.
116 root 1.106 - properly parse PERL_ANYEVENT_PROTOCOLS and use the info correctly.
117 root 1.112 - tcp_connect now properly iterates through all targets.
118 root 1.104 - check wether IPv6 sockets can actually be created, otherwise, disable ipv6
119 root 1.114 support entirely. also hardcode some AF_INET6 constants for the
120 root 1.107 sake of perl 5.8.
121 root 1.106 - vastly improved nameserver/suffix detection algorithm for windows
122     (still a hack...)
123     - try to use a fallback dns server if no dns servers could be found.
124 root 1.108 - splatter around some local $SIG{__DIE__}'s to work around bad
125     die handlers.
126 root 1.104
127 root 1.102 4.03 Sun May 25 05:05:57 CEST 2008
128 root 1.100 - work around perl bugs on windows, where perl returns undocumented
129     error codes for sysread, syswrite etc.
130 root 1.96 - fix AnyEvent::Handle::unshift_read to really unshift and not push.
131 root 1.97 - AnyEvent::Handle could sometimes stumble over 0-byte writes.
132 root 1.101 - fix unpack_sockaddr, now works for AF_INET6 sockaddr's.
133 root 1.100 - updated documentation.
134 root 1.103 - lots of workarounds for perl 5.8 quirks.
135 root 1.98 - implement a more flexible type system for both reads and writes
136     in AnyEvent::Handle.
137 root 1.101 - support IPv6 in tcp_server.
138     - pass local hostname and port to the prepare callback in tcp_server.
139 root 1.99 - make types extendable in AnyEvent::Handle.
140 root 1.100 - croak, not die, in AnyEvent::Handle;
141 root 1.96
142 root 1.95 4.0 Sat May 24 19:58:08 CEST 2008
143 root 1.88 - added (experimental) AnyEvent::DNS module.
144     - added (experimental) AnyEvent::Socket module.
145 root 1.93 - added (experiemntal) support for TLS/SSL in AnyEvent::Handle.
146 root 1.90 - make condvar->end call ->send as documented.
147     - make condvar constructor support the documented cb => argument.
148 root 1.94 - overload condvars so you can use them instead of code references.
149 root 1.93 - support more of the POSIX forms instead of a pure dotted quad for
150 root 1.89 verbatim ip addresses.
151 root 1.88 - AnyEvent::Socket::inet_aton will use AnyEvent::DNS now and not fork anymore.
152 root 1.87 - try very hard not to freeze on broken windows perls.
153 root 1.86 - make on_eof optional in AnyEvent::Handle.
154 root 1.83 - support service names in tcp_connect and tcp_server.
155 root 1.84 - work around netbsd/openbsd bug causing unix sockets not to
156 root 1.121 become writable until empty.
157 root 1.81 - only make a dummy read for error detection when getpeername
158     returns ENOTCONN.
159 root 1.82 - defend AnyEvent::Util::inet_aton against Coro::LWP brutal
160     override.
161 root 1.91 - new AnyEvent::Guard::cancel.
162 root 1.81
163 root 1.80 3.5 Sat May 17 23:17:14 CEST 2008
164 root 1.79 - gracefully deal with systems not defining CLOCK_MONOTONIC
165     (as opposed to not supporting the clock itself, which worked in 3.41).
166 root 1.77 - added AnyEvent::Util::tcp_connect and AnyEvent::Util::tcp_server
167     helpers, to replace the ill-designed AnyEvent::Socket class.
168     - added some examples (eg/connect, eg/handle).
169     - added AnyEvent::Util::guard.
170     - AnyEvent::Util now exports most of its functions.
171 elmex 1.74 - fixed a bug in *_read_chunk, where the callback was called with $self as
172     first and second argument.
173 root 1.77 - simplified and fixed regex handling in AnyEvent::Handle::*_read_line.
174 root 1.72 - fix manpage condvars examples to use new syntax.
175 root 1.78 - considerably improve inet_aton with EV::ADNS backend to support
176     cname chains (common dns configuration bug, e.g. with www.google.de)
177     and aaaa records if no a record could be found.
178 root 1.72
179 root 1.71 3.41 Sun May 11 19:53:13 CEST 2008
180     - work around a bug in perl 5.8.8's local. Reported by Yi Ma Mao.
181    
182 root 1.70 3.4 Sun May 11 00:29:25 CEST 2008
183     - complete re-implementation of condvars with a hopefully much mroe useful
184     API (backward compatible functions exist but are undocumented).
185 root 1.69 - AnyEvent::Handle fully rewritten with a hopefully more powerful API
186     (still subject to change).
187 root 1.63 - take advantage of CLOCK_MONOTONIC, if available, in AnyEvent::Impl::Perl.
188 root 1.68 - provide AnyEvent::post_detect and @AnyEvent::post_detect, which
189 root 1.67 allows module authors to avoid forcing event loop detection.
190     (used by Coro::AIO, Coro::BDB, Coro::AnyEvent for example).
191 root 1.66 - remove coro backends: Coro now provides generic support for AnyEvent
192     via Coro::AnyEvent.
193 root 1.63
194 root 1.62 3.3 Mon Apr 28 09:51:06 CEST 2008
195     - added AnyEvent::Handle, AnyEvent::Socket and AnyEvent::Util modules.
196 root 1.55 - fix a bug in the pure perl backend that kept watchers alive
197     when multiple watchers were registered for the same fh/poll combo.
198 root 1.54 - add a benchmark section showing AnyEvent overhead and comparing
199     the different event loops with each other.
200 root 1.56 - prefer pure perl over tk when autoprobing, as it's about as fast,
201     but doesn't crash with many watchers.
202 root 1.62 - declare Qt support non-experimental.
203 root 1.56 - clarify the confusing section about the file descriptor being
204     kept alive.
205     - document the race between loading of an event module and
206     child processes exiting.
207 root 1.53 - support POE as "backend" (with some caveats, POE is not generic
208 root 1.54 enough, and darn slow).
209 root 1.53 - support Wx and Prima through POE.
210 root 1.60 - optimise perl backend to use 20% less memory and take advantage
211 root 1.62 of typical timeout behaviour. It can now compete with
212 root 1.60 select/poll-based C event loops in most cases (it is usually
213     faster than Event and Glib :).
214 root 1.59 - roughly cut EV memory use in half and increase its speed by 30%,
215 root 1.62 by removing undocumented functionality. Did something similar
216     to other event loops where possible.
217 root 1.53
218 root 1.50 3.2 Thu Apr 24 10:10:40 CEST 2008
219 root 1.51 - do not die when anyevent watchers are destroyed while running callbacks
220     in the pureperl backend (could only happen when two watchers are registered
221     for the same fh/poll combo).
222     - support autoloading for child watchers, was broken in all versions.
223 root 1.47 - implement PERL_ANYEVENT_MODEL env variable.
224 root 1.49 - (experimental) implement interface to the (very crashy/buggy) Event::Lib module.
225     - (experimental) implement interface to the Qt module (cannot be autoprobed).
226 root 1.52 - this release is IO:AnyEvent-proof.
227 root 1.47
228 root 1.46 3.12 Tue Apr 22 07:11:46 CEST 2008
229     - reinstate AUTHOR section that got lost somehow.
230     - do not hang in the testsuite with badly broken perls (activestate,
231     strawberry...), but instead diagnose the problem and continue.
232     - use INT instead of CHLD in an attempt to support broken windows perls
233     better (this decreases the test quality, unfortunately).
234     - do not send the signal to the process group
235     (no problem for CHLD, bad for INT :).
236    
237 root 1.45 3.11 Sat Apr 19 06:57:31 CEST 2008
238     - major documentation rework.
239     - document the fact that child watchers only watch for zombies.
240     - fix the child watcher example.
241    
242 root 1.43 3.1 Wed Apr 16 17:09:01 CEST 2008
243 root 1.40 - work around recurring bugs in Tk by dup'ing filehandles, the
244 root 1.43 only method with good success chances on Tk (the bugs apparently
245     don't get fixed anytime soon).
246 root 1.42 - lift the restriction of only one watcher per fh direction
247     (as the Tk bug workaround also lifts it and only Tk imposed
248     such strong limits).
249 root 1.41 - changed probe order to prefer coro adaptors.
250     - explain why recursion into the event loop is not supported
251     unless the backend supports it (only Coro::EV does without
252     any restrictions...).
253     - add simple manpages for all backend modules.
254 root 1.40
255 root 1.39 3.0 Mon Apr 7 21:30:23 CEST 2008
256 root 1.38 - Coro::Signal changed semantics, roll our own, also cleaning
257     up the Coro implementation in general.
258     - rename Coro backend to CoroEvent.
259     - add some decision helping paragraph to the manpage that should
260 root 1.44 help people to decide whether AnyEvent is the right thing for them.
261 root 1.38
262 root 1.37 2.9 Mon Jan 28 13:31:54 CET 2008
263     - update for EV 3.0 API changes.
264    
265 root 1.36 2.8 Sun Nov 25 15:06:03 CET 2007
266     - waitpid can validly return 0. accept this fact of life
267     instead of reporting it to any watchers.
268    
269 root 1.35 2.7 Fri Nov 23 11:41:14 CET 2007
270 root 1.34 - force use of AnyEvent::Impl::Perl in testsuite, there is
271     too much breakage outside AnyEvent.
272 root 1.35 - deliver signals synchronously in AnyEvent::Impl::Perl
273     or any other event loop that relies on AnyEvents child
274     watcher emulation. *Could* help with hanging testsuite
275     (except when Event or EV are installed).
276 root 1.34
277 root 1.33 2.6 Fri Nov 9 20:36:35 CET 2007
278 root 1.32 - fix bug in testsuite.
279     - move EV adaptor modules to AnyEvent.
280     - add Coro+EV adaptor module.
281 root 1.26
282 root 1.31 2.55 Tue Nov 6 17:41:32 CET 2007
283 root 1.27 - add EV to the list of supported event models.
284 root 1.30 - do not auto-reset pid watchers, pass pid and status to them.
285 root 1.29 - allow a pid of zero to watch for all children in child watchers.
286 root 1.27
287 root 1.25 2.54 Wed Jul 18 17:36:23 CEST 2007
288     - work around a perl bug that results in
289     BEGIN not safe after errors--compilation aborted without
290     any discernible reason or error message by once
291     again not use'ing strict.
292    
293 root 1.24 2.53 Sun Jul 8 10:51:53 CEST 2007
294     - make Glib interface work again (spotted by elmex).
295    
296 root 1.22 2.52 Wed Mar 7 18:36:16 CET 2007
297     - child watchers stopped working permanently when
298 root 1.23 all current child watchers were destroyed.
299 root 1.22
300 root 1.21 2.51 Mon Dec 11 21:33:24 CET 2006
301     - work around bugs in perl where eval "require Module" returns
302     true even if the module couldn't be loaded :/.
303    
304 root 1.20 2.5 Mon Dec 11 02:15:28 CET 2006
305 root 1.19 - avoid $AUTOLOAD because many perls corrupt it.
306 root 1.20 - AnyEvent::detect forces autodetection.
307     - implement signal watchers (experimental)
308     (Tk does not support async signals (<= 804.027 at least),
309     so they might get delayed indefinitely on Tk).
310     - implement child watchers (experimental).
311     - moved default condvar implementation into base module, simplifying
312     most implementation modules.
313 root 1.14
314 root 1.18 2.1 Fri Nov 24 15:50:48 CET 2006
315 root 1.16 - better docs.
316     - simple testsuite.
317 root 1.17 - added AnyEvent->one_event method for special purposes.
318 root 1.16
319 root 1.15 2.0 Wed Nov 1 02:21:30 CET 2006
320 root 1.13 - INCOMPATIBLE CHANGE: poll can now either be "r" or "w" but not both.
321     - INCOMPATIBLE CHANGE: io watcher callbacks have no arguments anymore.
322     - EXPERIMENTAL:
323     new pure-perl model added, AnyEvent now always finds a suitable
324     event model.
325 root 1.12 - improved documentation.
326     - reduced cpu overhead.
327    
328 root 1.11 1.02 Fri Jan 13 14:15:40 CET 2006
329     - add COPYING to clarify license.
330    
331 root 1.10 1.01 Sun Jan 8 05:48:09 CET 2006
332     - correctly cancel Event timers, avoid memory leaks.
333    
334 root 1.9 1.0 Sun Jan 8 05:40:58 CET 2006
335 root 1.8 - allow third-party interfaces to be added at runtime.
336     - fix version number.
337    
338 root 1.7 0.9 Fri Dec 30 02:25:41 CET 2005
339 root 1.6 - fixed errors in the documentation.
340 root 1.7 - going back to using $VERSION as "load check",
341     as suggested by Jörn Reder. Let's see why I stopped using
342     this method.
343     - add 'hup' to the list of events to receive for glib
344     and generate 'rw' events for it, as some versions of
345     glib seem to require this, while this breaks other
346     (older) versions of glib.
347     - implemented PERL_ANYEVENT_VERBOSE env variable.
348 root 1.6
349 root 1.5 0.3 Sun Dec 4 10:43:33 CET 2005
350     - no changes to the code.
351     - fixed documentation.
352     - clarified some corner cases.
353     - vastly improved documentation with a long example.
354    
355 root 1.3 0.2 Thu Dec 1 22:18:49 CET 2005
356 root 1.44 - check whether a valid method was called, to avoid endless loops.
357 root 1.4 - move condvars into their own class (cleaner, safer).
358     - don't die when some modules are not available.
359     - Tk is too broken to allow for words. Will work once Tk works.
360 root 1.3
361 root 1.2 0.1 Thu Dec 1 19:44:57 CET 2005
362     - spiced up and cleaned up for release.
363    
364 root 1.1 0.01 Tue Sep 21 18:12:09 CEST 2004
365     - original version; copied from Convert::Scalar.
366