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/misc/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 FGSubsystemMgr ),
48 #if defined(FX) && defined(XMESA)
58 current_panel( NULL ),
65 props( new SGPropertyNode ),
66 initial_state( NULL ),
68 commands( new SGCommandMgr ),
72 channel_options_list( NULL ),
81 FGGlobals::~FGGlobals()
91 // set the fg_root path
92 void FGGlobals::set_fg_root (const string &root) {
95 // append /data to root if it exists
96 SGPath tmp( fg_root );
98 tmp.append( "version" );
99 if ( ulFileExists( tmp.c_str() ) ) {
106 FGGlobals::get_subsystem_mgr () const
108 return subsystem_mgr;
112 FGGlobals::get_subsystem (const char * name)
114 return subsystem_mgr->get_subsystem(name);
118 FGGlobals::add_subsystem (const char * name,
119 FGSubsystem * subsystem,
120 FGSubsystemMgr::GroupType type,
123 subsystem_mgr->add(name, subsystem, type, min_time_sec);
127 // Save the current state as the initial state.
129 FGGlobals::saveInitialState ()
131 delete initial_state;
132 initial_state = new SGPropertyNode();
133 if (!copyProperties(props, initial_state))
134 SG_LOG(SG_GENERAL, SG_ALERT, "Error saving initial state");
138 // Restore the saved initial state, if any
140 FGGlobals::restoreInitialState ()
142 if ( initial_state == 0 ) {
143 SG_LOG(SG_GENERAL, SG_ALERT,
144 "No initial state available to restore!!!");
148 SGPropertyNode *currentPresets = new SGPropertyNode;
149 SGPropertyNode *targetNode = fgGetNode( "/sim/presets" );
151 // stash the /sim/presets tree
152 if ( !copyProperties(targetNode, currentPresets) ) {
153 SG_LOG( SG_GENERAL, SG_ALERT, "Failed to save /sim/presets subtree" );
156 if ( copyProperties(initial_state, props) ) {
157 SG_LOG( SG_GENERAL, SG_INFO, "Initial state restored successfully" );
159 SG_LOG( SG_GENERAL, SG_INFO,
160 "Some errors restoring initial state (read-only props?)" );
163 // recover the /sim/presets tree
164 if ( !copyProperties(currentPresets, targetNode) ) {
165 SG_LOG( SG_GENERAL, SG_ALERT,
166 "Failed to restore /sim/presets subtree" );
169 delete currentPresets;
173 FGGlobals::get_current_view () const
175 return viewmgr->get_current_view();
178 // end of globals.cxx