source: xplcommon/src/xplcommon/posix/Waiter.h@ 14:3caa1d3122db

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

Moved the storage of the error code to where it belongs

File size: 4.5 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_POSIX_WAITER_H
31#define XPLCOMMON_POSIX_WAITER_H
32//------------------------------------------------------------------------------
33
34#include "../Failable.h"
35
36#include <map>
37
38#include <cstdlib>
39
40#include <poll.h>
41
42//------------------------------------------------------------------------------
43
44namespace xplcommon { namespace posix {
45
46//------------------------------------------------------------------------------
47
48class Waitable;
49
50//------------------------------------------------------------------------------
51
52/**
53 * Class that can be used to register waitable objects and then wait
54 * for them.
55 */
56class Waiter : public Failable
57{
58private:
59 /**
60 * Type for the set of waitables.
61 */
62 typedef std::map<int, Waitable*> waitables_t;
63
64 /**
65 * The set of waitables belonging to this waiter.
66 */
67 waitables_t waitables;
68
69 /**
70 * The number of waitables.
71 */
72 size_t numWaitables;
73
74public:
75 /**
76 * Construct the waiter.
77 */
78 Waiter();
79
80 /**
81 * Destroy the waiter. All waitables that still exists will be
82 * modified to point to no waiter.
83 */
84 ~Waiter();
85
86 /**
87 * Wait for any if the waitables to become ready or until a
88 * timeout expires.
89 *
90 * If any of the waitables are ready, the function returns immediately.
91 *
92 * @return true if any of the waitables has become ready, false if
93 * the timeout occurs.
94 */
95 bool wait(int timeout = -1);
96
97protected:
98 /**
99 * Add a waitable.
100 */
101 void add(Waitable* waitable);
102
103 /**
104 * Remove a waitable.
105 */
106 void remove(Waitable* waitable);
107
108private:
109 /**
110 * Determine if any of the waitables is ready.
111 */
112 bool hasReady() const;
113
114 /**
115 * Fill the given array of poll descriptors with those file
116 * descriptors that wait for an event.
117 *
118 * @param pollFDs the file descriptor array to fill. It should
119 * contain at least as many elements as the number of waitables.
120 *
121 * @return the number of valid poll file descriptors.
122 */
123 size_t setupPollFDs(pollfd* pollFDs);
124
125 /**
126 * Process the given array of poll descriptors. For each
127 * descriptor, if its events are not 0, the handleEvents()
128 * function of the corresponding waitable is called.
129 */
130 void processPollFDs(const pollfd* pollFDs, size_t size);
131
132 friend class Waitable;
133};
134
135//------------------------------------------------------------------------------
136// Inline definitions
137//------------------------------------------------------------------------------
138
139inline Waiter::Waiter() :
140 numWaitables(0)
141{
142}
143
144//------------------------------------------------------------------------------
145
146} /* namespace xplcommon::posix */ } /* namespace xplcommon */
147
148//------------------------------------------------------------------------------
149#endif // XPLCOMMON_POSIX_WAITABLE_H
150
151// Local Variables:
152// mode: C++
153// c-basic-offset: 4
154// indent-tabs-mode: nil
155// End:
Note: See TracBrowser for help on using the repository browser.