X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FMain%2Fglobals.cxx;h=33098d807ee09619d331933e3bc437f0ee78a381;hb=4fe615fff546df5e381f7fc9ddae92dd3dc36251;hp=d8b2997c851d0d02c992522cdbc9beb5d00b3d6e;hpb=986492d72d0e84c2ba2dfdad366f5c7414ee6ac9;p=flightgear.git diff --git a/src/Main/globals.cxx b/src/Main/globals.cxx index d8b2997c8..33098d807 100644 --- a/src/Main/globals.cxx +++ b/src/Main/globals.cxx @@ -2,7 +2,7 @@ // // Written by Curtis Olson, started July 2000. // -// Copyright (C) 2000 Curtis L. Olson - curt@flightgear.org +// Copyright (C) 2000 Curtis L. Olson - http://www.flightgear.org/~curt // // This program is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public License as @@ -16,16 +16,22 @@ // // You should have received a copy of the GNU General Public License // along with this program; if not, write to the Free Software -// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. +// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // // $Id$ +#ifdef HAVE_CONFIG_H +# include +#endif #include #include #include +#include + #include "globals.hxx" +#include "renderer.hxx" #include "viewmgr.hxx" #include "fg_props.hxx" @@ -67,7 +73,7 @@ FGGlobals::FGGlobals() : props( new SGPropertyNode ), initial_state( NULL ), locale( NULL ), - commands( new SGCommandMgr ), + commands( SGCommandMgr::instance() ), model_lib( NULL ), acmodel( NULL ), model_mgr( NULL ), @@ -76,11 +82,14 @@ FGGlobals::FGGlobals() : scenery( NULL ), tile_mgr( NULL ), io( new FGIO ), + fontcache ( new FGFontCache ), navlist( NULL ), loclist( NULL ), gslist( NULL ), dmelist( NULL ), mkrlist( NULL ), + tacanlist( NULL ), + carrierlist( NULL ), fixlist( NULL ) { } @@ -94,14 +103,10 @@ FGGlobals::~FGGlobals() delete event_mgr; delete initial_state; delete props; - delete commands; delete io; + delete fontcache; delete renderer; - - // make sure only to delete the initial waypoints list if it acually - // still exists. - if (initial_waypoints) - delete initial_waypoints; + delete initial_waypoints; } @@ -115,7 +120,9 @@ void FGGlobals::set_fg_root (const string &root) { tmp.append( "version" ); if ( ulFileExists( tmp.c_str() ) ) { fg_root += "/data"; - } + } + + fgSetString("/sim/fg-root", fg_root.c_str()); } void FGGlobals::set_fg_scenery (const string &scenery) { @@ -155,6 +162,10 @@ void FGGlobals::set_fg_scenery (const string &scenery) { ulCloseDir( od ); } } + // insert a marker for FGTileEntry::load(), so that + // FG_SCENERY=A:B becomes list ["A/Terrain", "A/Objects", "", + // "B/Terrain", "B/Objects", ""] + fg_scenery.push_back(""); } }