3a11496eb634b45c86bf0a52000e085f130a979a
[yaz-moved-to-github.git] / include / yaz / poll.h
1 /* This file is part of the YAZ toolkit.
2  * Copyright (C) 1995-2008 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.5 2008-02-21 10:15:03 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_none = 0,
44     yaz_poll_read = 1,
45     yaz_poll_write = 2,
46     yaz_poll_except = 4,
47     yaz_poll_timeout = 8,
48 };
49
50 /** \brief select/poll fd info */
51 struct yaz_poll_fd {
52     /** input mask passed to select/poll */
53     enum yaz_poll_mask input_mask;
54     /** resulting mask as returned by select/poll */
55     enum yaz_poll_mask output_mask;
56     /** file descriptor to use */
57     int fd;
58     /** user-defined data */
59     void *client_data;
60 };
61
62 /** \brief poll wrapper for poll or select 
63     \param fds array of sockets to be polled
64     \param num_fds size of fds array (number of sockets)
65     \param sec number of seconds to wait (-1 for no timeout)
66     \param nsec nano seconds to wait
67     \retval -1 error
68     \retval 0 timeout
69     \retval >0 event occur on one or more sockets
70
71     This functions calls yaz_poll_poll on systems where poll is
72     available and yaz_poll_select where it it unavailable.
73 */
74 YAZ_EXPORT
75 int yaz_poll(struct yaz_poll_fd *fds, int num_fds, int sec, int nsec);
76
77 #define yaz_poll_add(var,value) var = (enum yaz_poll_mask ) ((int) var | value)
78 YAZ_END_CDECL
79
80 #endif
81 /*
82  * Local variables:
83  * c-basic-offset: 4
84  * indent-tabs-mode: nil
85  * End:
86  * vim: shiftwidth=4 tabstop=8 expandtab
87  */
88