vfs: check userland buffers before reading them.
[haiku.git] / src / servers / registrar / Event.cpp
blobbaa7b78f86bdccf1f761ef27557c46b2f42df158
1 //------------------------------------------------------------------------------
2 // Copyright (c) 2001-2002, OpenBeOS
3 //
4 // Permission is hereby granted, free of charge, to any person obtaining a
5 // copy of this software and associated documentation files (the "Software"),
6 // to deal in the Software without restriction, including without limitation
7 // the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 // and/or sell copies of the Software, and to permit persons to whom the
9 // Software is furnished to do so, subject to the following conditions:
11 // The above copyright notice and this permission notice shall be included in
12 // all copies or substantial portions of the Software.
14 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
19 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
20 // DEALINGS IN THE SOFTWARE.
22 // File Name: Event.cpp
23 // Author: Ingo Weinhold (bonefish@users.sf.net)
24 // YellowBites (http://www.yellowbites.com)
25 // Description: Base class for events as handled by EventQueue.
26 //------------------------------------------------------------------------------
28 #include "Event.h"
30 /*! \class Event
31 \brief Base class for events as handled by EventQueue.
33 Event features methods to set and get the event time and the "auto delete"
34 flag, and a Do() method invoked, when the event is executed.
36 If the "auto delete" flag is set to \c true, the event is deleted by the
37 event queue after it has been executed. The same happens, if Do() returns
38 \c true.
41 /*! \var bigtime_t Event::fTime
42 \brief The event time.
45 /*! \var bool Event::fAutoDelete
46 \brief The "auto delete" flag.
49 // constructor
50 /*! \brief Creates a new event.
52 The event time is initialized to 0. That is, it should be set before
53 pushing the event into an event queue.
55 \param autoDelete Specifies whether the object shall automatically be
56 deleted by the event queue after being executed.
58 Event::Event(bool autoDelete)
59 : fTime(0),
60 fAutoDelete(autoDelete)
64 // constructor
65 /*! \brief Creates a new event.
66 \param time Time when the event shall be executed.
67 \param autoDelete Specifies whether the object shall automatically be
68 deleted by the event queue after being executed.
70 Event::Event(bigtime_t time, bool autoDelete)
71 : fTime(time),
72 fAutoDelete(autoDelete)
76 // destructor
77 /*! \brief Frees all resources associated with the object.
79 Does nothing.
81 Event::~Event()
85 // SetTime
86 /*! \brief Sets a new event time.
88 \note You must not call this method, when the event is in an event queue.
89 Use EventQueue::ModifyEvent() instead.
91 \param time The new event time.
93 void
94 Event::SetTime(bigtime_t time)
96 fTime = time;
99 // Time
100 /*! \brief Returns the time of the event.
101 \return Returns the time of the event.
103 bigtime_t
104 Event::Time() const
106 return fTime;
109 // SetAutoDelete
110 /*! \brief Sets whether the event shall be deleted after execution.
111 \param autoDelete Specifies whether the object shall automatically be
112 deleted by the event queue after being executed.
114 void
115 Event::SetAutoDelete(bool autoDelete)
117 fAutoDelete = autoDelete;
120 // IsAutoDelete
121 /*! \brief Returns whether the event shall be deleted after execution.
122 \return Returns whether the object shall automatically be
123 deleted by the event queue after being executed.
125 bool
126 Event::IsAutoDelete() const
128 return fAutoDelete;
131 // Do
132 /*! \brief Hook method invoked when the event time has arrived.
134 To be overridden by derived classes. As the method is executed in the
135 event queue's timer thread, the execution of the method should take
136 as little time as possible to keep the event queue precise.
138 The return value of this method indicates whether the event queue shall
139 delete the object. This does not override the IsAutoDelete() value. If
140 IsAutoDelete() is \c true, then the object is deleted regardless of this
141 method's return value, but if IsAutoDelete() is \c false, this method's
142 return value is taken into consideration. To be precise the logical OR
143 of IsAutoDelete() and the return value of Do() specifies whether the
144 object shall be deleted. The reason for this handling is that there are
145 usally two kind of events: "one-shot" events and those that are reused
146 periodically or from time to time. The first kind can simply be
147 constructed with "auto delete" set to \c true and doesn't need to care
148 about Do()'s return value. The second kind shall usually not be deleted,
149 but during the execution of Do() it might turn out, that it the would be
150 a good idea to let it be deleted by the event queue.
151 BTW, the event may as well delete itself in Do(); that is not a very
152 nice practice though.
154 \note IsAutoDelete() is checked by the event queue before Do() is invoked.
155 Thus changing it in Do() won't have any effect.
157 If it is not deleted, the event can re-push itself into the queue
158 within Do().
160 \note The event queue is not locked when this method is invoked and it
161 doesn't contain the event anymore.
163 \param queue The event queue executing the event.
164 \return \c true, if the event shall be deleted by the event queue,
165 \c false, if IsAutoDelete() shall be checked for this decision.
167 bool
168 Event::Do(EventQueue *queue)
170 return fAutoDelete;