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

Comparing libev/ev.h (file contents):
Revision 1.118 by root, Thu Jul 9 09:11:20 2009 UTC vs.
Revision 1.119 by root, Fri Jul 10 00:36:21 2009 UTC

500/* 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 */
501/* you can call it in either the parent or the child */ 501/* you can call it in either the parent or the child */
502/* you can actually call it at any time, anywhere :) */ 502/* you can actually call it at any time, anywhere :) */
503void ev_default_fork (void); 503void ev_default_fork (void);
504 504
505unsigned int ev_backend (EV_P); /* backend in use by loop */ 505unsigned int ev_backend (EV_P); /* backend in use by loop */
506unsigned int ev_loop_count (EV_P); /* number of loop iterations */
507unsigned int ev_loop_depth (EV_P); /* #ev_loop enters - #ev_loop leaves */
508void ev_loop_verify (EV_P); /* abort if loop data corrupted */
509 506
510void ev_now_update (EV_P); /* update event loop time */ 507void ev_now_update (EV_P); /* update event loop time */
511void ev_invoke_pending (EV_P); /* invoke all pending watchers */
512 508
513#if EV_WALK_ENABLE 509#if EV_WALK_ENABLE
514/* 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 */
515/* callback on every such watcher. The callback might stop the watcher, */ 511/* callback on every such watcher. The callback might stop the watcher, */
516/* but do nothing else with the loop */ 512/* but do nothing else with the loop */
527 523
528#if EV_PROTOTYPES 524#if EV_PROTOTYPES
529void ev_loop (EV_P_ int flags); 525void ev_loop (EV_P_ int flags);
530void 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 */
531 527
532void ev_set_io_collect_interval (EV_P_ ev_tstamp interval); /* sleep at least this time, default 0 */
533void ev_set_timeout_collect_interval (EV_P_ ev_tstamp interval); /* sleep at least this time, default 0 */
534
535/* 528/*
536 * 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
537 * 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
538 * 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.
539 */ 532 */
540void ev_ref (EV_P); 533void ev_ref (EV_P);
541void ev_unref (EV_P); 534void ev_unref (EV_P);
542
543/*
544 * stop/start the timer handling.
545 */
546void ev_suspend (EV_P);
547void ev_resume (EV_P);
548 535
549/* 536/*
550 * 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
551 * if timeout is < 0, do wait indefinitely 538 * if timeout is < 0, do wait indefinitely
552 */ 539 */
553void 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
554#endif 573#endif
555 574
556/* 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 */
557/* 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 */
558#define ev_init(ev,cb_) do { \ 577#define ev_init(ev,cb_) do { \

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines