Traffic: Improve iterator robustness
Attempting to fix Sentry crash FLIGHTGEAR-B, crash on shutdown. Not sure this is quite right, but the logic is clearer and we handle invalid iterators better.
This commit is contained in:
parent
c6182af080
commit
4fe8a118cc
2 changed files with 25 additions and 26 deletions
|
@ -1046,33 +1046,29 @@ void FGTowerController::signOff(int id)
|
||||||
{
|
{
|
||||||
// Search activeTraffic for a record matching our id
|
// Search activeTraffic for a record matching our id
|
||||||
TrafficVectorIterator i = searchActiveTraffic(activeTraffic, id);
|
TrafficVectorIterator i = searchActiveTraffic(activeTraffic, id);
|
||||||
|
|
||||||
// If this aircraft has left the runway, we can clear the departure record for this runway
|
|
||||||
ActiveRunwayVecIterator rwy = activeRunways.begin();
|
|
||||||
if (! activeRunways.empty()) {
|
|
||||||
//while ((rwy->getRunwayName() != i->getRunway()) && (rwy != activeRunways.end())) {
|
|
||||||
while (rwy != activeRunways.end()) {
|
|
||||||
if (rwy->getRunwayName() == i->getRunway()) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
rwy++;
|
|
||||||
}
|
|
||||||
if (rwy != activeRunways.end()) {
|
|
||||||
rwy->setCleared(0);
|
|
||||||
rwy->updatedepartureQueue();
|
|
||||||
} else {
|
|
||||||
SG_LOG(SG_ATC, SG_ALERT,
|
|
||||||
"AI error: Attempting to erase non-existing runway clearance record in FGTowerController::signoff at " << SG_ORIGIN);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (i == activeTraffic.end() || (activeTraffic.empty())) {
|
if (i == activeTraffic.end() || (activeTraffic.empty())) {
|
||||||
SG_LOG(SG_ATC, SG_ALERT,
|
SG_LOG(SG_ATC, SG_ALERT,
|
||||||
"AI error: Aircraft without traffic record is signing off from tower at " << SG_ORIGIN);
|
"AI error: Aircraft without traffic record is signing off from tower at " << SG_ORIGIN);
|
||||||
} else {
|
return;
|
||||||
i->getAircraft()->resetTakeOffStatus();
|
|
||||||
i = activeTraffic.erase(i);
|
|
||||||
SG_LOG(SG_ATC, SG_DEBUG, "Signing off from tower controller");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const auto trafficRunway = i->getRunway();
|
||||||
|
auto runwayIt = std::find_if(activeRunways.begin(), activeRunways.end(),
|
||||||
|
[&trafficRunway](const ActiveRunway& ar) {
|
||||||
|
return ar.getRunwayName() == trafficRunway;
|
||||||
|
});
|
||||||
|
|
||||||
|
if (runwayIt != activeRunways.end()) {
|
||||||
|
runwayIt->setCleared(0);
|
||||||
|
runwayIt->updatedepartureQueue();
|
||||||
|
} else {
|
||||||
|
SG_LOG(SG_ATC, SG_ALERT,
|
||||||
|
"AI error: Attempting to erase non-existing runway clearance record in FGTowerController::signoff at " << SG_ORIGIN);
|
||||||
|
}
|
||||||
|
|
||||||
|
i->getAircraft()->resetTakeOffStatus();
|
||||||
|
activeTraffic.erase(i);
|
||||||
|
SG_LOG(SG_ATC, SG_DEBUG, "Signing off from tower controller");
|
||||||
}
|
}
|
||||||
|
|
||||||
// NOTE:
|
// NOTE:
|
||||||
|
|
|
@ -331,13 +331,16 @@ public:
|
||||||
distanceToFinal = 6.0 * SG_NM_TO_METER;
|
distanceToFinal = 6.0 * SG_NM_TO_METER;
|
||||||
};
|
};
|
||||||
|
|
||||||
std::string getRunwayName() {
|
const std::string& getRunwayName() const
|
||||||
|
{
|
||||||
return rwy;
|
return rwy;
|
||||||
};
|
};
|
||||||
int getCleared () {
|
int getCleared() const
|
||||||
|
{
|
||||||
return currentlyCleared;
|
return currentlyCleared;
|
||||||
};
|
};
|
||||||
double getApproachDistance() {
|
const double getApproachDistance() const
|
||||||
|
{
|
||||||
return distanceToFinal;
|
return distanceToFinal;
|
||||||
};
|
};
|
||||||
//time_t getEstApproachTime() { return estimatedArrival; };
|
//time_t getEstApproachTime() { return estimatedArrival; };
|
||||||
|
|
Loading…
Add table
Reference in a new issue