#include <fstream>
#include <iostream>
+#include <cstdlib>
using namespace std;
// Configuration Initialisation
// Should this be in kln89.cxx ?
_turnAnticipationEnabled = false;
-
- _time = new SGTime;
-
+
_messageStack.clear();
_dto = false;
}
DCLGPS::~DCLGPS() {
- delete _time;
delete _approachFP; // Don't need to delete the waypoints inside since they point to
// the waypoints in the approach database.
// TODO - may need to delete the approach database!!
_elapsedTime += dt;
}
- _time->update(_gpsLon * SG_DEGREES_TO_RADIANS, _gpsLat * SG_DEGREES_TO_RADIANS, 0, 0);
// FIXME - currently all the below assumes leg mode and no DTO or OBS cancelled.
if(_activeFP->IsEmpty()) {
// Not sure if we need to reset these each update or only when fp altered
class DCLGPSFilter : public FGPositioned::Filter
{
public:
- virtual bool pass(const FGPositioned* aPos) const {
+ virtual bool pass(FGPositioned* aPos) const
+ {
switch (aPos->type()) {
case FGPositioned::AIRPORT:
// how about heliports and seaports?
GPSWaypoint* DCLGPS::FindFirstById(const string& id) const
{
- DCLGPSFilter filter;
- FGPositionedRef result = FGPositioned::findNextWithPartialId(NULL, id, &filter);
- return GPSWaypoint::createFromPositioned(result);
+ DCLGPSFilter filter;
+ FGPositioned::List matches = FGPositioned::findAllWithIdent(id, &filter, false);
+ if (matches.empty()) {
+ return NULL;
+ }
+
+ FGPositioned::sortByRange(matches, SGGeod::fromRad(_lon, _lat));
+ return GPSWaypoint::createFromPositioned(matches.front());
}
GPSWaypoint* DCLGPS::FindFirstByExactId(const string& id) const
multi = false;
FGPositioned::TypeFilter filter(ty);
- if (exact) {
- FGPositioned::List matches =
- FGPositioned::findAllWithIdent(id, &filter);
- FGPositioned::sortByRange(matches, SGGeod::fromRad(_lon, _lat));
- multi = (matches.size() > 1);
- return matches.empty() ? NULL : matches.front().ptr();
+ FGPositioned::List matches =
+ FGPositioned::findAllWithIdent(id, &filter, exact);
+ if (matches.empty()) {
+ return NULL;
}
- return FGPositioned::findNextWithPartialId(NULL, id, &filter);
+ FGPositioned::sortByRange(matches, SGGeod::fromRad(_lon, _lat));
+ return matches.front();
}
FGNavRecord* DCLGPS::FindFirstVorById(const string& id, bool &multi, bool exact)
h *= SG_RADIANS_TO_DEGREES;
// TODO - use the real altitude below instead of 0.0!
//cout << "MagVar = " << sgGetMagVar(_gpsLon, _gpsLat, 0.0, _time->getJD()) * SG_RADIANS_TO_DEGREES << '\n';
- h -= sgGetMagVar(_gpsLon, _gpsLat, 0.0, _time->getJD()) * SG_RADIANS_TO_DEGREES;
+ double jd = globals->get_time_params()->getJD();
+ h -= sgGetMagVar(_gpsLon, _gpsLat, 0.0, jd) * SG_RADIANS_TO_DEGREES;
while(h >= 360.0) h -= 360.0;
while(h < 0.0) h += 360.0;
return(h);
// Return a position on a radial from wp1 given distance d (nm) and magnetic heading h (degrees)
// Note that d should be less that 1/4 Earth diameter!
GPSWaypoint DCLGPS::GetPositionOnMagRadial(const GPSWaypoint& wp1, double d, double h) {
- h += sgGetMagVar(wp1.lon, wp1.lat, 0.0, _time->getJD()) * SG_RADIANS_TO_DEGREES;
+ double jd = globals->get_time_params()->getJD();
+ h += sgGetMagVar(wp1.lon, wp1.lat, 0.0, jd) * SG_RADIANS_TO_DEGREES;
return(GetPositionOnRadial(wp1, d, h));
}