| 
      event_init,  event_dispatch,   event_loop,   event_loopexit,
event_set,
     event_add,     event_del,     event_once,     event_pending,
event_initialized,
     evtimer_set, evtimer_add, evtimer_del, evtimer_pending,
     evtimer_initialized,  signal_set,  signal_add,   signal_del,
signal_pending,
     signal_initialized,    bufferevent_new,    bufferevent_free,
bufferevent_write,
     bufferevent_write_buffer,                  bufferevent_read,
bufferevent_enable,
     bufferevent_disable,  bufferevent_settimeout,  evbuffer_new,
evbuffer_free,
     evbuffer_add,   evbuffer_add_buffer,    evbuffer_add_printf,
evbuffer_drain,
     evbuffer_write,  evbuffer_read,  evbuffer_find  -  execute a
function when a
     specific event occurs
     #include <sys/time.h>
     #include <event.h>
     void
     event_init();
     int
     event_dispatch();
     int
     event_loop(int flags);
     int
     event_loopexit(struct timeval *tv);
     void
     event_set(struct event *ev, int fd, short event,
             void (*fn)(int, short, void *), void *arg);
     int
     event_add(struct event *ev, struct timeval *tv);
     int
     event_del(struct event *ev);
     int
     event_once(int fd, short event, void (*fn)(int, short,  void
*),
             void *arg, struct timeval *tv);
     int
     event_pending(struct  event *ev, short event, struct timeval
*tv);
     int
     event_initialized(struct event *ev);
     void
     evtimer_set(struct event *ev, void  (*fn)(int,  short,  void
*), void *arg);
     void
     evtimer_add(struct event *ev, struct timeval *);
     void
     evtimer_del(struct event *ev);
     int
     evtimer_pending(struct event *ev, struct timeval *tv);
     int
     evtimer_initialized(struct event *ev);
     void
     signal_set(struct  event  *ev,  int  signal, void (*fn)(int,
short, void *),
             void *arg);
     void
     signal_add(struct event *ev, struct timeval *);
     void
     signal_del(struct event *ev);
     int
     signal_pending(struct event *ev, struct timeval *tv);
     int
     signal_initialized(struct event *ev);
     struct bufferevent *
     bufferevent_new(int  fd,   evbuffercb   readcb,   evbuffercb
writecb, everrorcb,
             void *cbarg);
     void
     bufferevent_free(struct bufferevent *bufev);
     int
     bufferevent_write(struct  bufferevent  *bufev,  void  *data,
size_t size);
     int
     bufferevent_write_buffer(struct bufferevent *bufev,
             struct evbuffer *buf);
     size_t
     bufferevent_read(struct  bufferevent  *bufev,  void   *data,
size_t size);
     int
     bufferevent_enable(struct bufferevent *bufev, short event);
     int
     bufferevent_disable(struct bufferevent *bufev, short event);
     void
     bufferevent_settimeout(struct   bufferevent   *bufev,    int
timeout_read,
             int timeout_write);
     struct evbuffer *
     evbuffer_new(void);
     void
     evbuffer_free(struct evbuffer *buf);
     int
     evbuffer_add(struct  evbuffer  *buf,  u_char  *data,  size_t
size);
     int
     evbuffer_add_buffer(struct evbuffer  *dst,  struct  evbuffer
*src);
     int
     evbuffer_add_printf(struct evbuffer *buf, char *fmt, ...);
     void
     evbuffer_drain(struct evbuffer *buf, size_t size);
     int
     evbuffer_write(struct evbuffer *buf, int fd);
     int
     evbuffer_read(struct evbuffer *buf, int fd, int size);
     u_char *
     evbuffer_find(struct  evbuffer  *buf,  u_char  *data, size_t
size);
     int (*event_sigcb)(void);
     int event_gotsig;
     The event API provides a mechanism  to  execute  a  function
when a specific
     event  on a file descriptor occurs or after a given time has
passed.
     The event API needs to be initialized with event_init()  before it can be
     used.
     In order to process events, an application needs to call
     event_dispatch().   This function only returns on error, and
should replace
 the event core of the application program.
     In order to avoid races in signal handlers,  the  event  API
provides two
     variables:  event_sigcb  and event_gotsig.  A signal handler
sets
     event_gotsig to indicate that a signal  has  been  received.
The application
  sets  event_sigcb  to  a callback function.  After the
signal handler
     sets event_gotsig, event_dispatch will execute the  callback
function to
     process  received  signals.   The callback returns 1 when no
events are registered
 any more.  It can return -1 to indicate an error  to
the event library,
  causing event_dispatch() to terminate with errno set
to EINTR.
     The event_loop function provides  an  interface  for  single
pass execution
     of    pending    events.     The   flags   EVLOOP_ONCE   and
EVLOOP_NONBLOCK are recognized.
  The event_loopexit function allows the  loop  to  be
terminated after
 some amount of time has passed.  The parameter indicates
