source: xplcommon/src/xplcommon/POSIXWaiter.h@ 1:00e7af4d1367

Last change on this file since 1:00e7af4d1367 was 1:00e7af4d1367, checked in by István Váradi <ivaradi@…>, 11 years ago

Implemented basic event waiting infrastructure

File size: 4.8 KB
Line 
1// Copyright (c) 2013 by István Váradi
2
3// This file is part of libxplcommon, a common utility library for
4// development related to X-Plane
5
6// Redistribution and use in source and binary forms, with or without
7// modification, are permitted provided that the following conditions are met:
8
9// 1. Redistributions of source code must retain the above copyright notice, this
10// list of conditions and the following disclaimer.
11// 2. Redistributions in binary form must reproduce the above copyright notice,
12// this list of conditions and the following disclaimer in the documentation
13// and/or other materials provided with the distribution.
14
15// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
16// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
19// ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
21// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
22// ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25
26// The views and conclusions contained in the software and documentation are those
27// of the authors and should not be interpreted as representing official policies,
28// either expressed or implied, of the FreeBSD Project.
29
30#ifndef XPLCOMMON_POSIXWAITER_H
31#define XPLCOMMON_POSIXWAITER_H
32//------------------------------------------------------------------------------
33
34#include "config.h"
35
36#ifdef HAVE_POLL_H
37
38//------------------------------------------------------------------------------
39
40#include <map>
41
42#include <cstdlib>
43
44#include <poll.h>
45
46//------------------------------------------------------------------------------
47
48namespace xplcommon {
49
50//------------------------------------------------------------------------------
51
52class POSIXWaitable;
53
54//------------------------------------------------------------------------------
55
56/**
57 * Class that can be used to register waitable objects and then wait
58 * for them.
59 */
60class POSIXWaiter
61{
62private:
63 /**
64 * Type for the set of waitables.
65 */
66 typedef std::map<int, POSIXWaitable*> waitables_t;
67
68 /**
69 * The set of waitables belonging to this waiter.
70 */
71 waitables_t waitables;
72
73 /**
74 * The number of waitables.
75 */
76 size_t numWaitables;
77
78public:
79 /**
80 * Construct the waiter.
81 */
82 POSIXWaiter();
83
84 /**
85 * Destroy the waiter. All waitables that still exists will be
86 * modified to point to no waiter.
87 */
88 ~POSIXWaiter();
89
90 /**
91 * Wait for any if the waitables to become ready or until a
92 * timeout expires.
93 *
94 * If any of the waitables are ready, the function returns immediately.
95 *
96 * @return true if any of the waitables has become ready, false if
97 * the timeout occurs.
98 */
99 bool wait(int timeout = -1);
100
101protected:
102 /**
103 * Add a waitable.
104 */
105 void add(POSIXWaitable* waitable);
106
107 /**
108 * Remove a waitable.
109 */
110 void remove(POSIXWaitable* waitable);
111
112private:
113 /**
114 * Determine if any of the waitables is ready.
115 */
116 bool hasReady() const;
117
118 /**
119 * Fill the given array of poll descriptors with those file
120 * descriptors that wait for an event.
121 *
122 * @param pollFDs the file descriptor array to fill. It should
123 * contain at least as many elements as the number of waitables.
124 *
125 * @return the number of valid poll file descriptors.
126 */
127 size_t setupPollFDs(pollfd* pollFDs);
128
129 /**
130 * Process the given array of poll descriptors. For each
131 * descriptor, if its events are not 0, the handleEvents()
132 * function of the corresponding waitable is called.
133 */
134 void processPollFDs(const pollfd* pollFDs, size_t size);
135
136 friend class POSIXWaitable;
137};
138
139//------------------------------------------------------------------------------
140
141typedef POSIXWaiter Waiter;
142
143//------------------------------------------------------------------------------
144// Inline definitions
145//------------------------------------------------------------------------------
146
147inline POSIXWaiter::POSIXWaiter() :
148 numWaitables(0)
149{
150}
151
152//------------------------------------------------------------------------------
153
154} /* namespace xplcommon */
155
156//------------------------------------------------------------------------------
157#endif // HAVE_POLL_H
158
159#endif // XPLCOMMON_POSIXWAITABLE_H
160
161// Local Variables:
162// mode: C++
163// c-basic-offset: 4
164// indent-tabs-mode: nil
165// End:
Note: See TracBrowser for help on using the repository browser.