mirror of https://github.com/OpenTTD/OpenTTD
(svn r303) Fix: [ 1022227 ] Ships could unload cargo at stations without docks
parent
807da4e722
commit
0ba58f25a4
|
@ -663,8 +663,10 @@ static void ShipController(Vehicle *v)
|
||||||
|
|
||||||
v->last_station_visited = v->next_order_param;
|
v->last_station_visited = v->next_order_param;
|
||||||
|
|
||||||
|
/* Process station in the schedule. Don't do that for buoys (HVOT_BUOY) */
|
||||||
st = DEREF_STATION(v->next_order_param);
|
st = DEREF_STATION(v->next_order_param);
|
||||||
if (!(st->had_vehicle_of_type & HVOT_BUOY)) {
|
if (!(st->had_vehicle_of_type & HVOT_BUOY)
|
||||||
|
&& (st->facilities & FACIL_DOCK)) { /* ugly, ugly workaround for problem with ships able to drop off cargo at wrong stations */
|
||||||
v->next_order = (v->next_order & (OF_FULL_LOAD|OF_UNLOAD)) | OF_NON_STOP | OT_LOADING;
|
v->next_order = (v->next_order & (OF_FULL_LOAD|OF_UNLOAD)) | OF_NON_STOP | OT_LOADING;
|
||||||
ShipArrivesAt(v, st);
|
ShipArrivesAt(v, st);
|
||||||
|
|
||||||
|
@ -674,7 +676,7 @@ static void ShipController(Vehicle *v)
|
||||||
MarkShipDirty(v);
|
MarkShipDirty(v);
|
||||||
}
|
}
|
||||||
InvalidateWindowWidget(WC_VEHICLE_VIEW, v->index, 4);
|
InvalidateWindowWidget(WC_VEHICLE_VIEW, v->index, 4);
|
||||||
} else {
|
} else { /* leave buoys right aways */
|
||||||
v->next_order = OT_LEAVESTATION;
|
v->next_order = OT_LEAVESTATION;
|
||||||
v->cur_order_index++;
|
v->cur_order_index++;
|
||||||
InvalidateVehicleOrderWidget(v);
|
InvalidateVehicleOrderWidget(v);
|
||||||
|
|
Loading…
Reference in New Issue