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,34 +1046,30 @@ void FGTowerController::signOff(int id)
|
|||
{
|
||||
// Search activeTraffic for a record matching our id
|
||||
TrafficVectorIterator i = searchActiveTraffic(activeTraffic, id);
|
||||
if (i == activeTraffic.end() || (activeTraffic.empty())) {
|
||||
SG_LOG(SG_ATC, SG_ALERT,
|
||||
"AI error: Aircraft without traffic record is signing off from tower at " << SG_ORIGIN);
|
||||
return;
|
||||
}
|
||||
|
||||
// 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();
|
||||
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);
|
||||
}
|
||||
}
|
||||
if (i == activeTraffic.end() || (activeTraffic.empty())) {
|
||||
SG_LOG(SG_ATC, SG_ALERT,
|
||||
"AI error: Aircraft without traffic record is signing off from tower at " << SG_ORIGIN);
|
||||
} else {
|
||||
|
||||
i->getAircraft()->resetTakeOffStatus();
|
||||
i = activeTraffic.erase(i);
|
||||
activeTraffic.erase(i);
|
||||
SG_LOG(SG_ATC, SG_DEBUG, "Signing off from tower controller");
|
||||
}
|
||||
}
|
||||
|
||||
// NOTE:
|
||||
// IF WE MAKE TRAFFICRECORD A MEMBER OF THE BASE CLASS
|
||||
|
|
|
@ -331,13 +331,16 @@ public:
|
|||
distanceToFinal = 6.0 * SG_NM_TO_METER;
|
||||
};
|
||||
|
||||
std::string getRunwayName() {
|
||||
const std::string& getRunwayName() const
|
||||
{
|
||||
return rwy;
|
||||
};
|
||||
int getCleared () {
|
||||
int getCleared() const
|
||||
{
|
||||
return currentlyCleared;
|
||||
};
|
||||
double getApproachDistance() {
|
||||
const double getApproachDistance() const
|
||||
{
|
||||
return distanceToFinal;
|
||||
};
|
||||
//time_t getEstApproachTime() { return estimatedArrival; };
|
||||
|
|
Loading…
Add table
Reference in a new issue