summaryrefslogtreecommitdiff
path: root/order_cmd.c
diff options
context:
space:
mode:
authorbjarni <bjarni@openttd.org>2006-10-05 08:27:40 +0000
committerbjarni <bjarni@openttd.org>2006-10-05 08:27:40 +0000
commit55c7840710742ee3caebded16fadc3700ad65e0c (patch)
tree226a76bc9c6a0a5fdfa3a29b63adf1e5672217e8 /order_cmd.c
parentff6f83b56ca48d1590ae7adc8f6f85fbfe7c7424 (diff)
downloadopenttd-55c7840710742ee3caebded16fadc3700ad65e0c.tar.xz
(svn r6647) -Fix: [vehicle list windows] Lists of shared orders are now no longer closed by a window event if the list is empty
The window is now closed when the order is deleted. This is because removing windows from a window event is asking for problems
Diffstat (limited to 'order_cmd.c')
-rw-r--r--order_cmd.c16
1 files changed, 15 insertions, 1 deletions
diff --git a/order_cmd.c b/order_cmd.c
index b87fb6879..c0bcc343b 100644
--- a/order_cmd.c
+++ b/order_cmd.c
@@ -1124,7 +1124,21 @@ void DeleteVehicleOrders(Vehicle *v)
v->orders = NULL;
v->num_orders = 0;
- while (cur != NULL) {
+ if (cur != NULL) {
+ /* Delete the vehicle list of shared orders, if any */
+ int window_type = 0;
+
+ switch (v->type) {
+ case VEH_Train: window_type = WC_TRAINS_LIST; break;
+ case VEH_Road: window_type = WC_ROADVEH_LIST; break;
+ case VEH_Ship: window_type = WC_SHIPS_LIST; break;
+ case VEH_Aircraft: window_type = WC_AIRCRAFT_LIST; break;
+ default: NOT_REACHED();
+ }
+ DeleteWindowById(window_type, (cur->index << 16) | (v->type << 11) | VLW_SHARED_ORDERS | v->owner);
+ }
+
+ while (cur != NULL) {
next = cur->next;
DeleteOrder(cur);
cur = next;