]> git.mxchange.org Git - flightgear.git/blob - Time/event.hxx
Converted to Point3D class.
[flightgear.git] / Time / event.hxx
1 // event.hxx -- Flight Gear periodic event scheduler
2 //
3 // Written by Curtis Olson, started December 1997.
4 //
5 // Copyright (C) 1997  Curtis L. Olson  - curt@infoplane.com
6 //
7 // This program is free software; you can redistribute it and/or
8 // modify it under the terms of the GNU General Public License as
9 // published by the Free Software Foundation; either version 2 of the
10 // License, or (at your option) any later version.
11 //
12 // This program is distributed in the hope that it will be useful, but
13 // WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15 // General Public License for more details.
16 //
17 // You should have received a copy of the GNU General Public License
18 // along with this program; if not, write to the Free Software
19 // Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 //
21 // $Id$
22 // (Log is kept at end of this file)
23
24
25 #ifndef _EVENT_HXX
26 #define _EVENT_HXX
27
28
29 #ifndef __cplusplus                                                          
30 # error This library requires C++
31 #endif                                   
32
33
34 #if defined ( __sun__ ) || defined ( __sgi )
35 extern "C" void *memmove(void *, const void *, size_t);
36 extern "C" void *memset(void *, int, size_t);
37 #endif
38
39
40 #include <deque>        // STL double ended queue
41 #include <list>         // STL list
42 #include <string>
43
44 #include "Include/fg_stl_config.h"
45
46 #ifdef FG_NEED_AUTO_PTR
47 #  include "Include/auto_ptr.hxx"
48 #else
49 #  include <memory>
50 #endif
51
52 #include "Include/fg_callback.hxx"
53
54 #ifdef NEEDNAMESPACESTD
55 using namespace std;
56 #endif
57
58 #include "fg_time.hxx"
59
60
61 class fgEVENT
62 {
63 public:
64     enum EventState
65     {
66         FG_EVENT_SUSP   = 0,
67         FG_EVENT_READY  = 1,
68         FG_EVENT_QUEUED = 2
69     };
70
71     fgEVENT() {} // Required by deque<>.
72
73     fgEVENT( const string& desc,
74              const fgCallback& cb,
75              EventState _status,
76              int _interval );
77
78     fgEVENT( const fgEVENT& evt );
79
80     ~fgEVENT();
81
82     void run();
83
84 //     void PrintStats() const;
85     int PrintStats() const;
86
87 public:
88
89     string description;
90
91     // The callback object.
92     // We wrap it in an auto_ptr<> because deque<> calls our copy ctor
93     // and dtor when inserting and removing.
94     auto_ptr<fgCallback> event_cb;
95
96     EventState status;       // status flag
97
98     long interval;    // interval in ms between each iteration of this event
99
100     fg_timestamp last_run;
101     fg_timestamp current;
102     fg_timestamp next_run;
103
104     long cum_time;    // cumulative processor time of this event
105     long min_time;    // time of quickest execution
106     long max_time;    // time of slowest execution
107     long count;       // number of times executed
108 };
109
110
111 class fgEVENT_MGR {
112
113     // Event table
114     deque < fgEVENT > event_table;
115
116     // Run Queue
117     list < fgEVENT * > run_queue;
118
119 public:
120
121     // Constructor
122     fgEVENT_MGR ( void );
123
124     // Initialize the scheduling subsystem
125     void Init( void );
126
127     // Register an event with the scheduler
128     void Register( const string& desc, void (*event)( void ),
129                    fgEVENT::EventState status, int interval) {
130         Register( desc, fgFunctionCallback(event), status, interval );
131     }
132
133     void Register( const string& desc,
134                    const fgCallback& cb,
135                    fgEVENT::EventState status, 
136                    int interval );
137
138     // Update the scheduling parameters for an event
139     void Update( void );
140
141     // Delete a scheduled event
142     void Delete( void );
143
144     // Temporarily suspend scheduling of an event
145     void Suspend( void );
146
147     // Resume scheduling and event
148     void Resume( void );
149
150     // Dump scheduling stats
151     void PrintStats( void );
152
153     // Add pending jobs to the run queue and run the job at the front
154     // of the queue
155     void Process( void );
156
157     // Destructor
158     ~fgEVENT_MGR ( void );
159 };
160
161
162 // Wrapper to dump scheduling stats
163 void fgEventPrintStats( void );
164
165 extern fgEVENT_MGR global_events;
166
167
168 #endif // _EVENT_HXX
169
170
171 // $Log$
172 // Revision 1.12  1998/10/16 00:56:08  curt
173 // Converted to Point3D class.
174 //
175 // Revision 1.11  1998/09/15 02:09:30  curt
176 // Include/fg_callback.hxx
177 //   Moved code inline to stop g++ 2.7 from complaining.
178 //
179 // Simulator/Time/event.[ch]xx
180 //   Changed return type of fgEVENT::printStat().  void caused g++ 2.7 to
181 //   complain bitterly.
182 //
183 // Minor bugfix and changes.
184 //
185 // Simulator/Main/GLUTmain.cxx
186 //   Added missing type to idle_state definition - eliminates a warning.
187 //
188 // Simulator/Main/fg_init.cxx
189 //   Changes to airport lookup.
190 //
191 // Simulator/Main/options.cxx
192 //   Uses fg_gzifstream when loading config file.
193 //
194 // Revision 1.10  1998/09/08 21:41:06  curt
195 // Added constructor for fgEVENT.
196 //
197 // Revision 1.9  1998/09/02 14:37:45  curt
198 // Renamed struct -> class.
199 //
200 // Revision 1.8  1998/08/29 13:11:32  curt
201 // Bernie Bright writes:
202 //   I've created some new classes to enable pointers-to-functions and
203 //   pointers-to-class-methods to be treated like objects.  These objects
204 //   can be registered with fgEVENT_MGR.
205 //
206 //   File "Include/fg_callback.hxx" contains the callback class defns.
207 //
208 //   Modified fgEVENT and fgEVENT_MGR to use the callback classes.  Also
209 //   some minor tweaks to STL usage.
210 //
211 //   Added file "Include/fg_stl_config.h" to deal with STL portability
212 //   issues.  I've added an initial config for egcs (and probably gcc-2.8.x).
213 //   I don't have access to Visual C++ so I've left that for someone else.
214 //   This file is influenced by the stl_config.h file delivered with egcs.
215 //
216 //   Added "Include/auto_ptr.hxx" which contains an implementation of the
217 //   STL auto_ptr class which is not provided in all STL implementations
218 //   and is needed to use the callback classes.
219 //
220 //   Deleted fgLightUpdate() which was just a wrapper to call
221 //   fgLIGHT::Update().
222 //
223 //   Modified fg_init.cxx to register two method callbacks in place of the
224 //   old wrapper functions.
225 //
226 // Revision 1.7  1998/07/30 23:48:54  curt
227 // Sgi build tweaks.
228 // Pause support.
229 //
230 // Revision 1.6  1998/07/24 21:42:25  curt
231 // Output message tweaks.
232 //
233 // Revision 1.5  1998/07/13 21:02:07  curt
234 // Wrote access functions for current fgOPTIONS.
235 //
236 // Revision 1.4  1998/06/12 00:59:52  curt
237 // Build only static libraries.
238 // Declare memmove/memset for Sloaris.
239 // Rewrote fg_time.c routine to get LST start seconds to better handle
240 //   Solaris, and be easier to port, and understand the GMT vs. local
241 //   timezone issues.
242 //
243 // Revision 1.3  1998/06/03 00:48:12  curt
244 // No .h for STL includes.
245 //
246 // Revision 1.2  1998/05/22 21:14:54  curt
247 // Rewrote event.cxx in C++ as a class using STL for the internal event list
248 // and run queue this removes the arbitrary list sizes and makes things much
249 // more dynamic.  Because this is C++-classified we can now have multiple
250 // event_tables if we'd ever want them.
251 //
252 // Revision 1.1  1998/04/24 00:52:26  curt
253 // Wrapped "#include <config.h>" in "#ifdef HAVE_CONFIG_H"
254 // Fog color fixes.
255 // Separated out lighting calcs into their own file.
256 //
257 // Revision 1.4  1998/04/21 17:01:43  curt
258 // Fixed a problems where a pointer to a function was being passed around.  In
259 // one place this functions arguments were defined as ( void ) while in another
260 // place they were defined as ( int ).  The correct answer was ( int ).
261 //
262 // Prepairing for C++ integration.
263 //
264 // Revision 1.3  1998/01/22 02:59:43  curt
265 // Changed #ifdef FILE_H to #ifdef _FILE_H
266 //
267 // Revision 1.2  1998/01/19 18:40:39  curt
268 // Tons of little changes to clean up the code and to remove fatal errors
269 // when building with the c++ compiler.
270 //
271 // Revision 1.1  1997/12/30 04:19:22  curt
272 // Initial revision.
273