source: xplcommon/src/xplcommon/win32/Overlapped.h@ 26:46f4e06241c7

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

Further cleanup

File size: 4.3 KB
Line 
1// Copyright (c) 2012 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_WIN32_OVERLAPPED_H
31#define XPLCOMMON_WIN32_OVERLAPPED_H
32//------------------------------------------------------------------------------
33
34#include "Event.h"
35
36//------------------------------------------------------------------------------
37
38namespace xplcommon { namespace win32 {
39
40//------------------------------------------------------------------------------
41
42/**
43 * A wrapper for an OVERLAPPED structure which also has an event
44 * associated with it. Instances of this class can be registered into and
45 * unregistered from a Waiter. The destructor removes the object from
46 * the waiter, if it is registered.
47 */
48class Overlapped : public Event
49{
50private:
51 /**
52 * The Windows OVERLAPPED structure.
53 */
54 OVERLAPPED overlapped;
55
56public:
57 /**
58 * Construct the object. The overlapped structure will be reset to
59 * 0, and the event handle will be set.
60 */
61 Overlapped(EventFailable& eventFailable);
62
63 /**
64 * Reset the overlapped structure and set its event handle. The
65 * event is also cleared.
66 */
67 void reset();
68
69 /**
70 * Get the pointer to the overlapped structure.
71 */
72 OVERLAPPED* get();
73
74 /**
75 * Get the pointer to the overlapped structure.
76 */
77 const OVERLAPPED* get() const;
78
79 /**
80 * Get the result of the overlapped operation.
81 *
82 * If the operation has completed, the event will be cleared.
83 *
84 * @param size on successful return, it will contain the number of
85 * bytes read or written, which may be 0 for an end-of-file
86 * condition
87 * @param file the handle of the object on which the operation in
88 * question was performed
89 *
90 * @return true if the operation has completed, or false if it has
91 * not, or a failure has occured.
92 */
93 bool getResult(DWORD& size, HANDLE file);
94};
95
96//------------------------------------------------------------------------------
97// Inline definitions
98//------------------------------------------------------------------------------
99
100inline Overlapped::Overlapped(EventFailable& eventFailable) :
101 Event(eventFailable)
102{
103}
104
105//------------------------------------------------------------------------------
106
107inline OVERLAPPED* Overlapped::get()
108{
109 return &overlapped;
110}
111
112//------------------------------------------------------------------------------
113
114inline const OVERLAPPED* Overlapped::get() const
115{
116 return &overlapped;
117}
118
119//------------------------------------------------------------------------------
120
121} /* namespace xplcommon::win32 */ } /* namespace xplcommon */
122
123//------------------------------------------------------------------------------
124#endif // XPLCOMMON_WIN32_OVERLAPPED_H
125
126// Local Variables:
127// mode: C++
128// c-basic-offset: 4
129// indent-tabs-mode: nil
130// End:
Note: See TracBrowser for help on using the repository browser.