source: xplcommon/src/xplcommon/posix/Waitable.h@ 11:9adb0b9c456b

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

Implemented the server side of the local socket

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