# HG changeset patch # User rubidium # Date 2008-08-30 10:26:16 # Node ID 424b14d0d013c03ec6275687e9bbd41b2def22c5 # Parent 66da33ee7ae202a9e74dbc4796e7a06566444e45 (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) diff --git a/src/timetable_cmd.cpp b/src/timetable_cmd.cpp --- a/src/timetable_cmd.cpp +++ b/src/timetable_cmd.cpp @@ -24,15 +24,14 @@ static void ChangeTimetable(Vehicle *v, 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; + } } - } - - for (v = v->FirstShared(); v != NULL; v = v->NextShared()) { InvalidateWindow(WC_VEHICLE_TIMETABLE, v->index); } }