#ifndef _AIRPORT_DYNAMICS_HXX_
#define _AIRPORT_DYNAMICS_HXX_
+#include <set>
+
#include <ATC/trafficcontrol.hxx>
+#include "airports_fwd.hxx"
#include "parking.hxx"
#include "groundnetwork.hxx"
#include "runwayprefs.hxx"
-#include "sidstar.hxx"
-// forward decls
-class FGAirport;
-class FGEnvironment;
+class ParkingAssignment
+{
+public:
+ ParkingAssignment();
+ ~ParkingAssignment();
+
+// create a parking assignment (and mark it as unavailable)
+ ParkingAssignment(FGParking* pk, FGAirport* apt);
+
+ ParkingAssignment(const ParkingAssignment& aOther);
+ void operator=(const ParkingAssignment& aOther);
+
+ bool isValid() const;
+ FGParking* parking() const;
+
+ void release();
+private:
+ void clear();
+
+ class ParkingAssignmentPrivate;
+ ParkingAssignmentPrivate* _sharedData;
+};
class FGAirportDynamics {
private:
FGAirport* _ap;
- FGParkingVec parkings;
+ typedef std::set<PositionedID> ParkingSet;
+ // if a parking item is in this set, it is occupied
+ ParkingSet occupiedParkings;
+
FGRunwayPreference rwyPrefs;
- FGSidStar SIDs;
FGStartupController startupController;
FGGroundNetwork groundNetwork;
FGTowerController towerController;
bool innerGetActiveRunway(const std::string &trafficType, int action, std::string &runway, double heading);
std::string chooseRwyByHeading(stringVec rwys, double heading);
- double elevation;
-
+ FGParking* innerGetAvailableParking(double radius, const std::string & flType,
+ const std::string & airline,
+ bool skipEmptyAirlineCode);
public:
FGAirportDynamics(FGAirport* ap);
~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, 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);
-
+ const std::string getId() const;
+
+ FGAirport* parent() const
+ { return _ap; }
+
+ void getActiveRunway( const std::string& trafficType,
+ int action,
+ std::string& runway,
+ double heading );
+
+ /**
+ * retrieve an available parking by GateID, or -1 if no suitable
+ * parking location could be found.
+ */
+ ParkingAssignment getAvailableParking(double radius, const std::string& fltype,
+ const std::string& acType, const std::string& airline);
+
+ void setParkingAvailable(PositionedID guid, bool available);
+
+ bool isParkingAvailable(PositionedID parking) const;
+
+ FGParkingRef getParking(PositionedID i) const;
+ void releaseParking(PositionedID id);
+ std::string getParkingName(PositionedID i) const;
+
+ /**
+ * Find a parking gate index by name. Note names are often not unique
+ * in our data, so will return the first match. If the parking is found,
+ * it will be marked as in-use (unavailable)
+ */
+ ParkingAssignment getParkingByName(const std::string& name) const;
// ATC related functions.
FGStartupController *getStartupController() {