xref: /haiku/src/servers/registrar/Event.cpp (revision 4c8e85b316c35a9161f5a1c50ad70bc91c83a76f)
1 //------------------------------------------------------------------------------
2 //	Copyright (c) 2001-2002, Haiku
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:
10 //
11 //	The above copyright notice and this permission notice shall be included in
12 //	all copies or substantial portions of the Software.
13 //
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.
21 //
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 //------------------------------------------------------------------------------
27 
28 #include "Event.h"
29 
30 /*!	\class Event
31 	\brief Base class for events as handled by EventQueue.
32 
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.
35 
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.
39 */
40 
41 /*!	\var bigtime_t Event::fTime
42 	\brief The event time.
43 */
44 
45 /*!	\var bool Event::fAutoDelete
46 	\brief The "auto delete" flag.
47 */
48 
49 // constructor
50 /*!	\brief Creates a new event.
51 
52 	The event time is initialized to 0. That is, it should be set before
53 	pushing the event into an event queue.
54 
55 	\param autoDelete Specifies whether the object shall automatically be
56 		   deleted by the event queue after being executed.
57 */
58 Event::Event(bool autoDelete)
59 	: fTime(0),
60 	  fAutoDelete(autoDelete)
61 {
62 }
63 
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.
69 */
70 Event::Event(bigtime_t time, bool autoDelete)
71 	: fTime(time),
72 	  fAutoDelete(autoDelete)
73 {
74 }
75 
76 // destructor
77 /*!	\brief Frees all resources associated with the object.
78 
79 	Does nothing.
80 */
81 Event::~Event()
82 {
83 }
84 
85 // SetTime
86 /*!	\brief Sets a new event time.
87 
88 	\note You must not call this method, when the event is in an event queue.
89 		  Use EventQueue::ModifyEvent() instead.
90 
91 	\param time The new event time.
92 */
93 void
94 Event::SetTime(bigtime_t time)
95 {
96 	fTime = time;
97 }
98 
99 // Time
100 /*!	\brief Returns the time of the event.
101 	\return Returns the time of the event.
102 */
103 bigtime_t
104 Event::Time() const
105 {
106 	return fTime;
107 }
108 
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.
113 */
114 void
115 Event::SetAutoDelete(bool autoDelete)
116 {
117 	fAutoDelete = autoDelete;
118 }
119 
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.
124 */
125 bool
126 Event::IsAutoDelete() const
127 {
128 	return fAutoDelete;
129 }
130 
131 // Do
132 /*!	\brief Hook method invoked when the event time has arrived.
133 
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.
137 
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.
153 
154 	\note IsAutoDelete() is checked by the event queue before Do() is invoked.
155 		  Thus changing it in Do() won't have any effect.
156 
157 	If it is not deleted, the event can re-push itself into the queue
158 	within Do().
159 
160 	\note The event queue is not locked when this method is invoked and it
161 		  doesn't contain the event anymore.
162 
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.
166 */
167 bool
168 Event::Do(EventQueue *queue)
169 {
170 	return fAutoDelete;
171 }
172 
173