ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/AnyEvent/Changes
Revision: 1.321
Committed: Thu Aug 6 13:45:04 2009 UTC (14 years, 9 months ago) by root
Branch: MAIN
CVS Tags: rel-4_91
Changes since 1.320: +2 -4 lines
Log Message:
4.91

File Contents

# User Rev Content
1 root 1.1 Revision history for Perl extension AnyEvent.
2    
3 root 1.321 4.91 Thu Aug 6 15:42:45 CEST 2009
4 root 1.319 - AE::Handle::starttls could get out of sync when the read buffer
5     already contains some TLS handshake.
6 root 1.318 - AE::Handle did not properly free the TLS session, causing bigger
7     memory leaks in Net::SSLeay than expected (reported by toaster).
8 root 1.320 - AE::Socket::tcp_connect will now artificially delay invoking
9     the callback to avoid returning after invoking the callback.
10 root 1.321 - convert many internal watcher uses to AE API.
11 root 1.317
12 root 1.316 4.9 Sat Aug 1 11:07:01 CEST 2009
13 root 1.308 - Glib silently fails when registering a timeout with
14     a negative value, so avoid that.
15 root 1.315 - call condvar callback immediately when it is set
16     after the condition is already signalled.
17 root 1.314 - check rbuf_max condition only after trying to consume
18     data.
19 root 1.305 - normalise signal numbers to names when using the ae's
20     signal handling, but do not document this (yet).
21 root 1.308 - pure perl signal emulation did not properly set nonblocking
22     mode on the signal pipe on win32 (this is unlikely to have caused
23     any issues).
24 root 1.310 - new module: AnyEvent::Debug.
25 root 1.309 - AnyEvent::Strict now checks that a signal was specified
26     by name (not name or number).
27     - reduce memory footprint in typical cases by ~50kb by
28 root 1.308 only compiling signal code when necessary.
29 root 1.313 - add AnyEvent::Handle->rbuf_max.
30 root 1.311 - grab the AE namespace for future new API, implement stubs for
31     said future/alternative API.
32 root 1.315 - new function: AnyEvent::Socket::format_hostport.
33 root 1.305
34 root 1.303 4.881 Tue Jul 28 12:51:53 CEST 2009
35     - work around a bug in local in pre-5.10 perls, causing
36 root 1.304 AnyEvent::Handle to recurse when it should not
37     (analyzed by elmex).
38 root 1.303
39 root 1.302 4.88 Tue Jul 28 04:04:37 CEST 2009
40 root 1.301 - re-bless the handle into a dummy package after calling
41     AnyEvent::Handle::destroy, so the user does not need to check
42     for errors after every push_write etc.
43 root 1.302 - do not attempt to run t/02_signals.t on obviously broken
44     platforms.
45 root 1.301
46 root 1.300 4.87 Sun Jul 26 02:06:16 CEST 2009
47 root 1.295 - do not attempt to linger when there is no longer a valid fh.
48 root 1.296 - enforce tls mode to be either accept or connect, do not simply
49     segfault in Net::SSLeay.
50 root 1.298 - AnyEvent::Handle can now call tcp_connect itself (new parameters
51 root 1.299 connect, on_prepare, on_connect and on_connect_error). Updated
52     tutorial accordingly.
53 root 1.297 - add AnyEvent::Impl::Irssi backend.
54 root 1.295
55 root 1.294 4.86 Mon Jul 20 23:52:29 CEST 2009
56     - since the verbose warning is not enough, explicitly document
57     that versions before 1.33 of Net::SSLeay are not secure.
58 root 1.292 - work around signal handling races in Event and (...) Event::Lib.
59 root 1.293 - try to align signal-race timer to full-second boundaries.
60     - work around Tk not liking negative timeouts.
61 root 1.292 - don't complain of different grades of environmental unfriendlyness
62 root 1.302 in IO::Async.
63 root 1.292
64 root 1.290 4.85 Sat Jul 18 06:16:14 CEST 2009
65 root 1.287 - nail the signal race problem in perl once and for all
66     (see $AnyEvent::MAX_SIGNAL_LATENCY).
67     - take advantage of Async::Interrupt if it is available.
68     - load Time::HiRes and Guard modules on demand only.
69     - add optional/recommended modules section to AnyEvent
70     documentation.
71 root 1.288 - reduce memory usage considerably (and reduce startup penalty)
72     by not using "strict", "warnings" and "overload" modules.
73 root 1.289 - work around buggy windows/openbsd perls and provide EBADMSG
74     and EPROTO ourselves when missing.
75     - improve perl 5.6 compatibility of the core event loop.
76     - made Net::SSLeay version 1.33 a soft requirement.
77 root 1.286
78 root 1.285 4.83 Fri Jul 17 16:56:26 CEST 2009
79 root 1.284 - implement AnyEvent::Socket::getprotobyname.
80 root 1.283 - AnyEvent::CondVar's will now detect recursive blocking
81 root 1.284 waits and will croak, as too many people fall into
82     this trap.
83 root 1.281 - AnyEvent::Handle will now call ->destroy on itself after
84     executing the on_error callback, instead of doing some
85     half-baked internal shutdown, for fatal errors.
86 root 1.282 - clarify on_eof behaviour w.r.t. the read queue and
87     on_read callbacks.
88 root 1.281 - ignore some possible spurious wake-ups in tcp_connect.
89 root 1.279
90 root 1.278 4.82 Sat Jul 11 00:34:55 CEST 2009
91 root 1.277 - POE and Event backends didn't accept some callable objects as
92     callbacks.
93 root 1.275 - use Config module instead of POSIX module to detect signal names
94     in AnyEvent::Strict and AnyEvent::Impl::EventLib, as the POSIX
95     module doesn't even have all POSIX signals :/.
96 root 1.276 - use more workarounds around the many refcnt/corruption bugs in
97     Event::Lib.
98     - work around a race condition in perl's select, causing t/03_child.t
99     to rarely fail.
100 root 1.275
101 root 1.274 4.81 Thu Jul 9 10:30:30 CEST 2009
102 root 1.272 - AnyEvent::Handle didn't properly diagnose write errors
103     (it expected -1 from syswrite, how lame... :).
104 root 1.268 - support file descriptors in addition to file handles
105     in AnyEvent->io.
106 root 1.265 - new env variables: PERL_ANYEVENT_RESOLV_CONF,
107 root 1.266 PERL_ANYEVENT_MAX_OUTSTANDING_DNS, PERL_ANYEVENT_CA_FILE
108     and PERL_ANYEVENT_CA_PATH.
109 root 1.267 - provide a sensible synopsis section for AnyEvent::TLS.
110 root 1.273 - add a "supported backends" section to the manpage.
111 root 1.270 - added simple io watcher test to testsuite, using a
112     portable_socketpair.
113 root 1.271 - tried to improve the stability of the Event::Lib backend,
114     YMMV.
115 root 1.265
116 root 1.264 4.8 Mon Jul 6 23:45:16 CEST 2009
117 root 1.261 - AnyEvent::DNS did not properly follow CNAME records with
118     uppercase targets.
119 root 1.262 - AnyEvent::DNS would errornously return AAAA records
120     with v4 mapped addresses (a faulty record) as ipv4 addresses,
121     causing AnyEvent::Socket to throw an exception.
122 root 1.260 - added new module AnyEvent::TLS for easier SSL/TLS context
123     creation, with many options including hostname verification,
124     secure default configuration, lots of documentation and,
125     predefined diffie-hellman keys for perfect forward security
126     and much more. get it while it's still fresh!
127     - use AnyEvent::TLS in AnyEvent::Handle for context management.
128 root 1.256 - load AnyEvent::Handle only on demand in AnyEvent::DNS,
129     so AnyEvent::Socket users have smaller memory footprint
130     in the common case.
131 root 1.258 - add AnyEvent::Handle->push_shutdown method.
132     - add an additional error message parameter to AnyEvent::Handle's
133     on_error callback (for TLS, $! is still available).
134 root 1.263 - add AnyEvent::Handle on_starttls/on_stoptls callbacks.
135 root 1.257 - make AnyEvent::Handle more robust against early conenction
136     failures (during new), and return C<undef> in that case
137     from the constructor.
138 root 1.259 - AnyEvent::Handle will now try to load only JSON::XS first,
139     then fall back to JSON.
140 root 1.262 - format_ipv4/format_ipv6 are now exported by default, for symmetry,
141     and because it was documented that way.
142 root 1.256
143 root 1.258 4.451 Fri Jul 3 00:28:58 CEST 2009
144     - do not clear rbuf when shutting down an AnyEvent::Handle
145     object - doing so breaks AnyEvent::HTTP.
146    
147 root 1.255 4.45 Mon Jun 29 22:59:26 CEST 2009
148     - a write error could cause AnyEvent::Handle to create
149     an I/O watcher with an undefined $fh.
150 root 1.251 - special-case mapped ipv4 addresses in both
151     AnyEvent::Socket::format_address and parse_address,
152     to treat them just like ipv4 addresses.
153 root 1.254 - updated and overhauled the AnyEvent::Intro doc.
154 root 1.252 - implement AnyEvent::Socket::format_ipv4/ipv6.
155     - slightly speed up portable_pipe/socketpair.
156 root 1.255 - expand condvar begin/end documentation.
157 root 1.250
158 root 1.249 4.42 Fri Jun 26 08:32:18 CEST 2009
159 root 1.248 - preliminary and neccesarily incomplete support for IO::Async.
160 root 1.247 - reset SIGCHLD to DEFAULT when AnyEvent is loaded, in
161     case it was set to IGNORE, to ensure we can catch child statuses
162     even when the calling env acts stupidly.
163 root 1.248 - updated benchmarks with IO::Async, which performs very well.
164 root 1.247
165 root 1.245 4.412 Wed Jun 24 01:35:57 CEST 2009
166 root 1.242 - support an "untaint" attribute for AnyEvent::DNS
167     and set it on the default resolver.
168 root 1.241 - implement and document AnyEvent::Impl::Perl::loop.
169 root 1.242 - remove all anyevent-env variables from %ENV
170     when running in tainted mode.
171 root 1.244 - mention and extend the IO::Lambda benchmark.
172 root 1.241
173 root 1.240 4.411 Sun Jun 7 18:48:02 CEST 2009
174 root 1.239 - do not try to use F_SETFD on windows.
175    
176 root 1.238 4.41 Thu May 14 06:40:11 CEST 2009
177 root 1.236 - work around issues in older perls (5.8.0?) when
178     a signal handler is deleted from the %SIG hash.
179 root 1.237 - use POSIX::_exit in child test, to avoid running
180     destructors.
181     - speed up CHLD handling by relying on SIGCHLD being
182     synchronously delivered, even when we roll our own
183     implementation.
184 root 1.238 - AnyEvent::DNS: add the "dname" resource record name
185     for cosmetic reasons.
186 root 1.235
187 root 1.234 4.4 Sun Apr 26 20:12:33 CEST 2009
188     - implemented idle watchers, where applicable.
189 root 1.232 - AnyEvent->time died when Event backend was in use.
190     - fix a memleak in the Tk backend.
191     - sped up Tk timer handling.
192 root 1.233 - clip negative "after" values to 0 in AnyEvent::Impl::Event
193     to avoid spamming out warning messages.
194 root 1.232 - fix Qt timers without interval.
195 root 1.242 - avoid Qt zero-timeout special case, in old libqt's.
196 root 1.232
197 root 1.231 4.352 Mon Apr 20 16:31:11 CEST 2009
198 root 1.229 - fix AnyEvent::Strict error messages for child watchers.
199 root 1.230 - fix/update Makefile.PL "recommends" versions.
200     - add AnyEvent->now_update.
201 root 1.229
202 root 1.228 4.351 Sat Apr 11 07:56:14 CEST 2009
203 root 1.225 - actually make the signal pipe work under win32.
204 root 1.227 - localise $! in signal handler to avoid changing $!, although
205     perl itself does not seem to save/restore errno either.
206 root 1.226 - set the cloexec flag on the signal pipe (normally set by perl too).
207 root 1.225
208 root 1.224 4.35 Fri Mar 27 11:48:20 CET 2009
209 root 1.220 - event models relying on AnyEvent's signal watcher emulation did
210     invoke the callback asynchronously, contradicting documentation
211     and causing signals to get lost (this includes AnyEvent's own
212     event loop). AnyEvent now uses the standard pipe trick to make
213     callback execution synchronous to the event loop.
214 root 1.224 - AnyEvent::Handle didn't free TLS context data on DESTROY
215 root 1.223 (patch by Pavel Shaydo).
216 root 1.220 - work around the ever-incompatibly-changing API of MakeMaker.
217 root 1.221 - document that changing global variables without restoring them
218     is a bad idea in Perl (noted by Adam Rosenstein).
219 root 1.224 - AnyEvent::Strict now barfs if ->io is passed a file.
220 root 1.220
221 root 1.219 4.34 Thu Feb 12 18:32:45 CET 2009
222 root 1.218 - separately buffer TLS read data, as otherwise the read queue could
223     deadlock as receiving data is not expected while draining the
224     read queue (which cna only happen with TLS).
225 root 1.214 - raise EBADMSG error on JSON decoding errors.
226 root 1.215 - fix some minor manpage bugs (reported by Maximilian Gaß).
227     - speed up select bitmask parsing quite a bit in the pure perl
228     backend.
229 root 1.216 - use CORE::select instead of just select in AnyEvent::Impl::Perl.
230 root 1.214
231 root 1.213 4.331 Tue Jan 6 21:07:25 CET 2009
232 root 1.212 - socketpair fails on many vista machines because vista has
233     completely broken accept/getpeername and getsockname functions,
234     so we provide our own socketpair emulation that kind of works
235     (AnyEvent::Util::portable_pipe).
236     - new function: AnyEvent::Util::portable_socketpair.
237 root 1.211 - take advantage of the Guard module if it exists.
238    
239 root 1.210 4.33 Fri Nov 21 02:35:40 CET 2008
240     - AnyEvent::Strict did errornously flag a fileno of 0 as
241     illegal.
242 root 1.206 - reduce memory usage and slightly speed up the pure perl backend
243     by only storing the file descriptor, not the file handle.
244 root 1.207 - add missing autocork method to AnyEvent::Handle (reported
245     by Adam Rosenstein).
246 root 1.209 - AnyEvent::DNS->resolve errornously documented an $rcode result
247 root 1.208 argument, but there isn't (spotted by Henrik Krohns).
248 root 1.209 - the naked truth about Tk - it's basically unmaintained.
249 root 1.206
250 root 1.205 4.32 Mon Nov 3 22:46:32 CET 2008
251 root 1.204 - fix AnyEvent::Socket::resolve_sockaddr to properly support
252     unix sockets again and choose a proper default for
253     the socket type.
254     - fix call to resolve_sockaddr in tcp_connect.
255    
256 root 1.203 4.31 Thu Oct 30 04:41:48 CET 2008
257 root 1.200 - implemented AnyEvent::Handle->destroy method.
258 root 1.203 - hint about unexpected effects in TLS mode.
259 root 1.200 - speed up AnyEvent::Impl::Perl by using more arrays
260     instead of hashes without the slightest loss of readability :)
261 root 1.201 - work around a perl argument refcounting bug.
262 root 1.202 - with some perl patches applied, AnyEvent now seems leak-free.
263 root 1.198
264 root 1.197 4.3 Fri Oct 3 09:18:43 CEST 2008
265 root 1.196 - AnyEvent will now install a no-op signal handler for SIGPIPE,
266     unless one has been installed already.
267 root 1.197 - warn about not loaidng AnyEvent::Impl::POE early enough
268     (patch by Adam Rosenstein).
269 root 1.193 - fixed a great number of bugs and corner cases in AnyEvent::Handle:
270     - fix a bug in where in SSL connect mode, the
271 root 1.191 client would first wait for some data by the server and
272 root 1.197 otherwise hang. (reported and analyzed in an absolutely
273 root 1.191 exemplary manner by Adam Rosenstein).
274 root 1.193 - fix a bug in where SSL EOF would not be treated
275 root 1.191 as stream EOF, putting the connection into a hung state.
276 root 1.197 (reported and analyzed in an absolutely exemplary manner by Adam
277 root 1.191 Rosenstein).
278 root 1.193 - fix a potential segfault when the TLS context
279 root 1.191 would go missing in a read callback (e.g. due to stoptls) -
280     Net::SSLeay of course makes no type checking whatsoever.
281 root 1.192 - AnyEvent::Handle will not stop the read watcher in TLS mode.
282     - AnyEvent::Handle->stoptls will send a TLS close notify
283     instead of simply destroying the stream now.
284 root 1.195 - fix a bug where large blocks of data written in TLS mode
285     would not be sent unless triggered by receives.
286 root 1.193 - on_drain will now take the tls write buffer into account.
287     - SSL operations have been streamlined a bit and should be faster
288     now, more to come, though.
289 root 1.194 - added a FAQ section, will document nontrivial issues in there.
290 root 1.191
291 root 1.190 4.234 Mon Sep 29 04:08:13 CEST 2008
292 root 1.189 - fix child watcher documentation: only child exits will be reported,
293     no trace events.
294 root 1.190 - mention SIGPIPE in AnyEvent::Handle.
295     - perl backend will now use POSIX::times as monotonic clock
296 root 1.188 when available and the monotonic clock option is not.
297 root 1.187 - run even without Time::HiRes in some cases now, but do not
298 root 1.190 provide sub-second accuracy (all *supported* perl versions have
299 root 1.187 Time::HiRes).
300    
301 root 1.186 4.233 Fri Aug 22 01:48:05 CEST 2008
302     - fix a bug in the testsuite, causing a hang.
303     - clarified lots of AnyEvent::Handle constructor arguments.
304    
305 root 1.185 4.232 Thu Aug 21 20:44:25 CEST 2008
306     - fix a bug in AnyEvent::Handle that could cause two fatal error
307     callbacks on EOF, which caused AnyEvent::HTTP to signal success twice
308     (testcase by Leon Brocard).
309     - clarified on_eof/on_error documentation a bit.
310    
311 root 1.184 4.231 Tue Jul 29 13:12:15 CEST 2008
312     - remove some debugging code left in AnyEvent::Util::fork_call
313     (and no, it's impossible to implement with the broken windows
314     perls without resource leaks or worse).
315    
316 root 1.183 4.23 Tue Jul 29 12:19:59 CEST 2008
317 root 1.177 - document the first parameter passed to condvar callbacks to be
318     the callback.
319 root 1.178 - add AnyEvent::Socket::{ntoa,aton} aliases.
320 root 1.180 - optimize the AE::Handle->push_read (line) for the default
321 root 1.179 eol marker.
322 root 1.180 - optimize push_read (packstring|storable) for small packets.
323 root 1.182 - invoke on_error callback when no on_eof callback is set.
324 root 1.180 - fix a bug in push_read (storable) of unknown impact.
325 root 1.177
326 root 1.176 4.22 Sun Jul 20 16:34:13 CEST 2008
327 root 1.174 - new function AnyEvent::Socket::parse_hostport.
328 root 1.175 - as the bulkheads at microsoft can't even get getprotobyname reliably
329     working on their shitty fucking broken os we need to hardcode
330     some common protocol numbers in AnyEvent::Socket. How can
331     people even bother with such a pile of shit as windows.
332 root 1.174
333 root 1.173 4.21 Thu Jul 17 14:40:05 CEST 2008
334 root 1.171 - INCOMPATIBLE CHANGE: AnyEvent::Util::fork_call now has a prototype
335     which is incompatible to previous invocation syntax.
336 root 1.172 - work around more windows perl bugs in fork_call. I cannot imagine
337     why anybody would bother implementing fork in such an obviously
338     unusable way.
339     - avoid calling $do_retry if the request has already finished in
340     AnyEvent::DNS, thus avoiding an exception (reported by Anatoly
341     K. Sharifulin).
342 root 1.170
343 root 1.169 4.2 Sat Jul 12 22:42:11 CEST 2008
344 root 1.165 - support an "interval" argument for repeating timers.
345 root 1.164 - fix a bug in the pure perl event loop that caused timers to
346     be delayed under some circumstances.
347 root 1.167 - implement optional argument checking via PERL_ANYEVENT_STRICT.
348 root 1.169 - not importing anything from Event causes it to malfunction
349     and not use Time::HiRes, work around this bug.
350     - more bug workarounds against the endlessly broken Tk module,
351 root 1.168 seems to work now on 32 bit machines, but less so on 64 bit.
352 root 1.164 - minor optimisations applied to most backends.
353    
354 root 1.163 4.161 Fri Jul 4 14:24:48 CEST 2008
355 elmex 1.162 - fixed the t/handle/02_write.t, it read after write, with the
356 root 1.163 assumption that all data could be written before read
357     (reported by Jim Razmus).
358 elmex 1.162
359 root 1.161 4.160 Thu Jul 3 04:02:21 CEST 2008
360 root 1.160 - re-registering signal watchers after unregistering one did
361     not work if a backend falls back on AnyEvent's default
362     implementation (also affected child watchers).
363 root 1.159 - new AnyEvent::Handle options: autocork and no_delay.
364    
365 root 1.158 4.152 Sun Jun 22 14:15:44 CEST 2008
366 root 1.159 - allow for 32-bit perls that implement shifts differently
367     on different architectures in parse_ipv4 (reported and
368 root 1.158 analysed by Keiichi DAIBA).
369    
370 root 1.157 4.151 Fri Jun 6 17:34:24 CEST 2008
371     - make sure specifying _only_ on_read and never pushing reads
372     works.
373    
374 root 1.155 4.15 Fri Jun 6 13:00:46 CEST 2008
375 root 1.154 - the pure perl backend would keep some watchers alive when more than
376     one watcher was registered for the same fd.
377 root 1.155 - new "packstring" and "storable" read and write types
378     for AnyEvent::Handle.
379 root 1.156 - allow on_eof handler to be called after on_error with EPIPE returns.
380 root 1.153 - do not immediately call on_read callback in handle constructor.
381    
382 root 1.152 4.14 Thu Jun 5 20:29:31 CEST 2008
383 elmex 1.149 - Fixed a bug in DNS SRV priority sorting.
384 root 1.150 - AnyEvent::Util::guard now reports runtime errors while
385     executing the guard block as warnings.
386 root 1.152 - handle 0-byte-reads just before EOF correctly in AnyEvent::Handle.
387 elmex 1.149
388 root 1.148 4.13 Thu Jun 5 00:47:59 CEST 2008
389 root 1.146 - AnyEvent::DNS only followed cname chains with length 2,
390     contrary to documentation. bumped it up to 10, thanks to
391     microsoft, the current broken-dns-config-king.
392 root 1.147 - AnyEvent::DNS didn't check for socket return status
393     but instead relied on perl not creating filehandles in that
394     case - too bad it gives you a bogus file handle (reported
395     and analysed by Vladimir Timofeev).
396 root 1.145 - fix queue management logic in AnyEvent::Handle:
397     when on_read was registered, the queue was empty
398     and no progress could be made AnyEvent::Handle would
399     enter an endless loop.
400     - correctly start reading again when the handle became
401     busy again after idling.
402 root 1.146 - correctly treat tls shut-downs as EOF condition
403     (for the time being, would be nice to have a callback for that).
404 root 1.145 - correctly call eof callback under all conditions
405     (hopefully).
406 root 1.146 - the timeout callback did not expect that $self can go
407     away any time.
408 root 1.145
409 root 1.144 4.12 Tue Jun 3 10:58:04 CEST 2008
410     - include AnyEvent::Intro, a tutorial for anyevent,
411     anyevent::socket and anyevent::handle.
412 root 1.143 - allow more options in on_error.
413 root 1.142
414 root 1.141 4.11 Fri May 30 23:42:25 CEST 2008
415 root 1.135 - INCOMPATIBLE CHANGE: replace ptr by real PTR lookup, provide
416     reverse_lookup and reverse_verify to replace it, support
417     v4mapped and v4compat addresses.
418 root 1.129 - provide more documentation for the resolver class.
419 root 1.130 - really replace longest run of :0: by :: in format_address,
420     also properly convert :: and ::1 again.
421 root 1.134 - support NAPTR record name and decode it.
422 root 1.133 - implement random weight sampling for SRV records, as per
423     rfc 2782.
424 root 1.137 - correctly abort on srv-record targets of ".".
425     - added AnyEvent::DNS::wait_for_slot.
426 root 1.138 - in the unlikely event of a virtual circuit connection
427     being invalidated by a delayed udp reply, AnyEvent::DNS
428     could die. this has been fixed.
429     - plug a probable memleak in the DNS vc code.
430     - use configured timeout also for VC request phase.
431 root 1.139 - implement timeout and max_outstanding methods
432     for resolver class.
433 root 1.140 - update version numbers in all modules.
434 root 1.129
435 root 1.128 4.1 Thu May 29 05:45:40 CEST 2008
436 root 1.123 - INCOMPATIBLE CHANGE: renamed xxx_ip functions to xxx_address
437     which mirrors their purpose better (old names still available
438     for a while). Also moved AnyEvent::DNS::addr to
439     AnyEvent::Socket::resolve_sockaddr.
440 root 1.127 - implement AnyEvent->time and AnyEvent->now.
441 root 1.124 - fix IPv6 support in pack_sockaddr.
442 root 1.123 - officially un-experimentalise all newly introduced code.
443     - support unix domain sockets everywhere by specifying
444     a host of "unix/" and the pathname as service.
445 root 1.126 - implement an activity timeout in AnyEvent::Handle.
446 root 1.122 - added a regex read type to AnyEvent::Handle.
447     - added a json read/write type to AnyEvent::Handle.
448 root 1.118 - always croak in on_error in AnyEvent::Handle.
449     - document how to subclass AnyEvent::Handle.
450 root 1.120 - implement AnyEvent::Util::fork_call.
451 root 1.127 - add support for IPv6 nameservers and nameserver statements.
452 root 1.121 - work around _yet_ _another_ windows perl bug in where empty
453     select masks cause errors in the pure perl backend (this
454     workaround cannot be implemented for the other event loops,
455     but EV also works around this).
456 root 1.123 - supply AnyEvent::Socket::address_type and make good use of it.
457 root 1.122 - clarify and fix the Handle documentation w.r.t $self vs. $handle
458     vs. callback arguments.
459 root 1.127 - add some recommends to the META.yml.
460 root 1.117
461 root 1.116 4.05 Mon May 26 19:44:06 CEST 2008
462     - some platforms ignore the rfc and prepend an extra sa_len member to
463     the sockaddr structure, cater for those. also use sockaddr_family,
464     didn't know it was there, but comes in handy for the workaround.
465 root 1.114 - undo the import WIN32 hack.
466    
467 root 1.113 4.04 Mon May 26 08:03:31 CEST 2008
468 root 1.109 - try to work around yet another windows bug: failed connects are reported
469 root 1.110 as if it were out-of-band data. windows users: you suck. Only
470     EV, Glib, Event and the pure perl backend can handle this condition.
471 root 1.111 - optimize write algorithm in AnyEvent::Handle.
472 root 1.106 - properly parse PERL_ANYEVENT_PROTOCOLS and use the info correctly.
473 root 1.112 - tcp_connect now properly iterates through all targets.
474 root 1.104 - check wether IPv6 sockets can actually be created, otherwise, disable ipv6
475 root 1.114 support entirely. also hardcode some AF_INET6 constants for the
476 root 1.107 sake of perl 5.8.
477 root 1.106 - vastly improved nameserver/suffix detection algorithm for windows
478     (still a hack...)
479     - try to use a fallback dns server if no dns servers could be found.
480 root 1.108 - splatter around some local $SIG{__DIE__}'s to work around bad
481     die handlers.
482 root 1.104
483 root 1.102 4.03 Sun May 25 05:05:57 CEST 2008
484 root 1.100 - work around perl bugs on windows, where perl returns undocumented
485     error codes for sysread, syswrite etc.
486 root 1.96 - fix AnyEvent::Handle::unshift_read to really unshift and not push.
487 root 1.97 - AnyEvent::Handle could sometimes stumble over 0-byte writes.
488 root 1.101 - fix unpack_sockaddr, now works for AF_INET6 sockaddr's.
489 root 1.100 - updated documentation.
490 root 1.103 - lots of workarounds for perl 5.8 quirks.
491 root 1.98 - implement a more flexible type system for both reads and writes
492     in AnyEvent::Handle.
493 root 1.101 - support IPv6 in tcp_server.
494     - pass local hostname and port to the prepare callback in tcp_server.
495 root 1.99 - make types extendable in AnyEvent::Handle.
496 root 1.100 - croak, not die, in AnyEvent::Handle;
497 root 1.96
498 root 1.95 4.0 Sat May 24 19:58:08 CEST 2008
499 root 1.88 - added (experimental) AnyEvent::DNS module.
500     - added (experimental) AnyEvent::Socket module.
501 root 1.93 - added (experiemntal) support for TLS/SSL in AnyEvent::Handle.
502 root 1.90 - make condvar->end call ->send as documented.
503     - make condvar constructor support the documented cb => argument.
504 root 1.94 - overload condvars so you can use them instead of code references.
505 root 1.93 - support more of the POSIX forms instead of a pure dotted quad for
506 root 1.89 verbatim ip addresses.
507 root 1.88 - AnyEvent::Socket::inet_aton will use AnyEvent::DNS now and not fork anymore.
508 root 1.87 - try very hard not to freeze on broken windows perls.
509 root 1.86 - make on_eof optional in AnyEvent::Handle.
510 root 1.83 - support service names in tcp_connect and tcp_server.
511 root 1.84 - work around netbsd/openbsd bug causing unix sockets not to
512 root 1.121 become writable until empty.
513 root 1.81 - only make a dummy read for error detection when getpeername
514     returns ENOTCONN.
515 root 1.181 - defend AnyEvent::Util::inet_aton against Coro::LWP's brutal
516 root 1.82 override.
517 root 1.91 - new AnyEvent::Guard::cancel.
518 root 1.81
519 root 1.80 3.5 Sat May 17 23:17:14 CEST 2008
520 root 1.79 - gracefully deal with systems not defining CLOCK_MONOTONIC
521     (as opposed to not supporting the clock itself, which worked in 3.41).
522 root 1.77 - added AnyEvent::Util::tcp_connect and AnyEvent::Util::tcp_server
523     helpers, to replace the ill-designed AnyEvent::Socket class.
524     - added some examples (eg/connect, eg/handle).
525     - added AnyEvent::Util::guard.
526     - AnyEvent::Util now exports most of its functions.
527 elmex 1.74 - fixed a bug in *_read_chunk, where the callback was called with $self as
528     first and second argument.
529 root 1.77 - simplified and fixed regex handling in AnyEvent::Handle::*_read_line.
530 root 1.72 - fix manpage condvars examples to use new syntax.
531 root 1.78 - considerably improve inet_aton with EV::ADNS backend to support
532     cname chains (common dns configuration bug, e.g. with www.google.de)
533     and aaaa records if no a record could be found.
534 root 1.72
535 root 1.71 3.41 Sun May 11 19:53:13 CEST 2008
536     - work around a bug in perl 5.8.8's local. Reported by Yi Ma Mao.
537    
538 root 1.70 3.4 Sun May 11 00:29:25 CEST 2008
539 root 1.181 - complete re-implementation of condvars with a hopefully much more useful
540 root 1.70 API (backward compatible functions exist but are undocumented).
541 root 1.69 - AnyEvent::Handle fully rewritten with a hopefully more powerful API
542     (still subject to change).
543 root 1.63 - take advantage of CLOCK_MONOTONIC, if available, in AnyEvent::Impl::Perl.
544 root 1.68 - provide AnyEvent::post_detect and @AnyEvent::post_detect, which
545 root 1.67 allows module authors to avoid forcing event loop detection.
546     (used by Coro::AIO, Coro::BDB, Coro::AnyEvent for example).
547 root 1.66 - remove coro backends: Coro now provides generic support for AnyEvent
548     via Coro::AnyEvent.
549 root 1.63
550 root 1.62 3.3 Mon Apr 28 09:51:06 CEST 2008
551     - added AnyEvent::Handle, AnyEvent::Socket and AnyEvent::Util modules.
552 root 1.55 - fix a bug in the pure perl backend that kept watchers alive
553     when multiple watchers were registered for the same fh/poll combo.
554 root 1.54 - add a benchmark section showing AnyEvent overhead and comparing
555     the different event loops with each other.
556 root 1.56 - prefer pure perl over tk when autoprobing, as it's about as fast,
557     but doesn't crash with many watchers.
558 root 1.62 - declare Qt support non-experimental.
559 root 1.56 - clarify the confusing section about the file descriptor being
560     kept alive.
561     - document the race between loading of an event module and
562     child processes exiting.
563 root 1.53 - support POE as "backend" (with some caveats, POE is not generic
564 root 1.54 enough, and darn slow).
565 root 1.53 - support Wx and Prima through POE.
566 root 1.60 - optimise perl backend to use 20% less memory and take advantage
567 root 1.62 of typical timeout behaviour. It can now compete with
568 root 1.60 select/poll-based C event loops in most cases (it is usually
569     faster than Event and Glib :).
570 root 1.59 - roughly cut EV memory use in half and increase its speed by 30%,
571 root 1.62 by removing undocumented functionality. Did something similar
572     to other event loops where possible.
573 root 1.53
574 root 1.50 3.2 Thu Apr 24 10:10:40 CEST 2008
575 root 1.51 - do not die when anyevent watchers are destroyed while running callbacks
576     in the pureperl backend (could only happen when two watchers are registered
577     for the same fh/poll combo).
578     - support autoloading for child watchers, was broken in all versions.
579 root 1.47 - implement PERL_ANYEVENT_MODEL env variable.
580 root 1.49 - (experimental) implement interface to the (very crashy/buggy) Event::Lib module.
581     - (experimental) implement interface to the Qt module (cannot be autoprobed).
582 root 1.52 - this release is IO:AnyEvent-proof.
583 root 1.47
584 root 1.46 3.12 Tue Apr 22 07:11:46 CEST 2008
585     - reinstate AUTHOR section that got lost somehow.
586     - do not hang in the testsuite with badly broken perls (activestate,
587     strawberry...), but instead diagnose the problem and continue.
588     - use INT instead of CHLD in an attempt to support broken windows perls
589     better (this decreases the test quality, unfortunately).
590     - do not send the signal to the process group
591     (no problem for CHLD, bad for INT :).
592    
593 root 1.45 3.11 Sat Apr 19 06:57:31 CEST 2008
594     - major documentation rework.
595     - document the fact that child watchers only watch for zombies.
596     - fix the child watcher example.
597    
598 root 1.43 3.1 Wed Apr 16 17:09:01 CEST 2008
599 root 1.40 - work around recurring bugs in Tk by dup'ing filehandles, the
600 root 1.43 only method with good success chances on Tk (the bugs apparently
601     don't get fixed anytime soon).
602 root 1.42 - lift the restriction of only one watcher per fh direction
603     (as the Tk bug workaround also lifts it and only Tk imposed
604     such strong limits).
605 root 1.41 - changed probe order to prefer coro adaptors.
606     - explain why recursion into the event loop is not supported
607     unless the backend supports it (only Coro::EV does without
608     any restrictions...).
609     - add simple manpages for all backend modules.
610 root 1.40
611 root 1.39 3.0 Mon Apr 7 21:30:23 CEST 2008
612 root 1.38 - Coro::Signal changed semantics, roll our own, also cleaning
613     up the Coro implementation in general.
614     - rename Coro backend to CoroEvent.
615     - add some decision helping paragraph to the manpage that should
616 root 1.44 help people to decide whether AnyEvent is the right thing for them.
617 root 1.38
618 root 1.37 2.9 Mon Jan 28 13:31:54 CET 2008
619     - update for EV 3.0 API changes.
620    
621 root 1.36 2.8 Sun Nov 25 15:06:03 CET 2007
622     - waitpid can validly return 0. accept this fact of life
623     instead of reporting it to any watchers.
624    
625 root 1.35 2.7 Fri Nov 23 11:41:14 CET 2007
626 root 1.34 - force use of AnyEvent::Impl::Perl in testsuite, there is
627     too much breakage outside AnyEvent.
628 root 1.35 - deliver signals synchronously in AnyEvent::Impl::Perl
629     or any other event loop that relies on AnyEvents child
630     watcher emulation. *Could* help with hanging testsuite
631     (except when Event or EV are installed).
632 root 1.34
633 root 1.33 2.6 Fri Nov 9 20:36:35 CET 2007
634 root 1.32 - fix bug in testsuite.
635     - move EV adaptor modules to AnyEvent.
636     - add Coro+EV adaptor module.
637 root 1.26
638 root 1.31 2.55 Tue Nov 6 17:41:32 CET 2007
639 root 1.27 - add EV to the list of supported event models.
640 root 1.30 - do not auto-reset pid watchers, pass pid and status to them.
641 root 1.29 - allow a pid of zero to watch for all children in child watchers.
642 root 1.27
643 root 1.25 2.54 Wed Jul 18 17:36:23 CEST 2007
644     - work around a perl bug that results in
645     BEGIN not safe after errors--compilation aborted without
646     any discernible reason or error message by once
647     again not use'ing strict.
648    
649 root 1.24 2.53 Sun Jul 8 10:51:53 CEST 2007
650     - make Glib interface work again (spotted by elmex).
651    
652 root 1.22 2.52 Wed Mar 7 18:36:16 CET 2007
653     - child watchers stopped working permanently when
654 root 1.23 all current child watchers were destroyed.
655 root 1.22
656 root 1.21 2.51 Mon Dec 11 21:33:24 CET 2006
657     - work around bugs in perl where eval "require Module" returns
658     true even if the module couldn't be loaded :/.
659    
660 root 1.20 2.5 Mon Dec 11 02:15:28 CET 2006
661 root 1.19 - avoid $AUTOLOAD because many perls corrupt it.
662 root 1.20 - AnyEvent::detect forces autodetection.
663     - implement signal watchers (experimental)
664     (Tk does not support async signals (<= 804.027 at least),
665     so they might get delayed indefinitely on Tk).
666     - implement child watchers (experimental).
667     - moved default condvar implementation into base module, simplifying
668     most implementation modules.
669 root 1.14
670 root 1.18 2.1 Fri Nov 24 15:50:48 CET 2006
671 root 1.16 - better docs.
672     - simple testsuite.
673 root 1.17 - added AnyEvent->one_event method for special purposes.
674 root 1.16
675 root 1.15 2.0 Wed Nov 1 02:21:30 CET 2006
676 root 1.13 - INCOMPATIBLE CHANGE: poll can now either be "r" or "w" but not both.
677     - INCOMPATIBLE CHANGE: io watcher callbacks have no arguments anymore.
678     - EXPERIMENTAL:
679     new pure-perl model added, AnyEvent now always finds a suitable
680     event model.
681 root 1.12 - improved documentation.
682     - reduced cpu overhead.
683    
684 root 1.11 1.02 Fri Jan 13 14:15:40 CET 2006
685     - add COPYING to clarify license.
686    
687 root 1.10 1.01 Sun Jan 8 05:48:09 CET 2006
688     - correctly cancel Event timers, avoid memory leaks.
689    
690 root 1.9 1.0 Sun Jan 8 05:40:58 CET 2006
691 root 1.8 - allow third-party interfaces to be added at runtime.
692     - fix version number.
693    
694 root 1.7 0.9 Fri Dec 30 02:25:41 CET 2005
695 root 1.6 - fixed errors in the documentation.
696 root 1.7 - going back to using $VERSION as "load check",
697     as suggested by Jörn Reder. Let's see why I stopped using
698     this method.
699     - add 'hup' to the list of events to receive for glib
700     and generate 'rw' events for it, as some versions of
701     glib seem to require this, while this breaks other
702     (older) versions of glib.
703     - implemented PERL_ANYEVENT_VERBOSE env variable.
704 root 1.6
705 root 1.5 0.3 Sun Dec 4 10:43:33 CET 2005
706     - no changes to the code.
707     - fixed documentation.
708     - clarified some corner cases.
709     - vastly improved documentation with a long example.
710    
711 root 1.3 0.2 Thu Dec 1 22:18:49 CET 2005
712 root 1.44 - check whether a valid method was called, to avoid endless loops.
713 root 1.4 - move condvars into their own class (cleaner, safer).
714     - don't die when some modules are not available.
715     - Tk is too broken to allow for words. Will work once Tk works.
716 root 1.3
717 root 1.2 0.1 Thu Dec 1 19:44:57 CET 2005
718     - spiced up and cleaned up for release.
719    
720 root 1.1 0.01 Tue Sep 21 18:12:09 CEST 2004
721     - original version; copied from Convert::Scalar.
722