#ifndef _AIRPORT_DYNAMICS_HXX_
#define _AIRPORT_DYNAMICS_HXX_
-
-#ifndef __cplusplus
-# error This library requires C++
-#endif
-
-#include <simgear/xml/easyxml.hxx>
-
+#include <ATC/trafficcontrol.hxx>
#include "parking.hxx"
#include "groundnetwork.hxx"
#include "runwayprefs.hxx"
-#include "trafficcontrol.hxx"
+#include "sidstar.hxx"
+// forward decls
class FGAirport;
+class FGEnvironment;
class FGAirportDynamics {
private:
- FGAirport* _ap;
-
- FGParkingVec parkings;
- FGRunwayPreference rwyPrefs;
- FGGroundNetwork groundNetwork;
- FGTowerController towerController;
-
- time_t lastUpdate;
- string prevTrafficType;
- stringVec landing;
- stringVec takeoff;
- stringVec currentlyActive;
-
- // 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 chooseRunwayFallback();
+ FGAirport* _ap;
+
+ FGParkingVec parkings;
+ FGRunwayPreference rwyPrefs;
+ FGSidStar SIDs;
+ FGStartupController startupController;
+ FGGroundNetwork groundNetwork;
+ FGTowerController towerController;
+ FGApproachController approachController;
+
+ time_t lastUpdate;
+ std::string prevTrafficType;
+ stringVec landing;
+ stringVec takeoff;
+ stringVec milActive, comActive, genActive, ulActive;
+ stringVec *currentlyActive;
+ intVec freqAwos; // </AWOS>
+ intVec freqUnicom; // </UNICOM>
+ intVec freqClearance;// </CLEARANCE>
+ intVec freqGround; // </GROUND>
+ intVec freqTower; // </TOWER>
+ intVec freqApproach; // </APPROACH>
+
+ int atisSequenceIndex;
+ double atisSequenceTimeStamp;
+
+ std::string chooseRunwayFallback();
+ bool innerGetActiveRunway(const std::string &trafficType, int action, std::string &runway, double heading);
+ std::string chooseRwyByHeading(stringVec rwys, double heading);
+
+ double elevation;
public:
- FGAirportDynamics(FGAirport* ap);
- FGAirportDynamics(const FGAirportDynamics &other);
- ~FGAirportDynamics();
-
-
- void init();
- double getLongitude() const;
- // Returns degrees
- double getLatitude() const;
- // Returns ft
- double getElevation() const;
- const string& getId() const;
-
- void getActiveRunway(const string& trafficType, int action, string& runway);
-
- void addParking(FGParking& park);
- bool getAvailableParking(double *lat, double *lon,
- double *heading, int *gate, double rad, const string& fltype,
- const string& acType, const string& airline);
- void getParking (int id, double *lat, double* lon, double *heading);
- FGParking *getParking(int i);
- void releaseParking(int id);
- string getParkingName(int i);
- //FGAirport *getAddress() { return this; };
- //const string &getName() const { return _name;};
- // Returns degrees
-
- FGGroundNetwork *getGroundNetwork() { return &groundNetwork; };
- FGTowerController *getTowerController() { return &towerController; };
-
-
- void setRwyUse(const FGRunwayPreference& ref);
+ FGAirportDynamics(FGAirport* ap);
+ ~FGAirportDynamics();
+
+ void addAwosFreq (int val) {
+ freqAwos.push_back(val);
+ };
+ void addUnicomFreq (int val) {
+ freqUnicom.push_back(val);
+ };
+ void addClearanceFreq(int val) {
+ freqClearance.push_back(val);
+ };
+ void addGroundFreq (int val) {
+ freqGround.push_back(val);
+ };
+ void addTowerFreq (int val) {
+ freqTower.push_back(val);
+ };
+ void addApproachFreq (int val) {
+ freqApproach.push_back(val);
+ };
+
+ void init();
+ double getLongitude() const;
+ // Returns degrees
+ double getLatitude() const;
+ // Returns ft
+ double getElevation() const;
+ const string& getId() const;
+
+ void getActiveRunway(const string& trafficType, int action, string& runway, double heading);
+
+ void addParking(FGParking& park);
+ bool getAvailableParking(double *lat, double *lon,
+ double *heading, int *gate, double rad, const string& fltype,
+ const string& acType, const string& airline);
+ void getParking (int id, double *lat, double* lon, double *heading);
+ FGParking *getParking(int i);
+ void releaseParking(int id);
+ string getParkingName(int i);
+ int getNrOfParkings() {
+ return parkings.size();
+ };
+ //FGAirport *getAddress() { return this; };
+ //const string &getName() const { return _name;};
+ // Returns degrees
+
+ // 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;
+ };
+
+ int getGroundFrequency(unsigned leg);
+ int getTowerFrequency (unsigned nr);
+
+ /// get current ATIS sequence letter
+ const std::string getAtisSequence();
+
+ /// get the current ATIS sequence number, updating it if necessary
+ int updateAtisSequence(int interval, bool forceUpdate);
+
+ void setRwyUse(const FGRunwayPreference& ref);
};