diff --git a/src/Instrumentation/gps.cxx b/src/Instrumentation/gps.cxx index 9a3470680..471089a53 100644 --- a/src/Instrumentation/gps.cxx +++ b/src/Instrumentation/gps.cxx @@ -267,6 +267,7 @@ void GPS::unbind() { _tiedProperties.Untie(); + _gpsNode.clear(); } void @@ -366,6 +367,14 @@ GPS::update (double delta_time_sec) _lastPosValid = !(_last_pos == SGGeod()); } +void GPS::shutdown() +{ + if (_route) { + _route->removeDelegate(this); + _route = nullptr; + } +} + void GPS::routeManagerFlightPlanChanged(SGPropertyNode*) { if (_route) { diff --git a/src/Instrumentation/gps.hxx b/src/Instrumentation/gps.hxx index 200499eb7..7e0ca3832 100644 --- a/src/Instrumentation/gps.hxx +++ b/src/Instrumentation/gps.hxx @@ -70,6 +70,7 @@ public: void bind() override; void unbind() override; void update (double delta_time_sec) override; + void shutdown() override; // Subsystem identification. static const char* staticSubsystemClassId() { return "gps"; }