// util.cxx - general-purpose utility functions.
-// Copyright (C) 2002 Curtis L. Olson - curt@me.umn.edu
+// Copyright (C) 2002 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
//
// 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$
#include "globals.hxx"
#include "util.hxx"
+#ifdef OSG_LIBRARY_STATIC
+#include "osgDB/Registry"
+#endif
void
fgDefaultWeatherValue (const char * propname, double value)
min_hdg);
fgSetDouble("/environment/config/aloft/entry[2]/wind-speed-kt",
speed);
-
-#ifdef FG_WEATHERCM
- // convert to fps
- speed *= SG_NM_TO_METER * SG_METER_TO_FEET * (1.0/3600);
- while (min_hdg > 360)
- min_hdg -= 360;
- while (min_hdg <= 0)
- min_hdg += 360;
- min_hdg *= SGD_DEGREES_TO_RADIANS;
- fgSetDouble("/environment/wind-from-north-fps", speed * cos(dir));
- fgSetDouble("/environment/wind-from-east-fps", speed * sin(dir));
-#endif // FG_WEATHERCM
}
void
fgExit (int status)
{
- SG_LOG(SG_GENERAL, SG_INFO, "Exiting FlightGear with status " << status);
+ // remove subsystems first, which need access to other subsystems in their
+ // destructors (e.g. "nasal")
+ SGSubsystem *sub;
+
+ sub = globals->get_subsystem("ai_model");
+ globals->get_subsystem_mgr()->get_group(SGSubsystemMgr::GENERAL)->remove_subsystem("ai_model");
+ delete sub;
- globals->get_io()->shutdown_all();
+ sub = globals->get_subsystem("submodel_mgr");
+ globals->get_subsystem_mgr()->get_group(SGSubsystemMgr::GENERAL)->remove_subsystem("submodel_mgr");
+ delete sub;
+
+#ifdef OSG_LIBRARY_STATIC
+ osgDB::Registry::instance( true);
+#endif
+
+ SG_LOG(SG_GENERAL, SG_INFO, "Exiting FlightGear with status " << status);
exit(status);
}