diff options
author | frosch <frosch@openttd.org> | 2012-01-27 22:08:51 +0000 |
---|---|---|
committer | frosch <frosch@openttd.org> | 2012-01-27 22:08:51 +0000 |
commit | a60f19ae14935e4f68667e67b650219380f5a86f (patch) | |
tree | 4f7619949d9b87678aa5fcde1a269f8187fa82ab | |
parent | 0b4d40b30e4d101180c6ea2259d4d0b5da24ebd0 (diff) | |
download | openttd-a60f19ae14935e4f68667e67b650219380f5a86f.tar.xz |
(svn r23859) -Fix: Inserting conditional orders for ships checked the wrong orders wrt. maximum distance.
-rw-r--r-- | src/order_cmd.cpp | 9 |
1 files changed, 8 insertions, 1 deletions
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); } |