the time after
 which the loop should terminate.
     It is the responsibility of  the  caller  to  provide  these
functions with
     pre-allocated event structures.
     The  function event_set() prepares the event structure ev to
be used in
     future calls to event_add() and event_del().  The event will
be prepared
     to  call  the  function specified by the fn argument with an
int argument
     indicating the file descriptor, a short argument  indicating
the type of
     event, and a void * argument given in the arg argument.  The
fd indicates
     the file descriptor that should  be  monitored  for  events.
The events can
     be either EV_READ, EV_WRITE, or both, indicating that an application can
     read or write from the file descriptor respectively  without
blocking.
     The function fn will be called with the file descriptor that
triggered
     the event and  the  type  of  event  which  will  be  either
EV_TIMEOUT,
     EV_SIGNAL,   EV_READ,  or  EV_WRITE.   The  additional  flag
EV_PERSIST makes an
     event_add() persistent until event_del() has been called.
     Once initialized, the ev structure can  be  used  repeatedly
with
     event_add()  and  event_del() and does not need to be reinitialized unless
     the function called and/or the argument  to  it  are  to  be
changed.
     The  function  event_add() schedules the execution of the ev
event when the
     event specified in event_set() occurs or  in  at  least  the
time specified
     in  the  tv.  If tv is NULL, no timeout occurs and the function will only
     be called if a matching event occurs on the file descriptor.
The event
     in   the   ev   argument  must  be  already  initialized  by
event_set() and may not
     be used in calls to event_set() until it has  timed  out  or
been removed
     with  event_del().   If the event in the ev argument already
has a scheduled
 timeout, the old timeout will be replaced  by  the  new
one.
     The  function event_del() will cancel the event in the argument ev.  If
     the event has already executed or has never been  added  the
call will have
     no effect.
     The  function event_once() is similiar to event_set().  However, it schedules
 a callback to be called exactly once and does  not  require the caller
     to  prepare  an  event  structure.   This  function supports
EV_TIMEOUT,
     EV_READ, and EV_WRITE.
     The event_pending() function can be used  to  check  if  the
event specified
     by event is pending to run.  If EV_TIMEOUT was specified and
tv is not
     NULL, the expiration time of the event will be  returned  in
tv.
     The  event_initialized()  macro  can  be used to check if an
event has been
     initialized.
     The functions evtimer_set(), evtimer_add(), evtimer_del(),
     evtimer_initialized(), and evtimer_pending()  are  abbreviations for common
     situations  where  only a timeout is required.  The file descriptor passed
     will be 0, and the event type will be EV_TIMEOUT.
     The functions signal_set(), signal_add(), signal_del(),
     signal_initialized(),  and  signal_pending()  are  abbreviations.  The event
     type   will   be   a   persistent   EV_SIGNAL.   That  means
signal_set() adds
     EV_PERSIST.
     It is possible to disable support for epoll,  kqueue,  poll,
or select by
     setting     the    environment    variable    EVENT_NOEPOLL,
EVENT_NOKQUEUE,
     EVENT_NOPOLL, or EVENT_NOSELECT.  By setting the environment
variable
     EVENT_SHOW_METHOD, libevent displays the kernel notification
method that
     it uses.
     libevent provides an abstraction on top of the regular event
callbacks.
     This  abstraction  is  called  a buffered event.  A buffered
event provides
     input and output buffers that get filled and  drained  automatically.  The
     user  of  a buffered event no longer deals directly with the
IO, but instead
 is reading from input and writing to output buffers.
     A new bufferevent is created by bufferevent_new().  The  parameter fd
     specifies  the  file  descriptor from which data is read and
written to.
     This file descriptor is not allowed to be  a  pipe(2).   The
next three parameters
  are  callbacks.   The read and write callback have
the following
     form: void (*cb)(struct bufferevent *bufev, void *arg).  The
argument is
     specified by the fourth parameter cbarg.
     By  default  the buffered event is read enabled and will try
to read from
     the file descriptor.  The write callback is executed whenever the output
     buffer  is drained below the write low watermark, which is 0
by default.
     The bufferevent_write() function can be used to  write  data
to the file
     descriptor.   The  data is appended to the output buffer and
written to the
     descriptor automatically as it becomes available  for  writing.  The
     bufferevent_read()  function  is  used to read data from the
input buffer.
     Both functions return the amount of data written or read.
     Upon successful completion event_add() and  event_del()  return 0.  Otherwise,
 -1 is returned and the global variable errno is set to
indicate the
     error.
     kqueue(2), poll(2), select(2), timeout(9)
     The event API manpage is based on the timeout(9) manpage  by
Artur
     Grabowski.  Support for real-time signals is due to Taral.
     The event library was written by Niels Provos.
      This  documentation is neither complete nor authorative.  If
you are in
     doubt about the usage of this API then check the source code
to find out
     how  it  works,  write up the missing piece of documentation
and send it to
     me for inclusion in this man page.
OpenBSD     3.6                          August      8,      2000
[ Back ] |