// forward decls
class FGAirportDynamics;
class FGRunway;
+class FGTaxiway;
typedef SGSharedPtr<FGRunway> FGRunwayPtr;
+typedef SGSharedPtr<FGTaxiway> FGTaxiwayPtr;
/***************************************************************************************
*
bool hasHardRunwayOfLengthFt(double aLengthFt) const;
unsigned int numTaxiways() const;
- FGRunway* getTaxiwayByIndex(unsigned int aIndex) const;
+ FGTaxiway* getTaxiwayByIndex(unsigned int aIndex) const;
- void addRunway(FGRunway* aRunway);
+ void setRunwaysAndTaxiways(std::vector<FGRunwayPtr>& rwys,
+ std::vector<FGTaxiwayPtr>& txwys);
class AirportFilter : public Filter
{
public:
virtual bool pass(FGPositioned* aPos) const {
- Type ty(aPos->type());
- return (ty >= AIRPORT) && (ty <= SEAPORT);
+ return passAirport(static_cast<FGAirport*>(aPos));
+ }
+
+ virtual Type minType() const {
+ return AIRPORT;
+ }
+
+ virtual Type maxType() const {
+ return SEAPORT;
+ }
+
+ virtual bool passAirport(FGAirport* aApt) const {
+ return true;
}
};
- class HardSurfaceFilter : public Filter
+ class HardSurfaceFilter : public AirportFilter
{
public:
HardSurfaceFilter(double minLengthFt);
- virtual bool pass(FGPositioned* aPos) const;
+ virtual bool passAirport(FGAirport* aApt) const;
+
+ virtual Type maxType() const {
+ return AIRPORT;
+ }
private:
double mMinLengthFt;
};
FGAirport(const FGAirport&);
std::vector<FGRunwayPtr> mRunways;
- std::vector<FGRunwayPtr> mTaxiways;
+ std::vector<FGTaxiwayPtr> mTaxiways;
};
// find basic airport location info from airport database