f617bdda0d162e5e4ea911e10d11cf0437f70881
[yaz-moved-to-github.git] / include / yaz / poll.h
1 /*
2  * Copyright (c) 1995-2007, Index Data
3  * All rights reserved.
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are met:
6  *
7  *     * Redistributions of source code must retain the above copyright
8  *       notice, this list of conditions and the following disclaimer.
9  *     * Redistributions in binary form must reproduce the above copyright
10  *       notice, this list of conditions and the following disclaimer in the
11  *       documentation and/or other materials provided with the distribution.
12  *     * Neither the name of Index Data nor the names of its contributors
13  *       may be used to endorse or promote products derived from this
14  *       software without specific prior written permission.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND ANY
17  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19  * DISCLAIMED. IN NO EVENT SHALL THE REGENTS AND CONTRIBUTORS BE LIABLE FOR ANY
20  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26  */
27 /* $Id: poll.h,v 1.2 2007-11-09 19:00:08 adam Exp $ */
28
29 /**
30  * \file
31  * \brief Poll , select wrappers
32  */
33 #ifndef YAZ_POLL_H
34 #define YAZ_POLL_H
35
36 #include <stddef.h>
37 #include <yaz/yconfig.h>
38
39 YAZ_BEGIN_CDECL
40
41 /** \brief select/poll masks .. timeout is "output" only */
42 enum yaz_poll_mask {
43     yaz_poll_read = 1,
44     yaz_poll_write = 2,
45     yaz_poll_except = 4,
46     yaz_poll_timeout = 8,
47 };
48
49 /** \brief select/poll fd info */
50 struct yaz_poll_fd {
51     /** input mask passed to select/poll */
52     enum yaz_poll_mask input_mask;
53     /** resulting mask as returned by select/poll */
54     enum yaz_poll_mask output_mask;
55     /** file descriptor to use */
56     int fd;
57     /** user-defined data */
58     void *client_data;
59 };
60
61 /** \brief socket poll wrapper using select
62     \param fds array of sockets to be polled
63     \param num_fds size of fds array (number of sockets)
64     \param timeout number of seconds to wait (-1 for no timeout)
65     \retval -1 error
66     \retval 0 timeout
67     \retval >0 event occur on one or more sockets
68 */
69 int yaz_poll_select(struct yaz_poll_fd *fds, int num_fds, int timeout);
70
71 /** \brief socket poll using poll
72     \param fds array of sockets to be polled
73     \param num_fds size of fds array (number of sockets)
74     \param timeout number of seconds to wait (-1 for no timeout)
75     \retval -1 error
76     \retval 0 timeout
77     \retval >0 event occur on one or more sockets
78 */
79 int yaz_poll_poll(struct yaz_poll_fd *fds, int num_fds, int timeout);
80
81 /** \brief poll wrapper for poll or select 
82     \param fds array of sockets to be polled
83     \param num_fds size of fds array (number of sockets)
84     \param timeout number of seconds to wait (-1 for no timeout)
85     \retval -1 error
86     \retval 0 timeout
87     \retval >0 event occur on one or more sockets
88
89     This functions calls yaz_poll_poll on systems where poll is
90     available and yaz_poll_select where it it unavailable.
91 */
92 int yaz_poll(struct yaz_poll_fd *fds, int num_fds, int timeout);
93
94 YAZ_END_CDECL
95
96 #endif
97 /*
98  * Local variables:
99  * c-basic-offset: 4
100  * indent-tabs-mode: nil
101  * End:
102  * vim: shiftwidth=4 tabstop=8 expandtab
103  */
104