ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/libev/ev.h
(Generate patch)

Comparing libev/ev.h (file contents):
Revision 1.117 by root, Wed Jul 8 04:29:31 2009 UTC vs.
Revision 1.119 by root, Fri Jul 10 00:36:21 2009 UTC

467struct ev_loop *ev_loop_new (unsigned int flags); 467struct ev_loop *ev_loop_new (unsigned int flags);
468void ev_loop_destroy (EV_P); 468void ev_loop_destroy (EV_P);
469void ev_loop_fork (EV_P); 469void ev_loop_fork (EV_P);
470 470
471ev_tstamp ev_now (EV_P); /* time w.r.t. timers and the eventloop, updated after each poll */ 471ev_tstamp ev_now (EV_P); /* time w.r.t. timers and the eventloop, updated after each poll */
472void ev_now_update (EV_P);
473 472
474#else 473#else
475 474
476int ev_default_loop (unsigned int flags); /* returns true when successful */ 475int ev_default_loop (unsigned int flags); /* returns true when successful */
477 476
501/* if you create alternative loops you have to call ev_loop_fork on them */ 500/* if you create alternative loops you have to call ev_loop_fork on them */
502/* you can call it in either the parent or the child */ 501/* you can call it in either the parent or the child */
503/* you can actually call it at any time, anywhere :) */ 502/* you can actually call it at any time, anywhere :) */
504void ev_default_fork (void); 503void ev_default_fork (void);
505 504
506unsigned int ev_backend (EV_P); /* backend in use by loop */ 505unsigned int ev_backend (EV_P); /* backend in use by loop */
507unsigned int ev_loop_count (EV_P); /* number of loop iterations */ 506
508unsigned int ev_loop_depth (EV_P); /* #ev_loop enters - #ev_loop leaves */ 507void ev_now_update (EV_P); /* update event loop time */
509void ev_loop_verify (EV_P); /* abort if loop data corrupted */
510 508
511#if EV_WALK_ENABLE 509#if EV_WALK_ENABLE
512/* walk (almost) all watchers in the loop of a given type, invoking the */ 510/* walk (almost) all watchers in the loop of a given type, invoking the */
513/* callback on every such watcher. The callback might stop the watcher, */ 511/* callback on every such watcher. The callback might stop the watcher, */
514/* but do nothing else with the loop */ 512/* but do nothing else with the loop */
525 523
526#if EV_PROTOTYPES 524#if EV_PROTOTYPES
527void ev_loop (EV_P_ int flags); 525void ev_loop (EV_P_ int flags);
528void ev_unloop (EV_P_ int how); /* set to 1 to break out of event loop, set to 2 to break out of all event loops */ 526void ev_unloop (EV_P_ int how); /* set to 1 to break out of event loop, set to 2 to break out of all event loops */
529 527
530void ev_set_io_collect_interval (EV_P_ ev_tstamp interval); /* sleep at least this time, default 0 */
531void ev_set_timeout_collect_interval (EV_P_ ev_tstamp interval); /* sleep at least this time, default 0 */
532
533/* 528/*
534 * ref/unref can be used to add or remove a refcount on the mainloop. every watcher 529 * ref/unref can be used to add or remove a refcount on the mainloop. every watcher
535 * keeps one reference. if you have a long-runing watcher you never unregister that 530 * keeps one reference. if you have a long-running watcher you never unregister that
536 * should not keep ev_loop from running, unref() after starting, and ref() before stopping. 531 * should not keep ev_loop from running, unref() after starting, and ref() before stopping.
537 */ 532 */
538void ev_ref (EV_P); 533void ev_ref (EV_P);
539void ev_unref (EV_P); 534void ev_unref (EV_P);
540
541/*
542 * stop/start the timer handling.
543 */
544void ev_suspend (EV_P);
545void ev_resume (EV_P);
546 535
547/* 536/*
548 * convenience function, wait for a single event, without registering an event watcher 537 * convenience function, wait for a single event, without registering an event watcher
549 * if timeout is < 0, do wait indefinitely 538 * if timeout is < 0, do wait indefinitely
550 */ 539 */
551void ev_once (EV_P_ int fd, int events, ev_tstamp timeout, void (*cb)(int revents, void *arg), void *arg); 540void ev_once (EV_P_ int fd, int events, ev_tstamp timeout, void (*cb)(int revents, void *arg), void *arg);
541
542# if EV_MINIMAL < 2
543unsigned int ev_loop_count (EV_P); /* number of loop iterations */
544unsigned int ev_loop_depth (EV_P); /* #ev_loop enters - #ev_loop leaves */
545void ev_loop_verify (EV_P); /* abort if loop data corrupted */
546
547void ev_set_io_collect_interval (EV_P_ ev_tstamp interval); /* sleep at least this time, default 0 */
548void ev_set_timeout_collect_interval (EV_P_ ev_tstamp interval); /* sleep at least this time, default 0 */
549
550/*
551 * a single void * can be attached to each loop. this is intended
552 * to aid the invoke_pending/blocking callbacks.
553 */
554void ev_set_userdata (EV_P_ void *data);
555void *ev_userdata (EV_P);
556
557/*
558 * hooks to overide how and when libev invokes callbacks,
559 * and hooks that wrap the actual eventloop blocking call.
560 */
561void ev_set_invoke_pending_cb (EV_P_ void (*invoke_pending_cb)(EV_P));
562void ev_set_blocking_cb (EV_P_ void (*suspend_cb_)(EV_P), void (*resume_cb_)(EV_P));
563
564void ev_invoke_pending (EV_P); /* invoke all pending watchers */
565
566/*
567 * stop/start the timer handling.
568 */
569void ev_suspend (EV_P);
570void ev_resume (EV_P);
571#endif
572
552#endif 573#endif
553 574
554/* these may evaluate ev multiple times, and the other arguments at most once */ 575/* these may evaluate ev multiple times, and the other arguments at most once */
555/* either use ev_init + ev_TYPE_set, or the ev_TYPE_init macro, below, to first initialise a watcher */ 576/* either use ev_init + ev_TYPE_set, or the ev_TYPE_init macro, below, to first initialise a watcher */
556#define ev_init(ev,cb_) do { \ 577#define ev_init(ev,cb_) do { \

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines