#include "parking.hxx"
#include "groundnetwork.hxx"
#include "runwayprefs.hxx"
+#include "sidstar.hxx"
//typedef vector<float> DoubleVec;
//typedef vector<float>::iterator DoubleVecIterator;
private:
FGAirport* _ap;
- FGParkingVec parkings;
- FGRunwayPreference rwyPrefs;
- FGStartupController startupController;
- FGGroundNetwork groundNetwork;
- FGTowerController towerController;
+ FGParkingVec parkings;
+ FGRunwayPreference rwyPrefs;
+ FGSidStar SIDs;
+ FGStartupController startupController;
+ FGGroundNetwork groundNetwork;
+ FGTowerController towerController;
+ FGApproachController approachController;
time_t lastUpdate;
string prevTrafficType;
intVec freqTower; // </TOWER>
intVec freqApproach; // </APPROACH>
- // Experimental keep a running average of wind dir and speed to prevent
- // Erratic runway changes.
- // Note: I should add these to the copy constructor and assigment operator to be
- // constistent
- //double avWindHeading [10];
- //double avWindSpeed [10];
+ string atisInformation;
string chooseRunwayFallback();
- bool innerGetActiveRunway(const string &trafficType, int action, string &runway);
+ bool innerGetActiveRunway(const string &trafficType, int action, string &runway, double heading);
+ string chooseRwyByHeading(stringVec rwys, double heading);
+
+ double elevation;
+
public:
FGAirportDynamics(FGAirport* ap);
FGAirportDynamics(const FGAirportDynamics &other);
double getElevation() const;
const string& getId() const;
- void getActiveRunway(const string& trafficType, int action, string& runway);
+ void getActiveRunway(const string& trafficType, int action, string& runway, double heading);
void addParking(FGParking& park);
bool getAvailableParking(double *lat, double *lon,
//FGAirport *getAddress() { return this; };
//const string &getName() const { return _name;};
// Returns degrees
- int getGroundFrequency() { return freqGround.size() ? freqGround[0] : 0; };
- FGStartupController *getStartupController() { return &startupController; };
- FGGroundNetwork *getGroundNetwork() { return &groundNetwork; };
- FGTowerController *getTowerController() { return &towerController; };
+ // Departure / Arrival procedures
+ FGSidStar * getSIDs() { return &SIDs; };
+ FGAIFlightPlan * getSID(string activeRunway, double heading);
-
+ // ATC related functions.
+ FGStartupController *getStartupController() { return &startupController; };
+ FGGroundNetwork *getGroundNetwork() { return &groundNetwork; };
+ FGTowerController *getTowerController() { return &towerController; };
+ FGApproachController *getApproachController() { return &approachController; };
+
+ const string& getAtisInformation() { return atisInformation; };
+ int getGroundFrequency (unsigned leg); //{ return freqGround.size() ? freqGround[0] : 0; };
+ int getTowerFrequency (unsigned nr);
void setRwyUse(const FGRunwayPreference& ref);
};