mirror of https://github.com/OpenTTD/OpenTTD
(svn r26694) -Fix (r26547) [FS#6063]: When orders become invalid, reset the waiting time, but keep the travel time.
parent
8701514172
commit
86c43ca183
|
@ -1870,7 +1870,19 @@ restart:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Clear wait time */
|
||||||
|
v->orders.list->UpdateTotalDuration(-order->GetWaitTime());
|
||||||
|
if (order->IsWaitTimetabled()) {
|
||||||
|
v->orders.list->UpdateTimetableDuration(-order->GetTimetabledWait());
|
||||||
|
order->SetWaitTimetabled(false);
|
||||||
|
}
|
||||||
|
order->SetWaitTime(0);
|
||||||
|
|
||||||
|
/* Clear order, preserving travel time */
|
||||||
|
bool travel_timetabled = order->IsTravelTimetabled();
|
||||||
order->MakeDummy();
|
order->MakeDummy();
|
||||||
|
order->SetTravelTimetabled(travel_timetabled);
|
||||||
|
|
||||||
for (const Vehicle *w = v->FirstShared(); w != NULL; w = w->NextShared()) {
|
for (const Vehicle *w = v->FirstShared(); w != NULL; w = w->NextShared()) {
|
||||||
/* In GUI, simulate by removing the order and adding it back */
|
/* In GUI, simulate by removing the order and adding it back */
|
||||||
InvalidateVehicleOrder(w, id | (INVALID_VEH_ORDER_ID << 8));
|
InvalidateVehicleOrder(w, id | (INVALID_VEH_ORDER_ID << 8));
|
||||||
|
|
Loading…
Reference in New Issue