Convert scenery path setup to use simgear::Dir
This commit is contained in:
parent
2c90eb8370
commit
af3f072c21
2 changed files with 27 additions and 36 deletions
|
@ -26,6 +26,7 @@
|
||||||
|
|
||||||
#include <simgear/structure/commands.hxx>
|
#include <simgear/structure/commands.hxx>
|
||||||
#include <simgear/misc/sg_path.hxx>
|
#include <simgear/misc/sg_path.hxx>
|
||||||
|
#include <simgear/misc/sg_dir.hxx>
|
||||||
#include <simgear/timing/sg_time.hxx>
|
#include <simgear/timing/sg_time.hxx>
|
||||||
#include <simgear/ephemeris/ephemeris.hxx>
|
#include <simgear/ephemeris/ephemeris.hxx>
|
||||||
#include <simgear/magvar/magvar.hxx>
|
#include <simgear/magvar/magvar.hxx>
|
||||||
|
@ -189,7 +190,8 @@ void FGGlobals::set_fg_root (const string &root) {
|
||||||
n->setAttribute(SGPropertyNode::WRITE, false);
|
n->setAttribute(SGPropertyNode::WRITE, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void FGGlobals::set_fg_scenery (const string &scenery) {
|
void FGGlobals::set_fg_scenery (const string &scenery)
|
||||||
|
{
|
||||||
SGPath s;
|
SGPath s;
|
||||||
if (scenery.empty()) {
|
if (scenery.empty()) {
|
||||||
s.set( fg_root );
|
s.set( fg_root );
|
||||||
|
@ -201,38 +203,35 @@ void FGGlobals::set_fg_scenery (const string &scenery) {
|
||||||
fg_scenery.clear();
|
fg_scenery.clear();
|
||||||
|
|
||||||
for (unsigned i = 0; i < path_list.size(); i++) {
|
for (unsigned i = 0; i < path_list.size(); i++) {
|
||||||
|
SGPath path(path_list[i]);
|
||||||
|
if (!path.exists()) {
|
||||||
|
SG_LOG(SG_GENERAL, SG_WARN, "scenery path not found:" << path.str());
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
ulDir *d = ulOpenDir( path_list[i].c_str() );
|
simgear::Dir dir(path);
|
||||||
if (d == NULL)
|
SGPath terrainDir(dir.file("Terrain"));
|
||||||
continue;
|
SGPath objectsDir(dir.file("Objects"));
|
||||||
ulCloseDir( d );
|
|
||||||
|
// this code used to add *either* the base dir, OR add the
|
||||||
SGPath pt( path_list[i] ), po( path_list[i] );
|
// Terrain and Objects subdirs, but the conditional logic was commented
|
||||||
pt.append("Terrain");
|
// out, such that all three dirs are added. Unfortunately there's
|
||||||
po.append("Objects");
|
// no information as to why the change was made.
|
||||||
|
fg_scenery.push_back(path.str());
|
||||||
ulDir *td = ulOpenDir( pt.c_str() );
|
|
||||||
ulDir *od = ulOpenDir( po.c_str() );
|
if (terrainDir.exists()) {
|
||||||
|
fg_scenery.push_back(terrainDir.str());
|
||||||
// "Terrain" and "Airports" directory don't exist. add directory as is
|
}
|
||||||
// otherwise, automatically append either Terrain, Objects, or both
|
|
||||||
//if (td == NULL && od == NULL)
|
if (objectsDir.exists()) {
|
||||||
fg_scenery.push_back( path_list[i] );
|
fg_scenery.push_back(objectsDir.str());
|
||||||
//else {
|
}
|
||||||
if (td != NULL) {
|
|
||||||
fg_scenery.push_back( pt.str() );
|
|
||||||
ulCloseDir( td );
|
|
||||||
}
|
|
||||||
if (od != NULL) {
|
|
||||||
fg_scenery.push_back( po.str() );
|
|
||||||
ulCloseDir( od );
|
|
||||||
}
|
|
||||||
//}
|
|
||||||
// insert a marker for FGTileEntry::load(), so that
|
// insert a marker for FGTileEntry::load(), so that
|
||||||
// FG_SCENERY=A:B becomes list ["A/Terrain", "A/Objects", "",
|
// FG_SCENERY=A:B becomes list ["A/Terrain", "A/Objects", "",
|
||||||
// "B/Terrain", "B/Objects", ""]
|
// "B/Terrain", "B/Objects", ""]
|
||||||
fg_scenery.push_back("");
|
fg_scenery.push_back("");
|
||||||
}
|
} // of path list iteration
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -40,20 +40,12 @@
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include <plib/ul.h>
|
|
||||||
|
|
||||||
#include <simgear/math/sg_random.h>
|
#include <simgear/math/sg_random.h>
|
||||||
#include <simgear/props/props_io.hxx>
|
#include <simgear/props/props_io.hxx>
|
||||||
#include <simgear/misc/sgstream.hxx>
|
#include <simgear/misc/sgstream.hxx>
|
||||||
#include <simgear/misc/sg_path.hxx>
|
#include <simgear/misc/sg_path.hxx>
|
||||||
#include <simgear/scene/material/mat.hxx>
|
#include <simgear/scene/material/mat.hxx>
|
||||||
#include <simgear/sound/soundmgr_openal.hxx>
|
#include <simgear/sound/soundmgr_openal.hxx>
|
||||||
|
|
||||||
// #include <Include/general.hxx>
|
|
||||||
// #include <Airports/simple.hxx>
|
|
||||||
// #include <Cockpit/cockpit.hxx>
|
|
||||||
// #include <FDM/flight.hxx>
|
|
||||||
|
|
||||||
#include <Autopilot/route_mgr.hxx>
|
#include <Autopilot/route_mgr.hxx>
|
||||||
#include <GUI/gui.h>
|
#include <GUI/gui.h>
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue