Annotation of embedaddon/thttpd/fdwatch.h, revision 1.1.1.1
1.1 misho 1: /* fdwatch.h - header file for fdwatch package
2: **
3: ** This package abstracts the use of the select()/poll()/kqueue()
4: ** system calls. The basic function of these calls is to watch a set
5: ** of file descriptors for activity. select() originated in the BSD world,
6: ** while poll() came from SysV land, and their interfaces are somewhat
7: ** different. fdwatch lets you write your code to a single interface,
8: ** with the portability differences hidden inside the package.
9: **
10: ** Usage is fairly simple. Call fdwatch_get_nfiles() to initialize
11: ** the package and find out how many fine descriptors are available.
12: ** Then each time through your main loop, call fdwatch_clear(), then
13: ** fdwatch_add_fd() for each of the descriptors you want to watch,
14: ** then call fdwatch() to actually perform the watch. After it returns
15: ** you can check which descriptors are ready via fdwatch_check_fd().
16: **
17: ** If your descriptor set hasn't changed from the last time through
18: ** the loop, you can skip calling fdwatch_clear() and fdwatch_add_fd()
19: ** to save a little CPU time.
20: **
21: **
22: ** Copyright © 1999 by Jef Poskanzer <jef@mail.acme.com>.
23: ** All rights reserved.
24: **
25: ** Redistribution and use in source and binary forms, with or without
26: ** modification, are permitted provided that the following conditions
27: ** are met:
28: ** 1. Redistributions of source code must retain the above copyright
29: ** notice, this list of conditions and the following disclaimer.
30: ** 2. Redistributions in binary form must reproduce the above copyright
31: ** notice, this list of conditions and the following disclaimer in the
32: ** documentation and/or other materials provided with the distribution.
33: **
34: ** THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
35: ** ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
36: ** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
37: ** ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
38: ** FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
39: ** DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
40: ** OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
41: ** HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
42: ** LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
43: ** OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
44: ** SUCH DAMAGE.
45: */
46:
47: #ifndef _FDWATCH_H_
48: #define _FDWATCH_H_
49:
50: #define FDW_READ 0
51: #define FDW_WRITE 1
52:
53: #ifndef INFTIM
54: #define INFTIM -1
55: #endif /* INFTIM */
56:
57: /* Figure out how many file descriptors the system allows, and
58: ** initialize the fdwatch data structures. Returns -1 on failure.
59: */
60: extern int fdwatch_get_nfiles( void );
61:
62: /* Add a descriptor to the watch list. rw is either FDW_READ or FDW_WRITE. */
63: extern void fdwatch_add_fd( int fd, void* client_data, int rw );
64:
65: /* Delete a descriptor from the watch list. */
66: extern void fdwatch_del_fd( int fd );
67:
68: /* Do the watch. Return value is the number of descriptors that are ready,
69: ** or 0 if the timeout expired, or -1 on errors. A timeout of INFTIM means
70: ** wait indefinitely.
71: */
72: extern int fdwatch( long timeout_msecs );
73:
74: /* Check if a descriptor was ready. */
75: extern int fdwatch_check_fd( int fd );
76:
77: /* Get the client data for the next returned event. Returns -1 when there
78: ** are no more events.
79: */
80: extern void* fdwatch_get_next_client_data( void );
81:
82: /* Generate debugging statistics syslog message. */
83: extern void fdwatch_logstats( long secs );
84:
85: #endif /* _FDWATCH_H_ */
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>