summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--newgrf_callbacks.h11
-rw-r--r--station_cmd.c30
2 files changed, 40 insertions, 1 deletions
diff --git a/newgrf_callbacks.h b/newgrf_callbacks.h
index 24a697395..62ce8ac96 100644
--- a/newgrf_callbacks.h
+++ b/newgrf_callbacks.h
@@ -19,6 +19,14 @@ enum CallbackID {
// only for train vehicles
CBID_TRAIN_VEHICLE_LENGTH = 0x11,
+ /* Called (if appropriate bit in callback mask is set) to determine if a
+ * newstation should be made available to build */
+ CBID_STATION_AVAILABILITY = 0x13,
+
+ /* Called (if appropriate bit in callback mask is set) when drawing a tile
+ * to choose a sprite layout to draw, instead of the standard 0-7 range */
+ CBID_STATION_SPRITE_LAYOUT = 0x14,
+
// Refit capacity, the passed vehicle needs to have its ->cargo_type set to
// the cargo we are refitting to, returns the new cargo capacity
CBID_VEHICLE_REFIT_CAPACITY = 0x15,
@@ -30,6 +38,9 @@ enum CallbackID {
/* This callback is called from vehicle purchase lists. It returns a value to be
* used as a custom string ID in the 0xD000 range. */
CBID_VEHICLE_ADDITIONAL_TEXT = 0x23,
+
+ /* Called when building a station to customize the tile layout */
+ CBID_STATION_TILE_LAYOUT = 0x24,
};
/**
diff --git a/station_cmd.c b/station_cmd.c
index b488fa212..e523e491b 100644
--- a/station_cmd.c
+++ b/station_cmd.c
@@ -29,6 +29,8 @@
#include "train.h"
#include "water_map.h"
#include "industry_map.h"
+#include "newgrf_callbacks.h"
+#include "newgrf_station.h"
enum {
/* Max stations: 64000 (64 * 1000) */
@@ -1049,6 +1051,20 @@ int32 CmdBuildRailroadStation(TileIndex tile_org, uint32 flags, uint32 p1, uint3
specindex = AllocateSpecToStation(statspec, st, flags & DC_EXEC);
if (specindex == -1) return CMD_ERROR;
+ if (statspec != NULL) {
+ /* Perform NewStation checks */
+
+ /* Check if the station size is permitted */
+ if (HASBIT(statspec->disallowed_platforms, numtracks - 1) || HASBIT(statspec->disallowed_lengths, plat_len - 1)) {
+ return CMD_ERROR;
+ }
+
+ /* Check if the station is buildable */
+ if (HASBIT(statspec->callbackmask, CBM_STATION_AVAIL) && GetStationCallback(CBID_STATION_AVAILABILITY, 0, 0, statspec, NULL, INVALID_TILE) == 0) {
+ return CMD_ERROR;
+ }
+ }
+
if (flags & DC_EXEC) {
TileIndexDiff tile_delta;
byte *layout_ptr;
@@ -1085,6 +1101,11 @@ int32 CmdBuildRailroadStation(TileIndex tile_org, uint32 flags, uint32 p1, uint3
SetCustomStationSpecIndex(tile, specindex);
SetStationTileRandomBits(tile, GB(Random(), 0, 4));
+ if (statspec != NULL) {
+ uint16 callback = GetStationCallback(CBID_STATION_TILE_LAYOUT, 0, 0, statspec, st, tile);
+ if (callback != CALLBACK_FAILED && callback < 8) SetStationGfx(tile, callback);
+ }
+
tile += tile_delta;
} while (--w);
SetSignalsOnBothDir(tile_org, track);
@@ -1992,8 +2013,15 @@ static void DrawTile_Station(TileInfo *ti)
relocation = GetCustomStationRelocation(statspec, st, ti->tile);
+ if (HASBIT(statspec->callbackmask, CBM_CUSTOM_LAYOUT)) {
+ uint16 callback = GetStationCallback(CBID_STATION_SPRITE_LAYOUT, 0, 0, statspec, st, ti->tile);
+ if (callback != CALLBACK_FAILED) tile = callback + GetRailStationAxis(ti->tile);
+ }
+
/* Ensure the chosen tile layout is valid for this custom station */
- t = &statspec->renderdata[tile < statspec->tiles ? tile : GetRailStationAxis(ti->tile)];
+ if (statspec->renderdata != NULL) {
+ t = &statspec->renderdata[tile < statspec->tiles ? tile : GetRailStationAxis(ti->tile)];
+ }
}
}