//
#include <simgear/misc/sg_path.hxx>
+
+#include <simgear/xml/easyxml.hxx>
+
#include <Main/globals.hxx>
+#include <Main/fg_props.hxx>
#include "xmlloader.hxx"
#include "dynamicloader.hxx"
#include "dynamics.hxx"
#include "runwayprefs.hxx"
+using std::string;
+
XMLLoader::XMLLoader() {}
XMLLoader::~XMLLoader() {}
void XMLLoader::load(FGAirportDynamics* d) {
FGAirportDynamicsXMLLoader visitor(d);
-
- SGPath parkpath( globals->get_fg_root() );
- parkpath.append( "/AI/Airports/" );
- parkpath.append( d->getId() );
- parkpath.append( "parking.xml" );
-
- if (parkpath.exists()) {
- try {
- readXML(parkpath.str(), visitor);
- d->init();
- } catch (const sg_exception &e) {
- //cerr << "unable to read " << parkpath.str() << endl;
+ if (fgGetBool("/sim/paths/use-custom-scenery-data") == false) {
+ SGPath parkpath( globals->get_fg_root() );
+ parkpath.append( "/AI/Airports/" );
+ parkpath.append( d->getId() );
+ parkpath.append( "parking.xml" );
+ SG_LOG(SG_GENERAL, SG_DEBUG, "running old loader:" << parkpath.c_str());
+ if (parkpath.exists()) {
+ try {
+ readXML(parkpath.str(), visitor);
+ d->init();
+ }
+ catch (const sg_exception &) {
+ }
+ }
+ } else {
+ if(loadAirportXMLDataIntoVisitor(d->getId(), "groundnet", visitor)) {
+ d->init();
}
}
-
}
void XMLLoader::load(FGRunwayPreference* p) {
FGRunwayPreferenceXMLLoader visitor(p);
+ if (fgGetBool("/sim/paths/use-custom-scenery-data") == false) {
+ SGPath rwyPrefPath( globals->get_fg_root() );
+ rwyPrefPath.append( "AI/Airports/" );
+ rwyPrefPath.append( p->getId() );
+ rwyPrefPath.append( "rwyuse.xml" );
+ if (rwyPrefPath.exists()) {
+ try {
+ readXML(rwyPrefPath.str(), visitor);
+ }
+ catch (const sg_exception &) {
+ }
+ }
+ } else {
+ loadAirportXMLDataIntoVisitor(p->getId(), "rwyuse", visitor);
+ }
+}
- SGPath rwyPrefPath( globals->get_fg_root() );
- rwyPrefPath.append( "AI/Airports/" );
- rwyPrefPath.append( p->getId() );
- rwyPrefPath.append( "rwyuse.xml" );
+void XMLLoader::load(FGSidStar* p) {
+ SGPath path;
+ if (findAirportData(p->getId(), "SID", path)) {
+ p->load(path);
+ }
+}
- //if (ai_dirs.find(id.c_str()) != ai_dirs.end()
- // && rwyPrefPath.exists())
- if (rwyPrefPath.exists()) {
- try {
- readXML(rwyPrefPath.str(), visitor);
- } catch (const sg_exception &e) {
- //cerr << "unable to read " << rwyPrefPath.str() << endl;
- }
+bool XMLLoader::findAirportData(const std::string& aICAO,
+ const std::string& aFileName, SGPath& aPath)
+{
+ string_list sc = globals->get_fg_scenery();
+ char buffer[128];
+ ::snprintf(buffer, 128, "%c/%c/%c/%s.%s.xml",
+ aICAO[0], aICAO[1], aICAO[2],
+ aICAO.c_str(), aFileName.c_str());
+
+ for (string_list_iterator it = sc.begin(); it != sc.end(); ++it) {
+ SGPath path(*it);
+ path.append("Airports");
+ path.append(string(buffer));
+ if (path.exists()) {
+ aPath = path;
+ return true;
+ } // of path exists
+ } // of scenery path iteration
+ return false;
+}
+
+bool XMLLoader::loadAirportXMLDataIntoVisitor(const string& aICAO,
+ const string& aFileName, XMLVisitor& aVisitor)
+{
+ SGPath path;
+ if (!findAirportData(aICAO, aFileName, path)) {
+ SG_LOG(SG_GENERAL, SG_DEBUG, "loadAirportXMLDataIntoVisitor: failed to find data for " << aICAO << "/" << aFileName);
+ return false;
}
+
+ SG_LOG(SG_GENERAL, SG_DEBUG, "loadAirportXMLDataIntoVisitor: loading from " << path.str());
+ readXML(path.str(), aVisitor);
+ return true;
}
+