ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/EV/Changes
Revision: 1.215
Committed: Fri Mar 1 11:20:07 2013 UTC (11 years, 2 months ago) by root
Branch: MAIN
CVS Tags: EV-rel-4_15
Changes since 1.214: +2 -0 lines
Log Message:
4.15

File Contents

# User Rev Content
1 root 1.143 Revision history for Perl extension EV
2 root 1.1
3 root 1.185 Changes marked with (libev) are changes in libev, and have more
4     documentation in the libev Changes file.
5    
6 root 1.215 4.15 Fri Mar 1 12:15:53 CET 2013
7     - (libev) upgrade to 4.15 - too many changes to list.
8 root 1.214 - EV::run now returns a boolean.
9 root 1.211 - API version 5:1.
10 root 1.214 - document that cleanup watchers are not available via perl.
11 root 1.212 - cast I32 to int in error message printf.
12 root 1.214 - remove dependencies on librt and libpthreads on GNU/Linux.
13 root 1.211
14 root 1.210 4.11 Sat Feb 4 19:56:26 CET 2012
15     - (libev) implement memory fences for (obsolete) llvm-gcc.
16    
17 root 1.209 4.10 Thu Jan 19 18:54:23 CET 2012
18     - (libev) fix a race where the workaround against the epoll fork
19     bugs caused signals to not be handled anymore.
20     - (libev) correct backend_fudge for most backends, and implement
21     a windows specific workaround to avoid looping because we call
22     both select and Sleep, both with different time resolutions.
23 root 1.207 - e_new wasn't declared static (causing very minor .so bloat).
24 root 1.208 - replace more old api names by new ones.
25 root 1.206
26 root 1.205 4.03 Tue Jan 11 14:51:05 CET 2011
27 root 1.203 - do not avoid the clock_gettime call on GNU/Linux anymore, as EV
28     links against -lpthread anyways - as a result, EV might now take
29     advantage of fast userspace clock_gettime implementations,
30     but also links against -lrt.
31 root 1.204 - (libev) lots of event port bug workarounds.
32     - (libev) officially support files in I/O watchers.
33     - (libev) new function ev_feed_signal.
34     - fix documentation parts still refering to the 3.x API.
35 root 1.203
36 root 1.202 4.02 Thu Dec 30 08:27:41 CET 2010
37     - the revents argument did not stringify correctly, as only the
38     numeric value was updated, while the string value was kept from
39     previous invocations.
40    
41 root 1.201 4.01 Sun Dec 5 12:42:13 CET 2010
42 root 1.197 - fully support EV_COMPAT3=0.
43 root 1.198 - default_fork was stupidly defined as inline.
44 root 1.199 - ask cpan to upgrade AnyEvent if < 5.29.
45 root 1.200 - support EV_EXTRA_DEFS during configuration.
46 root 1.201 - support -DEV_NO_LOOPS for snakker build.
47 root 1.197
48 root 1.196 4.00 Mon Oct 25 13:30:09 CEST 2010
49 root 1.194 - many API changes, see the manual.
50 root 1.196 - (libev) lots and lots of bugfixes, see the ev documentation.
51 root 1.187 - fix a bug where inotify usage would parse the same event
52     multiple times, causing various forms of breakage.
53     - greatly reduce stack usage for inotify (8kb to <0.5kb).
54 root 1.189 - expose ev_depth and ev_verify via the XS API.
55 root 1.196 - implement ev_cleanup watchers.
56 root 1.188 - (libev) ev_embed_stop did not correctly stop the watcher.
57     - (libev) disable poll backend on AIX.
58     - (libev) rename EV_TIMEOUT to EV_TIMER.
59     - (libev) add section on accept() problems to the manpage.
60 root 1.191 - (libev) no child watchers on win32.
61 root 1.190 - make code more aliasing compliant, in case perl is ever
62     translated to C.
63 root 1.193 - document the EV::CHECK runtime unavailability.
64 root 1.192 - ported to minix 3.1.7.
65 root 1.187
66 root 1.186 3.9 Thu Dec 31 07:59:59 CET 2009
67 root 1.182 - disable t/07* under automatic testing.
68 root 1.183 - increase t/09* timeouts as netbsd has *horribly* broken
69     select/kevent that *usually* sleep >>0.6s instead of 0.3.
70 root 1.184 - add constants EV::FLAG_NOSIGFD, EV::FLAG_NOINOTIFY and
71     EV::BACKEND_ALL.
72 root 1.185 - (libev) signalfd is no longer used by default.
73     - (libev) backport inotify code to C89.
74     - (libev) inotify file descriptors could leak into child processes.
75     - (libev) ev_stat watchers could keep an errornous extra ref on the loop.
76     - (libev) take advantage of inotify_init1, if available.
77     - (libev) the signal handling pipe wasn't always initialised under windows.
78     - changed minimum glibc requirement from glibc 2.9 to 2.7, for signalfd.
79     - (libev) only replace ev_stat.prev when we detect an actual difference.
80 root 1.182
81 root 1.181 3.8 Sun Aug 9 15:30:10 CEST 2009
82 root 1.180 - implement $loop->signal/signal_ns.
83 root 1.181 - (libev) incompatible change: do not necessarily reset signal
84     handler to SIG_DFL when a sighandler is stopped.
85     - (libev) ev_default_destroy did not properly free or zero some
86     members, potentially causing crashes and memory corruption on
87     repated ev_default_destroy/ev_default_loop calls.
88     - (libev) take advantage of signalfd on GNU/Linux systems.
89     - (libev) document that the signal mask might be in an unspecified
90     state when using libev's signal handling.
91     - (libev) take advantage of some GNU/Linux calls to set
92     cloexec/nonblock on fd creation, to avoid race conditions.
93     - implement internal glue code to interface more efficiently
94     with AnyEvent.
95 root 1.180
96 root 1.177 3.7 Fri Jul 17 16:49:16 CEST 2009
97 root 1.171 - add EV::loop_verify and EV::loop_depth.
98 root 1.172 - use output filehandle for i/o watchers waiting
99     for EV_WRITE, otherwise input filehandle.
100     - use common schmorp.h header.
101 root 1.176 - add EV::Timer->remaining.
102 root 1.175 - allow for subclassing of EV::Loop (see the exciting
103     EV::Loop::Async module for an example).
104     - added EV::invoke_pending and EV::pending_count.
105 root 1.171
106 root 1.177 - (libev) ev_unloop and ev_loop wrongly used a global variable to
107     exit loops, instead of using a per-loop variable.
108     - (libev) the ev_set_io_collect_interval interpretation has changed.
109     - add new functionality: EV::invoke_pending, EV::pending_count.
110     - add $timer->remaining.
111     - add EV::loop_depth.
112     - (libev) calling unloop in fork/prepare watchers will no longer poll
113     for new events.
114     - (libev) use GetSystemTimeAsFileTime instead of _timeb on windows,
115     for slightly higher accuracy.
116     - (libev) actually 0-initialise struct sigaction when installing
117     signals.
118    
119 root 1.170 3.6 Tue Apr 28 02:50:37 CEST 2009
120 root 1.167 - keepalive(0) could decrease the refcount of the loop
121     permanently.
122 root 1.168 - add ev_suspend/ev_resume, also make ev_now_update
123     accessible via the XS API.
124 root 1.169 - most EV::<eventtype> constants were missing and have been
125     added :/.
126     - add EV::VERSION_MAJOR/VERSION_MINOR constants.
127     - (libev) multiple timers becoming ready within an event loop
128     iteration will be invoked in the "correct" order now.
129     - (libev) do not leave the event loop early just because we have
130     no active watchers, fixing a problem when embedding a kqueue
131     loop that has active kernel events but no registered watchers
132     (reported by blacksand blacksand).
133     - (libev) correctly zero the idx values for arrays, so destroying
134     and reinitialising the default loop actually works (patch by
135     Malek Hadj-Ali).
136     - (libev) new EV::CUSTOM revents flag for use by applications.
137     - (libev) add documentation section about priorites.
138     - (libev) add a glossary to the dcoumentation.
139     - (libev) extend the ev_fork description slightly.
140     - (libev) optimize a jump out of call_pending.
141     - t/03_keepalive could fail when there was no actual error.
142 root 1.167
143 root 1.166 3.53 Sun Feb 15 02:38:20 CET 2009
144     - (libev) on win32, the event loop creation could randomly fail
145     due to an initialised variable having the wrong value.
146 root 1.165 - (libev) probe for CLOCK_REALTIME support at runtime as well and
147     fall back to gettimeofday if there is an error, to support older
148     operating systems with newer header files/libraries.
149     - prefer gettimeofday over clock_gettime by default.
150    
151 root 1.164 3.52 Wed Jan 7 21:46:14 CET 2009
152 root 1.163 - (libev) fix some issues in the select backend when in fd_set mode.
153     - (libev) due to a thinko, instead of disabling everything but
154     select on the borked OS X platform, everything but select was
155     allowed (reported by Emanuele Giaquinta).
156     - (libev) actually verify that local and remote port are matching in
157     libev's socketpair emulation, which makes denial-of-service
158     attacks harder (but not impossible - it's windows). Make sure
159     it even works under vista, which thinks that getpeer/sockname
160     should return fantasy port numbers.
161    
162 root 1.162 3.51 Wed Dec 24 23:01:59 CET 2008
163 root 1.161 - do not cache the arguments passed to callbacks if the refcount
164     indicates that the callback has stolen them.
165 root 1.159 - (libev) try to avoid librt on GNU/Linux.
166 root 1.160 - (libev) check port_getn return value dfferently, might potentially
167     avoid problems.
168 root 1.162 - (libev) fix a bug with stat watchers possibly causing freezes.
169     - (libev) work around OS X 10.5 breaking poll, now select is the
170     only viable choice left on that pile of garbage.
171 root 1.161 - play tester whore: disable some tests that typically fail only
172     on cpan tester machines.
173 root 1.159
174 root 1.158 3.49 Wed Nov 19 11:26:53 CET 2008
175 root 1.155 - fix typos in manpage (Alex Efros).
176 root 1.156 - increase timing even further, for the ever-overloaded cpan-tester
177     machines, and to the detriment of everybody else who wants a fast
178     make test.
179 root 1.157 - possible 5.6 compatibility.
180 root 1.158 - (libev) use inotify even on buggy kernels, but don't rely on it.
181     - (libev) use inotify only as an added hint on network filesystems.
182 root 1.155
183 root 1.154 3.48 Thu Oct 30 09:09:48 CET 2008
184 root 1.152 - (libev) use a generation counter to detect spurious epoll events
185 root 1.151 and recreate the kernel in such a case (sorry, it's slow, but
186     I didn't design epoll...).
187 root 1.150 - (libev) optimise away an EPOLL_CTL_ADD/MOD combo in the epoll
188     backend in some cases.
189     - (libev) use memset to initialise most arrays now and do away
190     with the init functions.
191 root 1.152 - speed up event callback invocation further (~15%), by
192 root 1.151 not creating the object reference each time.
193 root 1.153 - EV::sleep was documented, but not implemented. fun.
194 root 1.150
195     3.45 Tue Oct 21 22:20:39 CEST 2008
196     - (libev) disable inotify usage on linux <2.6.25 (kernel bug).
197 root 1.146 - (libev) ev_embed will now automatically follow fork.
198     - (libev) ev_once will now pass both io and timeout events to
199     the callback when both happen concurrently, instead of giving
200     one precedence.
201 root 1.149 - install C library documentation as EV::libev manpage (sorry, oesi).
202 root 1.150 - (libev) fix a minor performance bug in ev_stat handling.
203 root 1.146
204 root 1.145 3.44 Mon Sep 29 05:16:31 CEST 2008
205 root 1.144 - (libev) add EV::now_update and $loop->now_update.
206    
207 root 1.142 3.431 Sun Jul 13 00:19:02 CEST 2008
208     - made the EV::embed callback optional again. reported by
209     Vladimir Timofeev.
210    
211 root 1.141 3.43 Tue Jul 8 20:56:31 CEST 2008
212 root 1.140 - disabled warnings in EV.pm, the CHECK issue is now understood
213     and harmless.
214    
215 root 1.139 3.42 Mon May 26 07:36:46 CEST 2008
216 root 1.138 - (libev) work around another bug in windows perls and
217     windows itself: failed connects do NOT set read or write
218     flags in select, but this version of libev will.
219    
220 root 1.136 3.41 Thu May 22 01:39:40 CEST 2008
221 root 1.135 - (libev) fix many heap-related bugs (timers, periodics).
222 root 1.134 - (libev) improve timing stability of timers and periodics.
223 root 1.137 - expose ev_loop_verify to perl code.
224 root 1.134 - clarify documentation for periodic reschedule callbacks.
225     - verify that the passed callback argument is indeed a code
226     reference, for earlier error reporting and a nice calling
227     speed increase (as well as saving memory).
228    
229 root 1.133 3.4 Tue May 20 21:51:55 CEST 2008
230 root 1.132 - (libev) work around both a windows bug and a bug in perl's
231     select on windows when not waiting for any file descriptors.
232 root 1.131 - bundle ev.pod into the tarball, just to increase its size
233     (and for the poor internetless person).
234    
235 root 1.130 3.33 Sun May 18 12:43:04 CEST 2008
236     - (libev) use numerous enhancements such as a more
237     cache-friendly 4-heap and heap index caching for timers.
238     - remove undocumented ev_timer->at accessor.
239    
240 root 1.129 3.31 Wed Apr 16 20:48:59 CEST 2008
241     - (libev) post-last-minute fix for ev_poll.c problem.
242    
243 root 1.128 3.3 Wed Apr 16 19:04:47 CEST 2008
244 root 1.125 - (libev) linux eventfd support.
245 root 1.128 - (libev) inline more with C99 compilers.
246     - (libev) work around a number of bugs in valgrind.
247     - (libev) work around broken realloc on openbsd and darwin.
248 root 1.126 - added example to EV::MakeMaker manpage.
249 root 1.127 - add async_pending method.
250 root 1.125
251 root 1.123 3.2 Wed Apr 2 17:08:16 CEST 2008
252 root 1.117 - "ported" again to the Microsoft "C" language.
253 root 1.124 - relax testsuite timing for the benefit of freebsd users once more.
254 root 1.121 - fix EVAPI's ev_time and ev_sleep macros.
255 root 1.120 - (libev) fix select backend on 64 bit architetcures.
256 root 1.122 - (libev) ev_loop flags are now local to each invocation.
257 root 1.117
258 root 1.116 3.1 Sat Mar 8 11:41:14 CET 2008
259 root 1.113 - add ev_sync_* and ev_fork_* to EVAPI.h.
260 root 1.115 - provide EV::Embed->sweep method.
261     - new watcher type: async (not very useful in perl).
262 root 1.113
263 root 1.112 3.0 Mon Jan 28 13:23:11 CET 2008
264     - upgrade to libev-3.0.
265 root 1.111 - change child handler to incorporate tracing flag.
266    
267 root 1.110 2.01 Mon Dec 31 01:59:19 CET 2007
268     - found a minor problem in the testsuite that is only
269     caught by new Test::Harness versions (reported by Andreas
270     König).
271    
272 root 1.107 2.0 Sat Dec 22 17:47:03 CET 2007
273 root 1.100 - no longer force kqueue when enabled, enable it
274     on more systems (as its now by default not used on most).
275 root 1.95 - expose fork watchers.
276     - switch to libev's MULTIPLICITY API.
277 root 1.96 - use a slightly different include file name strategy.
278     - get rid of (unused) libevent emulation.
279 root 1.97 - 5% watcher management speedup due to callback optimisation
280     when inline closures are used, 5% slowdown due to multiplicity.
281 root 1.98 - very minimal support for dynamic event loops and embed watchers.
282 root 1.103 - fix name of prepare start/stop methods.
283 root 1.105 - create and export EV::sleep and EV::set_*_collect_interval.
284 root 1.106 - fix typos in manpage (Alex Efros).
285 root 1.95
286 root 1.94 1.86 Tue Dec 18 02:36:57 CET 2007
287 root 1.93 - add periodic->at methods.
288 root 1.92
289 root 1.91 1.85 Fri Dec 14 20:32:40 CET 2007
290 root 1.90 - further optimise epoll backend by adding a heuristic that
291     avoids EPOLL_CTL_DEL calls if possible.
292 root 1.87 - EV::signal->start was not async-signal safe.
293 root 1.89 - optimise start/stop when the fd hasn't changed.
294 root 1.87
295 root 1.86 1.8 Tue Dec 11 22:17:46 CET 2007
296 root 1.83 - API version 3:0.
297 root 1.81 - reduced fudge factor to zero for select, poll, epoll
298     and kqueue: your system better be posix-compliant
299     even in its extensions :->
300 root 1.82 - improve long-term numerical stability in periodic watchers
301     by introducing a separate offset value instead of reusing at.
302 root 1.84 - recalculate real/monotonic clocks before blocking fully
303     to avoid blocking for longer than necessary.
304 root 1.85 - fix bugs in the heap functions. this rarely lead to illegal
305     heap orderings.
306 root 1.81
307 root 1.80 1.72 Sat Dec 8 15:31:26 CET 2007
308 root 1.77 - add dummy loop arguments to some EVAPI functions
309     so that clients can use EV_A and EV_DEFAULT.
310 root 1.78 - expose ev_clear_pending.
311 root 1.79 - renamed trigger to invoke.
312 root 1.77
313 root 1.76 1.71 Fri Dec 7 19:10:24 CET 2007
314 root 1.75 - changed/implemented idle watcher priority.
315     - allow out-of-range priorities to be set.
316     - fix ->priority to actually work on started watchers.
317     - improved testsuite.
318    
319 root 1.74 1.6 Wed Dec 5 15:06:20 CET 2007
320 root 1.70 - add a missing SPAGAIN.
321 root 1.71 - ripped out EV::DNS, use EV::ADNS for a better backend.
322     - make ev_time callable from EVAPI.h.
323 root 1.72 - add EV::loop_count.
324 root 1.73 - some space optimisations.
325 root 1.70
326 root 1.69 1.5 Wed Nov 28 20:19:09 CET 2007
327 root 1.67 - add inotify backend.
328 root 1.69 - make testsuite even less sensible to timing issues,
329     add more stat tests.
330 root 1.68 - add ->attr, ->prev, ->stat calls to stat watcher.
331 root 1.67
332 root 1.66 1.4 Tue Nov 27 17:35:27 CET 2007
333 root 1.64 - work around a linux 2.4 kernel bug in child handlers.
334     - implement stat watcher interface.
335 root 1.65 - implement fork watcher interface.
336 root 1.64 - io->set did not keep the fh alive.
337     - actively check signal numbers/names to be valid.
338     - cleanups, minor fixes, new bugs.
339 root 1.66 - work around windows bugs in the testsuite.
340 root 1.64
341 root 1.63 1.3 Sun Nov 25 10:46:57 CET 2007
342     - stopping idle/check/prepare watchers could cause data corruption.
343 root 1.58 - implement and document EV::once.
344 root 1.57 - improved documentation, verify that netbsd indeed has the only
345     working kqueue implementation (out of darwin, freebsd, netbsd and
346     openbsd). Praise them!
347 root 1.62 - fix the data method so it might work.
348 root 1.59 - expose ev_ref/ev_unref to the C API.
349 root 1.61 - expose ref/unref in form of the ->keepalive method to perl.
350 root 1.58 - minor bugfixes and portability fixes.
351 root 1.57
352 root 1.56 1.2 Thu Nov 22 05:44:09 CET 2007
353     - disable kqueue by default on !netbsd, as its broken on freebsd,
354     darwin and openbsd and thus almost everywhere.
355     - add some allowance in t/01_timer.t for the uneven monotonic
356     vs. realtime clock tick on at least freebsd.
357     - add -lsocket -lnsl on solaris in case the perl guy forgot to
358     configure them.
359    
360 root 1.55 1.1 Wed Nov 21 06:08:48 CET 2007
361 root 1.53 - improved timer test to include periodics and
362     withstand small timing variations.
363 root 1.54 - many minor tweaks to libev.
364 root 1.53
365 root 1.52 1.0 Fri Nov 16 14:51:59 CET 2007
366 root 1.50 - require AnyEvent update if AnyEvent is installed.
367 root 1.51 - add solaris 10 port-based backend.
368     - add child_ns and fix check_ns.
369 root 1.52 - treat yes/no as enforcement, not as hint, when configuring,
370     documentation update (reported by Andy Grundman).
371 root 1.50
372 root 1.49 0.9 Wed Nov 14 22:24:49 CET 2007
373 root 1.45 - changed LIBEV_METHODS to LIBEV_FLAGS and the
374     way this is used inside libev.
375 root 1.46 - many, many bugfixes.
376     - add unloop constants.
377 root 1.47 - add timer test.
378 root 1.48 - ev_loop will now terminate immediately when no watchers are active.
379 root 1.45
380 root 1.44 0.8 Mon Nov 12 02:28:46 CET 2007
381 root 1.41 - fix "testsuite" again :().
382     - fix check/idle/prepare/child watcher stop.
383 root 1.42 - enourmously many fixes.
384     - rewritten select backend (mostly for win32).
385     - cache socket handles on win32.
386 root 1.43 - provide considerably finer control over configuration.
387 root 1.41
388 root 1.40 0.7 Fri Nov 9 20:37:58 CET 2007
389 root 1.39 - move AnyEvent adaptor into the AnyEvent module.
390 root 1.41 - use private copy of evdns.[ch].
391 root 1.39 - many minor fixes.
392    
393 root 1.38 0.6 Thu Nov 8 18:23:43 CET 2007
394 root 1.95 - (libev) better native win32 support.
395 root 1.35 - fix idle watchers.
396 root 1.37 - implement and document periodic reschedule callbacks.
397     - do not run dns test on !linux platforms (actually to exclude win32).
398 root 1.38 - fix (unused in EV :) poll backend.
399 root 1.34
400 root 1.33 0.51 Tue Nov 6 19:50:22 CET 2007
401 root 1.32 - fix kqueue/poll compilation issue.
402 root 1.33 - work around design issues in kqueue.
403 root 1.32 - enable kqueue by default, seems to work.
404    
405 root 1.31 0.5 Tue Nov 6 17:37:44 CET 2007
406 root 1.23 - add signal and pid mutators.
407 root 1.27 - add rstatus/rpid accessors.
408 root 1.24 - updated libev (lower cost for clock monotonic).
409 root 1.25 - support event priorities.
410 root 1.26 - try to find SIG_SIZE on perls that don't have it (Slaven Rezic).
411 root 1.28 - improved signal handling, fixed child watchers.
412 root 1.29 - experimentally add kqueue backend, completely untested.
413 root 1.30 - ported to cygwin and native win32.
414 root 1.23
415 root 1.22 0.1 Thu Nov 1 18:29:22 CET 2007
416 root 1.18 - replaced libevent by libev (total rewrite).
417     - many bugfixes w.r.t. libevent.
418     - new watcher types: periodic, check, prepare, child, idle.
419 root 1.16 - performance optimisations.
420 root 1.19 - added interactive configuration.
421 root 1.21 - added fork support.
422 root 1.16
423 root 1.14 0.03 Mon Oct 29 20:52:50 CET 2007
424 root 1.9 - add timed_io convenience constructors.
425     - improve documentation.
426 root 1.8 - support signal names in addition to signal numbers.
427 root 1.9 - support signal anyevent watchers.
428 root 1.10 - vastly improved testsuite (its all relative :).
429 root 1.11 - add EV::MakeMaker, beginning of C-level API.
430 root 1.12 - force strings to byte form.
431 root 1.6
432 root 1.5 0.02 Sun Oct 28 07:40:21 CET 2007
433 root 1.15 - call $EV::DIED in case a callback throws an exception.
434 root 1.4 - add const char * to typemap for possible 5.6 compatibility.
435 root 1.3
436     0.01 Sat Oct 27 19:10:18 CEST 2007
437     - initial release.
438    
439     0.00 Fri Oct 26 11:12:57 CEST 2007
440 root 1.1 - original version; cloned from JSON::XS
441