Fix auto timetable separation to handle non-station orders sensibly.

This commit is contained in:
Jonathan G Rennison
2015-08-09 15:54:08 +01:00
parent 34e41a2e26
commit d24f7763cc

View File

@@ -441,6 +441,27 @@ CommandCost CmdAutomateTimetable(TileIndex index, DoCommandFlag flags, uint32 p1
return CommandCost(); return CommandCost();
} }
static inline bool IsOrderUsableForSeparation(const Order *order)
{
if (order->IsType(OT_CONDITIONAL)) {
// Auto separation is unlikely to useful work at all if one of these is present, so give up
return false;
}
if (order->GetWaitTime() == 0 && order->IsType(OT_GOTO_STATION)) {
// non-station orders are permitted to have 0 wait times
return false;
}
if (order->GetTravelTime() == 0 && !order->IsTravelTimetabled()) {
// 0 travel times are permitted, if explicitly timetabled
// this is useful for depot service orders
return false;
}
return true;
}
int TimeToFinishOrder(Vehicle *v, int n) int TimeToFinishOrder(Vehicle *v, int n)
{ {
int left; int left;
@@ -448,8 +469,8 @@ int TimeToFinishOrder(Vehicle *v, int n)
int wait_time = order->GetWaitTime(); int wait_time = order->GetWaitTime();
int travel_time = order->GetTravelTime(); int travel_time = order->GetTravelTime();
assert(order != NULL); assert(order != NULL);
if (!IsOrderUsableForSeparation(order)) return -1;
if ((v->cur_real_order_index == n) && (v->last_station_visited == order->GetDestination())) { if ((v->cur_real_order_index == n) && (v->last_station_visited == order->GetDestination())) {
if (wait_time == 0) return -1;
if (v->current_loading_time > 0) { if (v->current_loading_time > 0) {
left = wait_time - v->current_order_time; left = wait_time - v->current_order_time;
} else { } else {
@@ -459,7 +480,6 @@ int TimeToFinishOrder(Vehicle *v, int n)
} else { } else {
left = travel_time; left = travel_time;
if (v->cur_real_order_index == n) left -= v->current_order_time; if (v->cur_real_order_index == n) left -= v->current_order_time;
if (travel_time == 0 || wait_time == 0) return -1;
if (left < 0) left = 0; if (left < 0) left = 0;
left +=wait_time; left +=wait_time;
} }
@@ -486,10 +506,8 @@ int SeparationBetween(Vehicle *v1, Vehicle *v2)
if (time < 0) { if (time < 0) {
for (n = 0; n < v1->GetNumOrders(); n++) { for (n = 0; n < v1->GetNumOrders(); n++) {
Order *order = v1->GetOrder(n); Order *order = v1->GetOrder(n);
int wait_time = order->GetWaitTime(); if (!IsOrderUsableForSeparation(order)) return -1;
int travel_time = order->GetTravelTime(); time += order->GetTravelTime() + order->GetWaitTime();
if (travel_time == 0 || wait_time == 0) return -1;
time += travel_time + wait_time;
} }
} }
separation += time; separation += time;