From 08ae2cf6e57628e1ca3b7c2c20f405001a497417 Mon Sep 17 00:00:00 2001 From: peter1138 Date: Wed, 9 Aug 2006 21:11:45 +0000 Subject: (svn r5822) - NewGRF: add support for callback 31, vehicle start/stop check. This allows a set to disallow a vehicle from being started, i.e. to not be able to leave the depot. This is almost a partner to callback 1D. --- ship_cmd.c | 10 ++++++++++ 1 file changed, 10 insertions(+) (limited to 'ship_cmd.c') diff --git a/ship_cmd.c b/ship_cmd.c index a47882f11..7b5737559 100644 --- a/ship_cmd.c +++ b/ship_cmd.c @@ -24,6 +24,7 @@ #include "yapf/yapf.h" #include "debug.h" #include "newgrf_callbacks.h" +#include "newgrf_text.h" static const uint16 _ship_sprites[] = {0x0E5D, 0x0E55, 0x0E65, 0x0E6D}; static const byte _ship_sometracks[4] = {0x19, 0x16, 0x25, 0x2A}; @@ -958,6 +959,7 @@ int32 CmdSellShip(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) int32 CmdStartStopShip(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) { Vehicle *v; + uint16 callback; if (!IsVehicleIndex(p1)) return CMD_ERROR; @@ -965,6 +967,14 @@ int32 CmdStartStopShip(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) if (v->type != VEH_Ship || !CheckOwnership(v->owner)) return CMD_ERROR; + /* Check if this ship can be started/stopped. The callback will fail or + * return 0xFF if it can. */ + callback = GetVehicleCallback(CBID_VEHICLE_START_STOP_CHECK, 0, 0, v->engine_type, v); + if (callback != CALLBACK_FAILED && callback != 0xFF) { + StringID error = GetGRFStringID(GetEngineGRFID(v->engine_type), 0xD000 + callback); + return_cmd_error(error); + } + if (flags & DC_EXEC) { if (IsShipInDepotStopped(v)) { DeleteVehicleNews(p1, STR_981C_SHIP_IS_WAITING_IN_DEPOT); -- cgit v1.2.3-70-g09d2