From a60f19ae14935e4f68667e67b650219380f5a86f Mon Sep 17 00:00:00 2001 From: frosch Date: Fri, 27 Jan 2012 22:08:51 +0000 Subject: (svn r23859) -Fix: Inserting conditional orders for ships checked the wrong orders wrt. maximum distance. --- src/order_cmd.cpp | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/order_cmd.cpp b/src/order_cmd.cpp index aed5195fe..824d82045 100644 --- a/src/order_cmd.cpp +++ b/src/order_cmd.cpp @@ -812,7 +812,14 @@ CommandCost CmdInsertOrder(TileIndex tile, DoCommandFlag flags, uint32 p1, uint3 if (++n == sel_ord && prev != NULL) break; } if (prev != NULL) { - uint dist = GetOrderDistance(prev, &new_order, v); + uint dist; + if (new_order.IsType(OT_CONDITIONAL)) { + /* The order is not yet inserted, so we have to do the first iteration here. */ + dist = GetOrderDistance(prev, v->GetOrder(new_order.GetConditionSkipToOrder()), v); + } else { + dist = GetOrderDistance(prev, &new_order, v); + } + if (dist >= 130) { return_cmd_error(STR_ERROR_TOO_FAR_FROM_PREVIOUS_DESTINATION); } -- cgit v1.2.3-70-g09d2