Changeset - r23490:269ca3d32272
[Not reviewed]
master
0 2 0
Michael Lutz - 5 years ago 2019-03-20 21:46:02
michi@icosahedron.de
Fix #7391, 9b99b95: Don't invalidate go to depot orders of non-aircraft when invalidating hangar orders that happen to share IDs.

This was caused because hangars are referred to by station ID, which is not unique with respect to depot IDs.
2 files changed with 3 insertions and 1 deletions:
0 comments (0 inline, 0 general)
src/order_backup.cpp
Show inline comments
 
@@ -263,6 +263,7 @@ CommandCost CmdClearOrderBackup(TileInde
 
		for (Order *order = ob->orders; order != NULL; order = order->next) {
 
			OrderType ot = order->GetType();
 
			if (ot == OT_GOTO_DEPOT && (order->GetDepotActionType() & ODATFB_NEAREST_DEPOT) != 0) continue;
 
			if (ot == OT_GOTO_DEPOT && hangar && !IsHangarTile(ob->tile)) continue; // Not an aircraft? Can't have a hangar order.
 
			if (ot == OT_IMPLICIT || (IsHangarTile(ob->tile) && ot == OT_GOTO_DEPOT && !hangar)) ot = OT_GOTO_STATION;
 
			if (ot == type && order->GetDestination() == destination) {
 
				/* Remove the order backup! If a station/depot gets removed, we can't/shouldn't restore those broken orders. */
src/order_cmd.cpp
Show inline comments
 
@@ -1851,7 +1851,7 @@ void RemoveOrderFromAllVehicles(OrderTyp
 

	
 
		order = &v->current_order;
 
		if ((v->type == VEH_AIRCRAFT && order->IsType(OT_GOTO_DEPOT) && !hangar ? OT_GOTO_STATION : order->GetType()) == type &&
 
				v->current_order.GetDestination() == destination) {
 
				(!hangar || v->type == VEH_AIRCRAFT) && v->current_order.GetDestination() == destination) {
 
			order->MakeDummy();
 
			SetWindowDirty(WC_VEHICLE_VIEW, v->index);
 
		}
 
@@ -1864,6 +1864,7 @@ restart:
 

	
 
			OrderType ot = order->GetType();
 
			if (ot == OT_GOTO_DEPOT && (order->GetDepotActionType() & ODATFB_NEAREST_DEPOT) != 0) continue;
 
			if (ot == OT_GOTO_DEPOT && hangar && v->type != VEH_AIRCRAFT) continue; // Not an aircraft? Can't have a hangar order.
 
			if (ot == OT_IMPLICIT || (v->type == VEH_AIRCRAFT && ot == OT_GOTO_DEPOT && !hangar)) ot = OT_GOTO_STATION;
 
			if (ot == type && order->GetDestination() == destination) {
 
				/* We want to clear implicit orders, but we don't want to make them
0 comments (0 inline, 0 general)