]> git.mxchange.org Git - flightgear.git/blobdiff - src/AIModel/AIFlightPlan.hxx
Interpret environment variables and hostname on Windows
[flightgear.git] / src / AIModel / AIFlightPlan.hxx
index 1525c662183e68d67344c03f4b8eedf7ef777979..c70028dd3e85a3fa37b206eff29a1f19133f2d0f 100644 (file)
 #include <vector>
 #include <string>
 
+
 #include <Airports/simple.hxx>
-#include <Airports/runways.hxx>
 #include <Navaids/awynet.hxx>
 
 #include "AIBase.hxx"
 
+
+
 using std::vector;
 using std::string;
 
+class FGTaxiRoute;
+class FGRunway;
+class FGAIAircraft;
 
 class FGAIFlightPlan {
 
@@ -53,9 +58,10 @@ public:
    string time;
 
   } waypoint;
-
+  FGAIFlightPlan();
   FGAIFlightPlan(const string& filename);
-  FGAIFlightPlan(const std::string& p,
+  FGAIFlightPlan(FGAIAircraft *,
+                 const std::string& p,
                 double course,
                 time_t start,
                 FGAirport *dep,
@@ -75,6 +81,7 @@ public:
    waypoint* const getCurrentWaypoint( void ) const;
    waypoint* const getNextWaypoint( void ) const;
    void IncrementWaypoint( bool erase );
+   void DecrementWaypoint( bool erase );
 
    double getDistanceToGo(double lat, double lon, waypoint* wp) const;
    int getLeg () const { return leg;};
@@ -85,15 +92,15 @@ public:
    double getBearing(double lat, double lon, waypoint* next) const;
   time_t getStartTime() const { return start_time; }
 
-  void    create(FGAirport *dep, FGAirport *arr, int leg, double alt, double speed, double lat, double lon,
+  void    create(FGAIAircraft *, FGAirport *dep, FGAirport *arr, int leg, double alt, double speed, double lat, double lon,
                 bool firstLeg, double radius, const string& fltType, const string& aircraftType, const string& airline);
 
   void setLeg(int val) { leg = val;}
   void setTime(time_t st) { start_time = st; }
   int getGate() const { return gateId; }
   double getLeadInAngle() const { return leadInAngle; }
-  const string& getRunway() const { return rwy._rwy_no; }
-  const string& getRunwayId() const { return rwy._id; }
+  const string& getRunway() const;
+  
   void setRepeat(bool r) { repeat = r; }
   bool getRepeat(void) const { return repeat; }
   void restart(void);
@@ -104,8 +111,20 @@ public:
   string getRunway() { return activeRunway; }
   bool isActive(time_t time) {return time >= this->getStartTime();}
 
+  void setRunway(string rwy) { activeRunway = rwy; };
+  string getRunwayClassFromTrafficType(string fltType);
+
+  void addWaypoint(waypoint* wpt) { waypoints.push_back(wpt); };
+
+  void setName(string n) { name = n; };
+  string getName() { return name; };
+
+  void setSID(FGAIFlightPlan* fp) { sid = fp;};
+  FGAIFlightPlan* getSID() { return sid; };
+
 private:
-  FGRunway rwy;
+  FGRunway* rwy;
+  FGAIFlightPlan *sid;
   typedef vector <waypoint*> wpt_vector_type;
   typedef wpt_vector_type::const_iterator wpt_vector_iterator;
 
@@ -122,23 +141,36 @@ private:
   string activeRunway;
   FGAirRoute airRoute;
   FGTaxiRoute *taxiRoute;
-
-  void createPushBack(bool, FGAirport*, double, double, double, const string&, const string&, const string&);
-  void createPushBackFallBack(bool, FGAirport*, double, double, double, const string&, const string&, const string&);
-  void createTaxi(bool, int, FGAirport *, double, double, double, const string&, const string&, const string&);
-  void createTakeOff(bool, FGAirport *, double, const string&);
-  void createClimb(bool, FGAirport *, double, double, const string&);
-  void createCruise(bool, FGAirport*, FGAirport*, double, double, double, double, const string&);
-  void createDecent(FGAirport *, const string&);
-  void createLanding(FGAirport *);
-  void createParking(FGAirport *, double radius);
+  string name;
+
+  void createPushBack(FGAIAircraft *, bool, FGAirport*, double, double, double, const string&, const string&, const string&);
+  void createPushBackFallBack(FGAIAircraft *, bool, FGAirport*, double, double, double, const string&, const string&, const string&);
+  void createTakeOff(FGAIAircraft *, bool, FGAirport *, double, const string&);
+  void createClimb(FGAIAircraft *, bool, FGAirport *, double, double, const string&);
+  void createCruise(FGAIAircraft *, bool, FGAirport*, FGAirport*, double, double, double, double, const string&);
+  void createDecent(FGAIAircraft *, FGAirport *, const string&);
+  void createLanding(FGAIAircraft *, FGAirport *, const string&);
+  void createParking(FGAIAircraft *, FGAirport *, double radius);
   void deleteWaypoints(); 
   void resetWaypoints();
 
-  string getRunwayClassFromTrafficType(string fltType);
+  void createLandingTaxi(FGAIAircraft *, FGAirport *apt, double radius, const string& fltType, const string& acType, const string& airline);
+  void createDefaultLandingTaxi(FGAIAircraft *, FGAirport* aAirport);
+  void createDefaultTakeoffTaxi(FGAIAircraft *, FGAirport* aAirport, FGRunway* aRunway);
+  void createTakeoffTaxi(FGAIAircraft *, bool firstFlight, FGAirport *apt, double radius, const string& fltType, const string& acType, const string& airline);
+        
+  waypoint* createOnGround(FGAIAircraft *, const std::string& aName, const SGGeod& aPos, double aElev, double aSpeed);
+  waypoint* createInAir(FGAIAircraft *, const std::string& aName, const SGGeod& aPos, double aElev, double aSpeed);
+  waypoint* cloneWithPos(FGAIAircraft *, waypoint* aWpt, const std::string& aName, const SGGeod& aPos);
+  waypoint* clone(waypoint* aWpt);
+    
 
   //void createCruiseFallback(bool, FGAirport*, FGAirport*, double, double, double, double);
  void evaluateRoutePart(double deplat, double deplon, double arrlat, double arrlon);
+ public:
+  wpt_vector_iterator getFirstWayPoint() { return waypoints.begin(); };
+  wpt_vector_iterator getLastWayPoint()  { return waypoints.end(); };
+
 };    
 
 #endif  // _FG_AIFLIGHTPLAN_HXX