]> git.mxchange.org Git - flightgear.git/blobdiff - src/Main/fg_init.cxx
Fix for the fix: check for a viewer.
[flightgear.git] / src / Main / fg_init.cxx
index 070d4daf38b68bc57e3f909dfdaaf0be5fc3d9b2..8de7deda1962b4b6d5681467a2a487ffefe7387c 100644 (file)
@@ -436,7 +436,7 @@ int fgInitConfig ( int argc, char **argv, bool reinit )
     
     simgear::Dir exportDir(simgear::Dir(dataPath).file("Export"));
     if (!exportDir.exists()) {
-      exportDir.create(0777);
+      exportDir.create(0755);
     }
     
     // Set /sim/fg-home and don't allow malign code to override it until
@@ -941,9 +941,7 @@ void fgStartNewReset()
 {
     SGPropertyNode_ptr preserved(new SGPropertyNode);
     
-    // copy properties which are USERARCHIVEd or PRESERVEd
-    int checked = SGPropertyNode::USERARCHIVE+SGPropertyNode::PRESERVE;
-    if (!copyProperties(globals->get_props(), preserved, checked, checked))
+    if (!copyPropertiesWithAttribute(globals->get_props(), preserved, SGPropertyNode::PRESERVE))
         SG_LOG(SG_GENERAL, SG_ALERT, "Error saving preserved state");
     
     fgSetBool("/sim/signals/reinit", true);
@@ -953,7 +951,7 @@ void fgStartNewReset()
     subsystemManger->shutdown();
     subsystemManger->unbind();
     
-    // remove them all (with some exceptions?)
+    // remove most subsystems, with a few exceptions.
     for (int g=0; g<SGSubsystemMgr::MAX_GROUPS; ++g) {
         SGSubsystemGroup* grp = subsystemManger->get_group(static_cast<SGSubsystemMgr::GroupType>(g));
         const string_list& names(grp->member_names());
@@ -1002,12 +1000,13 @@ void fgStartNewReset()
     simgear::clearEffectCache();
     simgear::SGModelLib::resetPropertyRoot();
         
-    globals->resetPropertyRoot();
+    simgear::GlobalParticleCallback::setSwitch(NULL);
     
+    globals->resetPropertyRoot();
     fgInitConfig(0, NULL, true);
     fgInitGeneral(); // all of this?
     
-    if ( copyProperties(preserved, globals->get_props(), checked, checked)) {
+    if ( copyProperties(preserved, globals->get_props()) {
         SG_LOG( SG_GENERAL, SG_INFO, "Preserved state restored successfully" );
     } else {
         SG_LOG( SG_GENERAL, SG_INFO,