From d40145008ee728c8c32cc3626809da0af17bafe9 Mon Sep 17 00:00:00 2001 From: rubidium Date: Sat, 30 Aug 2008 10:26:16 +0000 Subject: (svn r14192) -Fix [FS#2236]: properly update the current timetable's travel/wait times instead of only doing it for one vehicle in the shared order chain and only when some bit has not been set (PhilSophus) --- src/timetable_cmd.cpp | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/src/timetable_cmd.cpp b/src/timetable_cmd.cpp index f0fea8530..0aa856ca9 100644 --- a/src/timetable_cmd.cpp +++ b/src/timetable_cmd.cpp @@ -24,15 +24,14 @@ static void ChangeTimetable(Vehicle *v, VehicleOrderID order_number, uint16 time order->wait_time = time; } - if (v->cur_order_index == order_number && v->current_order.GetDepotOrderType() & ODTFB_PART_OF_ORDERS) { - if (is_journey) { - v->current_order.travel_time = time; - } else { - v->current_order.wait_time = time; - } - } - for (v = v->FirstShared(); v != NULL; v = v->NextShared()) { + if (v->cur_order_index == order_number && v->current_order.Equals(*order)) { + if (is_journey) { + v->current_order.travel_time = time; + } else { + v->current_order.wait_time = time; + } + } InvalidateWindow(WC_VEHICLE_TIMETABLE, v->index); } } -- cgit v1.2.3-70-g09d2