summaryrefslogtreecommitdiff
path: root/order_cmd.c
diff options
context:
space:
mode:
authorbjarni <bjarni@openttd.org>2006-10-08 20:54:27 +0000
committerbjarni <bjarni@openttd.org>2006-10-08 20:54:27 +0000
commiteeb8fc185385b31c74f1b3716620668f340d506f (patch)
tree34fda859aaefb3614ee685c534469ee16fedbdce /order_cmd.c
parente397df0e0dcef8b6880450040c2ba2f7505ea02d (diff)
downloadopenttd-eeb8fc185385b31c74f1b3716620668f340d506f.tar.xz
(svn r6694) -Fix: FS#361 Refit-to Order bug (only one of the two bugs mentioned there)
-Now refit orders are copied when copying orders -Fixed an initilation issue where CT_INVALID was used instead of CT_NO_REFIT (resulted in crashes in the order window) -Fixed a compiler warning in the function to load TTD savegames
Diffstat (limited to 'order_cmd.c')
-rw-r--r--order_cmd.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/order_cmd.c b/order_cmd.c
index c0bcc343b..17ba95ce2 100644
--- a/order_cmd.c
+++ b/order_cmd.c
@@ -50,6 +50,10 @@ Order UnpackOldOrder(uint16 packed)
order.dest = GB(packed, 8, 8);
order.next = NULL;
+ order.refit_cargo = CT_NO_REFIT;
+ order.refit_subtype = 0;
+ order.index = 0; // avoid compiler warning
+
// Sanity check
// TTD stores invalid orders as OT_NOTHING with non-zero flags/station
if (order.type == OT_NOTHING && (order.flags != 0 || order.dest != 0)) {
@@ -57,9 +61,6 @@ Order UnpackOldOrder(uint16 packed)
order.flags = 0;
}
- order.refit_cargo = CT_INVALID;
- order.refit_subtype = 0;
-
return order;
}
@@ -76,7 +77,7 @@ static Order UnpackVersion4Order(uint16 packed)
order.dest = GB(packed, 8, 8);
order.next = NULL;
order.index = 0; // avoid compiler warning
- order.refit_cargo = CT_INVALID;
+ order.refit_cargo = CT_NO_REFIT;
order.refit_subtype = 0;
return order;
}
@@ -128,6 +129,8 @@ static Order *AllocateOrder(void)
memset(order, 0, sizeof(*order));
order->index = index;
order->next = NULL;
+ order->refit_cargo = CT_NO_REFIT;
+ order->refit_subtype = 0;
return order;
}
@@ -151,8 +154,8 @@ void AssignOrder(Order *order, Order data)
order->flags = data.flags;
order->dest = data.dest;
- order->refit_cargo = CT_NO_REFIT;
- order->refit_subtype = CT_NO_REFIT;
+ order->refit_cargo = data.refit_cargo;
+ order->refit_subtype = data.refit_subtype;
}