1
0
Fork 0

Olaf Flebbe:

I had massive problems with tower.cxx, so I decided to doublecheck all
containers and iterators in order and found lot of potential problems.

Now I can fly with "debug on" of KSFO for minutes without problems.

The fix for AIMgr is from Mathias, but I reworked it. So blame me, not him.
This commit is contained in:
ehofman 2006-01-30 13:44:56 +00:00
parent bd1f711b51
commit 7e46303195
2 changed files with 35 additions and 13 deletions

View file

@ -213,16 +213,18 @@ void FGAIMgr::update(double dt) {
string s = (*apt_itr).first; string s = (*apt_itr).first;
if(traffic.find(s) != traffic.end()) { if(traffic.find(s) != traffic.end()) {
//cout << "s = " << s << ", traffic[s].size() = " << traffic[s].size() << '\n'; //cout << "s = " << s << ", traffic[s].size() = " << traffic[s].size() << '\n';
if(traffic[s].size()) { if(!traffic[s].empty()) {
apt_itr++; apt_itr++;
} else { } else {
//cout << "Erasing " << (*apt_itr).first << " and traffic" << '\n'; //cout << "Erasing " << (*apt_itr).first << " and traffic" << '\n';
activated.erase(apt_itr++); activated.erase(apt_itr);
apt_itr = activated.upper_bound(s);
traffic.erase(s); traffic.erase(s);
} }
} else { } else {
//cout << "Erasing " << (*apt_itr).first << ' ' << (*apt_itr).second << '\n'; //cout << "Erasing " << (*apt_itr).first << ' ' << (*apt_itr).second << '\n';
activated.erase(apt_itr++); activated.erase(apt_itr);
apt_itr = activated.upper_bound(s);
} }
} else { } else {
apt_itr++; apt_itr++;

View file

@ -311,6 +311,7 @@ void FGTower::Init() {
t->planePtr = NULL; t->planePtr = NULL;
t->clearedToTakeOff = true; t->clearedToTakeOff = true;
rwyList.push_back(t); rwyList.push_back(t);
rwyListItr = rwyList.begin();
departed = false; departed = false;
} else { } else {
//cout << "User not on active runway\n"; //cout << "User not on active runway\n";
@ -528,10 +529,11 @@ void FGTower::Respond() {
ClearHoldingPlane(t); ClearHoldingPlane(t);
t->leg = TAKEOFF_ROLL; t->leg = TAKEOFF_ROLL;
rwyList.push_back(t); rwyList.push_back(t);
rwyListItr = rwyList.begin();
rwyOccupied = true; rwyOccupied = true;
// WARNING - WE ARE ASSUMING ONLY ONE PLANE REPORTING HOLD AT A TIME BELOW // WARNING - WE ARE ASSUMING ONLY ONE PLANE REPORTING HOLD AT A TIME BELOW
// FIXME TODO - FIX THIS!!! // FIXME TODO - FIX THIS!!!
if(holdList.size()) { if(!holdList.empty()) {
if(holdListItr == holdList.end()) { if(holdListItr == holdList.end()) {
holdListItr = holdList.begin(); holdListItr = holdList.begin();
} }
@ -632,7 +634,7 @@ void FGTower::ProcessDownwindReport(TowerPlaneRec* t) {
// This assumes that the number spoken is landing position, not circuit position, since some of the traffic might be on straight-in final. // This assumes that the number spoken is landing position, not circuit position, since some of the traffic might be on straight-in final.
trns += " "; trns += " ";
TowerPlaneRec* tt = NULL; TowerPlaneRec* tt = NULL;
if((i == 1) && (!rwyList.size()) && (t->nextOnRwy) && (!cf)) { // Unfortunately nextOnRwy currently doesn't handle circuit/straight-in ordering properly at present, hence the cf check below. if((i == 1) && rwyList.empty() && (t->nextOnRwy) && (!cf)) { // Unfortunately nextOnRwy currently doesn't handle circuit/straight-in ordering properly at present, hence the cf check below.
trns += "Cleared to land"; // TODO - clear for the option if appropriate trns += "Cleared to land"; // TODO - clear for the option if appropriate
t->clearedToLand = true; t->clearedToLand = true;
if(!t->isUser) t->planePtr->RegisterTransmission(7); if(!t->isUser) t->planePtr->RegisterTransmission(7);
@ -843,7 +845,7 @@ void FGTower::ClearHoldingPlane(TowerPlaneRec* t) {
// Do one plane from the hold list // Do one plane from the hold list
void FGTower::CheckHoldList(double dt) { void FGTower::CheckHoldList(double dt) {
//cout << "Entering CheckHoldList..." << endl; //cout << "Entering CheckHoldList..." << endl;
if(holdList.size()) { if(!holdList.empty()) {
//cout << "*holdListItr = " << *holdListItr << endl; //cout << "*holdListItr = " << *holdListItr << endl;
if(holdListItr == holdList.end()) { if(holdListItr == holdList.end()) {
holdListItr = holdList.begin(); holdListItr = holdList.begin();
@ -866,9 +868,12 @@ void FGTower::CheckHoldList(double dt) {
ClearHoldingPlane(t); ClearHoldingPlane(t);
t->leg = TAKEOFF_ROLL; t->leg = TAKEOFF_ROLL;
rwyList.push_back(t); rwyList.push_back(t);
rwyListItr = rwyList.begin();
rwyOccupied = true; rwyOccupied = true;
holdList.erase(holdListItr); holdList.erase(holdListItr);
holdListItr = holdList.begin(); holdListItr = holdList.begin();
if (holdList.empty())
return;
} }
} }
// TODO - rationalise the considerable code duplication above! // TODO - rationalise the considerable code duplication above!
@ -886,7 +891,7 @@ void FGTower::CheckCircuitList(double dt) {
downwind_leg_pos = 0.0; downwind_leg_pos = 0.0;
crosswind_leg_pos = 0.0; crosswind_leg_pos = 0.0;
if(circuitList.size()) { // Do one plane from the circuit if(!circuitList.empty()) { // Do one plane from the circuit
if(circuitListItr == circuitList.end()) { if(circuitListItr == circuitList.end()) {
circuitListItr = circuitList.begin(); circuitListItr = circuitList.begin();
} }
@ -928,18 +933,21 @@ void FGTower::CheckCircuitList(double dt) {
t->opType = OUTBOUND; // TODO - could check if the user has climbed significantly above circuit altitude as well. t->opType = OUTBOUND; // TODO - could check if the user has climbed significantly above circuit altitude as well.
// Since we are unknown operation we should be in depList already. // Since we are unknown operation we should be in depList already.
//cout << ident << " Removing user from circuitList (TTT_UNKNOWN)\n"; //cout << ident << " Removing user from circuitList (TTT_UNKNOWN)\n";
circuitList.erase(circuitListItr); circuitListItr = circuitList.erase(circuitListItr);
RemoveFromTrafficList(t->plane.callsign); RemoveFromTrafficList(t->plane.callsign);
circuitListItr = circuitList.begin(); if (circuitList.empty())
return;
} }
} else if(t->opType == CIRCUIT) { } else if(t->opType == CIRCUIT) {
if(tortho.y() > 10000) { if(tortho.y() > 10000) {
// 10 km out - assume the user has abandoned the circuit!! // 10 km out - assume the user has abandoned the circuit!!
t->opType = OUTBOUND; t->opType = OUTBOUND;
depList.push_back(t); depList.push_back(t);
depListItr = depList.begin();
//cout << ident << " removing user from circuitList (CIRCUIT)\n"; //cout << ident << " removing user from circuitList (CIRCUIT)\n";
circuitList.erase(circuitListItr); circuitListItr = circuitList.erase(circuitListItr);
circuitListItr = circuitList.begin(); if (circuitList.empty())
return;
} }
} }
} }
@ -1152,20 +1160,24 @@ void FGTower::CheckRunwayList(double dt) {
// It's possible we could be a bit more proactive about this. // It's possible we could be a bit more proactive about this.
} else if(t->opType == OUTBOUND) { } else if(t->opType == OUTBOUND) {
depList.push_back(t); depList.push_back(t);
depListItr = depList.begin();
rwyList.pop_front(); rwyList.pop_front();
departed = true; departed = true;
timeSinceLastDeparture = 0.0; timeSinceLastDeparture = 0.0;
} else if(t->opType == CIRCUIT) { } else if(t->opType == CIRCUIT) {
//cout << ident << " adding " << t->plane.callsign << " to circuitList" << endl; //cout << ident << " adding " << t->plane.callsign << " to circuitList" << endl;
circuitList.push_back(t); circuitList.push_back(t);
circuitListItr = circuitList.begin();
AddToTrafficList(t); AddToTrafficList(t);
rwyList.pop_front(); rwyList.pop_front();
departed = true; departed = true;
timeSinceLastDeparture = 0.0; timeSinceLastDeparture = 0.0;
} else if(t->opType == TTT_UNKNOWN) { } else if(t->opType == TTT_UNKNOWN) {
depList.push_back(t); depList.push_back(t);
depListItr = depList.begin();
//cout << ident << " adding " << t->plane.callsign << " to circuitList" << endl; //cout << ident << " adding " << t->plane.callsign << " to circuitList" << endl;
circuitList.push_back(t); circuitList.push_back(t);
circuitListItr = circuitList.begin();
AddToTrafficList(t); AddToTrafficList(t);
rwyList.pop_front(); rwyList.pop_front();
departed = true; departed = true;
@ -1183,7 +1195,7 @@ void FGTower::CheckRunwayList(double dt) {
void FGTower::CheckApproachList(double dt) { void FGTower::CheckApproachList(double dt) {
//cout << "CheckApproachList called for " << ident << endl; //cout << "CheckApproachList called for " << ident << endl;
//cout << "AppList.size is " << appList.size() << endl; //cout << "AppList.size is " << appList.size() << endl;
if(appList.size()) { if(!appList.empty()) {
if(appListItr == appList.end()) { if(appListItr == appList.end()) {
appListItr = appList.begin(); appListItr = appList.begin();
} }
@ -1281,6 +1293,9 @@ void FGTower::CheckApproachList(double dt) {
if(appListItr == appList.end() ) { if(appListItr == appList.end() ) {
appListItr = appList.begin(); appListItr = appList.begin();
} }
if (appList.empty())
return;
} }
++appListItr; ++appListItr;
@ -1290,7 +1305,7 @@ void FGTower::CheckApproachList(double dt) {
// Do one plane from the departure list // Do one plane from the departure list
void FGTower::CheckDepartureList(double dt) { void FGTower::CheckDepartureList(double dt) {
if(depList.size()) { if(!depList.empty()) {
if(depListItr == depList.end()) { if(depListItr == depList.end()) {
depListItr = depList.begin(); depListItr = depList.begin();
} }
@ -1643,10 +1658,12 @@ bool FGTower::AddToCircuitList(TowerPlaneRec* t) {
// It depends on what the two planes are doing and whether there's a conflict what we do. // It depends on what the two planes are doing and whether there's a conflict what we do.
if(tpr->eta - t->eta > separation_time) { // No probs, plane 2 can squeeze in before plane 1 with no apparent conflict if(tpr->eta - t->eta > separation_time) { // No probs, plane 2 can squeeze in before plane 1 with no apparent conflict
circuitList.insert(twrItr, t); circuitList.insert(twrItr, t);
circuitListItr = circuitList.begin();
} else { // Ooops - this ones tricky - we have a potential conflict! } else { // Ooops - this ones tricky - we have a potential conflict!
conflict = true; conflict = true;
// HACK - just add anyway for now and flag conflict. // HACK - just add anyway for now and flag conflict.
circuitList.insert(twrItr, t); circuitList.insert(twrItr, t);
circuitListItr = circuitList.begin();
} }
//cout << "\tC\t" << circuitList.size() << '\n'; //cout << "\tC\t" << circuitList.size() << '\n';
return(conflict); return(conflict);
@ -1655,6 +1672,7 @@ bool FGTower::AddToCircuitList(TowerPlaneRec* t) {
// If we get here we must be at the end of the list, or maybe the list is empty. // If we get here we must be at the end of the list, or maybe the list is empty.
//cout << ident << " adding " << t->plane.callsign << " to circuitList" << endl; //cout << ident << " adding " << t->plane.callsign << " to circuitList" << endl;
circuitList.push_back(t); // TODO - check the separation with the preceding plane for the conflict flag. circuitList.push_back(t); // TODO - check the separation with the preceding plane for the conflict flag.
circuitListItr = circuitList.begin();
//cout << "\tE\t" << circuitList.size() << endl; //cout << "\tE\t" << circuitList.size() << endl;
return(conflict); return(conflict);
} }
@ -2007,6 +2025,7 @@ void FGTower::VFRArrivalContact(const string& ID, const LandingType& opt) {
responseReqd = true; responseReqd = true;
appList.push_back(t); // Not necessarily permanent appList.push_back(t); // Not necessarily permanent
appListItr = appList.begin();
AddToTrafficList(t); AddToTrafficList(t);
current_atcdialog->remove_entry(ident, USER_REQUEST_VFR_ARRIVAL, TOWER); current_atcdialog->remove_entry(ident, USER_REQUEST_VFR_ARRIVAL, TOWER);
@ -2036,6 +2055,7 @@ void FGTower::VFRArrivalContact(const PlaneRec& plane, FGAIPlane* requestee, con
//cout << "Before adding, appList.size = " << appList.size() << " at " << ident << '\n'; //cout << "Before adding, appList.size = " << appList.size() << " at " << ident << '\n';
appList.push_back(t); // Not necessarily permanent appList.push_back(t); // Not necessarily permanent
appListItr = appList.begin();
//cout << "After adding, appList.size = " << appList.size() << " at " << ident << '\n'; //cout << "After adding, appList.size = " << appList.size() << " at " << ident << '\n';
AddToTrafficList(t); AddToTrafficList(t);
} }