source: xplcommon/src/xplcommon/posix/Waitable.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.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_POSIX_WAITABLE_H
31#define XPLCOMMON_POSIX_WAITABLE_H
32//------------------------------------------------------------------------------
33
34#include "../Failable.h"
35
36#include <cerrno>
37
38//------------------------------------------------------------------------------
39
40namespace xplcommon { namespace posix {
41
42//------------------------------------------------------------------------------
43
44class Waiter;
45
46//------------------------------------------------------------------------------
47
48/**
49 * Base class of objects for which one can wait in a Waiter.
50 *
51 * It is basically a file descriptor.
52 */
53class Waitable : public Failable
54{
55public:
56 /**
57 * Set the given file descriptor to non-blocking.
58 */
59 static void setNonBlocking(int fd);
60
61protected:
62 /**
63 * The waiter this waitable belongs to, if any.
64 */
65 Waiter* waiter;
66
67 /**
68 * The file descriptor
69 */
70 int fd;
71
72 /**
73 * The events this waitable is interested in.
74 */
75 short events;
76
77protected:
78 /**
79 * Construct the waitable.
80 */
81 Waitable(Waiter* waiter, int fd = -1, short events = 0);
82
83public:
84 /**
85 * Destroy the waitable. It will be removed from the waiter.
86 */
87 virtual ~Waitable();
88
89 /**
90 * Get the waiter.
91 */
92 Waiter* getWaiter() const;
93
94 /**
95 * Indicate if this waitable is valid, i.e. the file descriptor is
96 * non-negative.
97 */
98 bool isValid() const;
99
100 /**
101 * Determine if the waitable is ready or not, i.e. if there is no
102 * need to wait for it.
103 *
104 * It first checks the events. If they are 0, the waitable is
105 * ready. Then it calls isReady() and returns the result of that
106 * function.
107 */
108 bool ready();
109
110protected:
111 /**
112 * Indicate if the waitable is ready, i.e. there is no need to
113 * wait for it.
114 *
115 * Calling this function should not delete the ready
116 * indication. It should be deleted by actually processing the
117 * data.
118 */
119 virtual bool isReady() = 0;
120
121 /**
122 * Handle the given events.
123 */
124 virtual void handleEvents(short events) = 0;
125
126 /**
127 * Set the error code from errno.
128 */
129 void setErrorCodeFromErrno();
130
131 friend class Waiter;
132};
133
134//------------------------------------------------------------------------------
135// Inline defintions
136//------------------------------------------------------------------------------
137
138inline Waiter* Waitable::getWaiter() const
139{
140 return waiter;
141}
142
143//------------------------------------------------------------------------------
144
145inline bool Waitable::isValid() const
146{
147 return fd>=0;
148}
149
150//------------------------------------------------------------------------------
151
152inline bool Waitable::ready()
153{
154 return (events==0) || isReady();
155}
156
157//------------------------------------------------------------------------------
158
159inline void Waitable::setErrorCodeFromErrno()
160{
161 setErrorCode(errno);
162}
163
164//------------------------------------------------------------------------------
165
166} /* namespace xplcommon::posix */ } /* namespace xplcommon */
167
168//------------------------------------------------------------------------------
169#endif // XPLCOMMON_POSIXWAITABLE_H
170
171// Local Variables:
172// mode: C++
173// c-basic-offset: 4
174// indent-tabs-mode: nil
175// End:
Note: See TracBrowser for help on using the repository browser.