1
0
Fork 0

Convert scenery path setup to use simgear::Dir

This commit is contained in:
James Turner 2010-07-05 08:31:09 +01:00 committed by James Turner
parent 2c90eb8370
commit af3f072c21
2 changed files with 27 additions and 36 deletions

View file

@ -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
} }

View file

@ -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>