1 // globals.cxx -- Global state that needs to be shared among the sim modules
3 // Written by Curtis Olson, started July 2000.
5 // Copyright (C) 2000 Curtis L. Olson - curt@flightgear.org
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.
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.
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.
24 #include <simgear/structure/commands.hxx>
25 #include <simgear/misc/sg_path.hxx>
27 #include "globals.hxx"
28 #include "viewmgr.hxx"
30 #include "fg_props.hxx"
34 ////////////////////////////////////////////////////////////////////////
35 // Implementation of FGGlobals.
36 ////////////////////////////////////////////////////////////////////////
43 FGGlobals::FGGlobals() :
44 subsystem_mgr( new SGSubsystemMgr ),
45 event_mgr( new SGEventMgr ),
49 #if defined(FX) && defined(XMESA)
59 current_panel( NULL ),
67 props( new SGPropertyNode ),
68 initial_state( NULL ),
70 commands( new SGCommandMgr ),
74 channel_options_list( NULL ),
83 FGGlobals::~FGGlobals()
94 // set the fg_root path
95 void FGGlobals::set_fg_root (const string &root) {
98 // append /data to root if it exists
99 SGPath tmp( fg_root );
100 tmp.append( "data" );
101 tmp.append( "version" );
102 if ( ulFileExists( tmp.c_str() ) ) {
109 FGGlobals::get_subsystem_mgr () const
111 return subsystem_mgr;
115 FGGlobals::get_subsystem (const char * name)
117 return subsystem_mgr->get_subsystem(name);
121 FGGlobals::add_subsystem (const char * name,
122 SGSubsystem * subsystem,
123 SGSubsystemMgr::GroupType type,
126 subsystem_mgr->add(name, subsystem, type, min_time_sec);
131 FGGlobals::get_event_mgr () const
138 FGGlobals::add_event (const char * name,
142 event_mgr->add(name, subsystem_mgr->get_subsystem(name),
143 repeat_value, initial_value);
147 FGGlobals::add_event (const char * name,
148 const SGSubsystem * subsystem,
152 event_mgr->add(name, subsystem, repeat_value, initial_value);
157 // Save the current state as the initial state.
159 FGGlobals::saveInitialState ()
161 delete initial_state;
162 initial_state = new SGPropertyNode();
164 if (!copyProperties(props, initial_state))
165 SG_LOG(SG_GENERAL, SG_ALERT, "Error saving initial state");
169 // Restore the saved initial state, if any
171 FGGlobals::restoreInitialState ()
173 if ( initial_state == 0 ) {
174 SG_LOG(SG_GENERAL, SG_ALERT,
175 "No initial state available to restore!!!");
179 SGPropertyNode *currentPresets = new SGPropertyNode;
180 SGPropertyNode *targetNode = fgGetNode( "/sim/presets" );
182 // stash the /sim/presets tree
183 if ( !copyProperties(targetNode, currentPresets) ) {
184 SG_LOG( SG_GENERAL, SG_ALERT, "Failed to save /sim/presets subtree" );
187 if ( copyProperties(initial_state, props) ) {
188 SG_LOG( SG_GENERAL, SG_INFO, "Initial state restored successfully" );
190 SG_LOG( SG_GENERAL, SG_INFO,
191 "Some errors restoring initial state (read-only props?)" );
194 // recover the /sim/presets tree
195 if ( !copyProperties(currentPresets, targetNode) ) {
196 SG_LOG( SG_GENERAL, SG_ALERT,
197 "Failed to restore /sim/presets subtree" );
200 delete currentPresets;
204 FGGlobals::get_current_view () const
206 return viewmgr->get_current_view();
209 // end of globals.cxx