OpenTTD Source 20260129-master-g2bb01bd0e4
tile_cmd.h
Go to the documentation of this file.
1/*
2 * This file is part of OpenTTD.
3 * OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
4 * OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
5 * See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <https://www.gnu.org/licenses/old-licenses/gpl-2.0>.
6 */
7
10#ifndef TILE_CMD_H
11#define TILE_CMD_H
12
13#include "core/enum_type.hpp"
15#include "command_type.h"
16#include "vehicle_type.h"
17#include "cargo_type.h"
18#include "track_type.h"
19#include "tile_map.h"
21
23enum class VehicleEnterTileState : uint8_t {
27};
28
30
36
38struct TileDesc {
40 uint64_t dparam = 0;
41 std::array<Owner, 4> owner{};
42 std::array<StringID, 4> owner_type{};
49 std::optional<std::string> grf = std::nullopt;
51 uint16_t rail_speed = 0;
53 uint16_t road_speed = 0;
55 uint16_t tram_speed = 0;
56 std::optional<bool> town_can_upgrade = std::nullopt;
57};
58
63typedef void DrawTileProc(TileInfo *ti);
64
76typedef int GetSlopeZProc(TileIndex tile, uint x, uint y, bool ground_vehicle);
77typedef CommandCost ClearTileProc(TileIndex tile, DoCommandFlags flags);
78
85typedef void AddAcceptedCargoProc(TileIndex tile, CargoArray &acceptance, CargoTypes &always_accepted);
86
92typedef void GetTileDescProc(TileIndex tile, TileDesc &td);
93
107typedef TrackStatus GetTileTrackStatusProc(TileIndex tile, TransportType mode, uint sub_mode, DiagDirection side);
108
114typedef void AddProducedCargoProc(TileIndex tile, CargoArray &produced);
115typedef bool ClickTileProc(TileIndex tile);
116typedef void AnimateTileProc(TileIndex tile);
117typedef void TileLoopProc(TileIndex tile);
118typedef void ChangeTileOwnerProc(TileIndex tile, Owner old_owner, Owner new_owner);
119
120typedef VehicleEnterTileStates VehicleEnterTileProc(Vehicle *v, TileIndex tile, int x, int y);
121typedef Foundation GetFoundationProc(TileIndex tile, Slope tileh);
122
138typedef CommandCost TerraformTileProc(TileIndex tile, DoCommandFlags flags, int z_new, Slope tileh_new);
139
148using CheckBuildAboveProc = CommandCost(TileIndex tile, DoCommandFlags flags, Axis axis, int height);
149
156 GetSlopeZProc *get_slope_z_proc;
157 ClearTileProc *clear_tile_proc;
161 ClickTileProc *click_tile_proc;
162 AnimateTileProc *animate_tile_proc;
163 TileLoopProc *tile_loop_proc;
164 ChangeTileOwnerProc *change_tile_owner_proc;
166 VehicleEnterTileProc *vehicle_enter_tile_proc;
167 GetFoundationProc *get_foundation_proc;
169 CheckBuildAboveProc *check_build_above_proc;
170};
171
173
174TrackStatus GetTileTrackStatus(TileIndex tile, TransportType mode, uint sub_mode, DiagDirection side = INVALID_DIAGDIR);
176void ChangeTileOwner(TileIndex tile, Owner old_owner, Owner new_owner);
177void GetTileDesc(TileIndex tile, TileDesc &td);
178
179inline void AddAcceptedCargo(TileIndex tile, CargoArray &acceptance, CargoTypes *always_accepted)
180{
181 AddAcceptedCargoProc *proc = _tile_type_procs[GetTileType(tile)]->add_accepted_cargo_proc;
182 if (proc == nullptr) return;
183 CargoTypes dummy = 0; // use dummy bitmask so there don't need to be several 'always_accepted != nullptr' checks
184 proc(tile, acceptance, always_accepted == nullptr ? dummy : *always_accepted);
185}
186
187inline void AddProducedCargo(TileIndex tile, CargoArray &produced)
188{
189 AddProducedCargoProc *proc = _tile_type_procs[GetTileType(tile)]->add_produced_cargo_proc;
190 if (proc == nullptr) return;
191 proc(tile, produced);
192}
193
199inline bool MayAnimateTile(TileIndex tile)
200{
201 return _tile_type_procs[GetTileType(tile)]->animate_tile_proc != nullptr;
202}
203
204inline void AnimateTile(TileIndex tile)
205{
206 AnimateTileProc *proc = _tile_type_procs[GetTileType(tile)]->animate_tile_proc;
207 assert(proc != nullptr);
208 proc(tile);
209}
210
211inline bool ClickTile(TileIndex tile)
212{
213 ClickTileProc *proc = _tile_type_procs[GetTileType(tile)]->click_tile_proc;
214 if (proc == nullptr) return false;
215 return proc(tile);
216}
217
218#endif /* TILE_CMD_H */
Types related to cargoes...
Common return value for all commands.
Enum-as-bit-set wrapper.
A sort-of mixin that implements 'at(pos)' and 'operator[](pos)' only for a specific enum class.
static constexpr TimerGame< struct Calendar >::Date INVALID_DATE
Representation of an invalid date.
Types related to commands.
Axis
Allow incrementing of DiagDirDiff variables.
DiagDirection
Enumeration for diagonal directions.
@ INVALID_DIAGDIR
Flag for an invalid DiagDirection.
Type (helpers) for enums.
constexpr std::underlying_type_t< enum_type > to_underlying(enum_type e)
Implementation of std::to_underlying (from C++23)
Definition enum_type.hpp:17
All geometry types in OpenTTD.
Slope
Enumeration for the slope-type.
Definition slope_type.h:47
Foundation
Enumeration for Foundations.
Definition slope_type.h:92
uint32_t StringID
Numeric value that represents a string, independent of the selected language.
Class for storing amounts of cargo.
Definition cargo_type.h:111
A coordinate with three dimensions.
Tile description for the 'land area information' tool.
Definition tile_cmd.h:38
uint16_t rail_speed
Speed limit of rail (bridges and track)
Definition tile_cmd.h:51
std::optional< std::string > grf
newGRF used for the tile contents
Definition tile_cmd.h:49
StringID station_name
Type of station within the class.
Definition tile_cmd.h:45
StringID str
Description of the tile.
Definition tile_cmd.h:39
TimerGameCalendar::Date build_date
Date of construction of tile contents.
Definition tile_cmd.h:43
std::array< Owner, 4 > owner
Name of the owner(s)
Definition tile_cmd.h:41
uint64_t dparam
Parameter of the str string.
Definition tile_cmd.h:40
StringID airport_class
Name of the airport class.
Definition tile_cmd.h:46
StringID airport_name
Name of the airport.
Definition tile_cmd.h:47
uint16_t tram_speed
Speed limit of tram (bridges and track)
Definition tile_cmd.h:55
StringID roadtype
Type of road on the tile.
Definition tile_cmd.h:52
StringID tramtype
Type of tram on the tile.
Definition tile_cmd.h:54
StringID railtype
Type of rail on the tile.
Definition tile_cmd.h:50
uint16_t road_speed
Speed limit of road (bridges and track)
Definition tile_cmd.h:53
std::array< StringID, 4 > owner_type
Type of each owner.
Definition tile_cmd.h:42
std::optional< bool > town_can_upgrade
Whether the town can upgrade this house during town growth.
Definition tile_cmd.h:56
StringID airport_tile_name
Name of the airport tile.
Definition tile_cmd.h:48
StringID station_class
Class of station.
Definition tile_cmd.h:44
Tile information, used while rendering the tile.
Definition tile_cmd.h:32
Slope tileh
Slope of the tile.
Definition tile_cmd.h:33
TileIndex tile
Tile index.
Definition tile_cmd.h:34
Set of callback functions for performing tile operations of a given tile type.
Definition tile_cmd.h:154
VehicleEnterTileProc * vehicle_enter_tile_proc
Called when a vehicle enters a tile.
Definition tile_cmd.h:166
DrawTileProc * draw_tile_proc
Called to render the tile and its contents to the screen.
Definition tile_cmd.h:155
AddAcceptedCargoProc * add_accepted_cargo_proc
Adds accepted cargo of the tile to cargo array supplied as parameter.
Definition tile_cmd.h:158
GetTileDescProc * get_tile_desc_proc
Get a description of a tile (for the 'land area information' tool)
Definition tile_cmd.h:159
TerraformTileProc * terraform_tile_proc
Called when a terraforming operation is about to take place.
Definition tile_cmd.h:168
GetTileTrackStatusProc * get_tile_track_status_proc
Get available tracks and status of a tile.
Definition tile_cmd.h:160
AddProducedCargoProc * add_produced_cargo_proc
Adds produced cargo of the tile to cargo array supplied as parameter.
Definition tile_cmd.h:165
ClickTileProc * click_tile_proc
Called when tile is clicked.
Definition tile_cmd.h:161
Vehicle data structure.
VehicleEnterTileState
Flags to describe several special states upon entering a tile.
Definition tile_cmd.h:23
@ EnteredStation
The vehicle entered a station.
@ CannotEnter
The vehicle cannot enter the tile.
@ EnteredWormhole
The vehicle either entered a bridge, tunnel or depot tile (this includes the last tile of the bridge/...
void AddProducedCargoProc(TileIndex tile, CargoArray &produced)
Tile callback function signature for obtaining the produced cargo of a tile.
Definition tile_cmd.h:114
void DrawTileProc(TileInfo *ti)
Tile callback function signature for drawing a tile and its contents to the screen.
Definition tile_cmd.h:63
VehicleEnterTileStates VehicleEnterTile(Vehicle *v, TileIndex tile, int x, int y)
Call the tile callback function for a vehicle entering a tile.
Definition vehicle.cpp:1831
const EnumClassIndexContainer< std::array< const TileTypeProcs *, to_underlying(TileType::MaxSize)>, TileType > _tile_type_procs
Tile callback functions for each type of tile.
Definition landscape.cpp:69
void ChangeTileOwner(TileIndex tile, Owner old_owner, Owner new_owner)
Change the owner of a tile.
void AddAcceptedCargoProc(TileIndex tile, CargoArray &acceptance, CargoTypes &always_accepted)
Tile callback function signature for obtaining cargo acceptance of a tile.
Definition tile_cmd.h:85
int GetSlopeZProc(TileIndex tile, uint x, uint y, bool ground_vehicle)
Tile callback function signature for obtaining the world Z coordinate of a given point of a tile.
Definition tile_cmd.h:76
TrackStatus GetTileTrackStatusProc(TileIndex tile, TransportType mode, uint sub_mode, DiagDirection side)
Tile callback function signature for getting the possible tracks that can be taken on a given tile by...
Definition tile_cmd.h:107
CommandCost(TileIndex tile, DoCommandFlags flags, Axis axis, int height) CheckBuildAboveProc
Tile callback function signature to test if a bridge can be built above a tile.
Definition tile_cmd.h:148
CommandCost TerraformTileProc(TileIndex tile, DoCommandFlags flags, int z_new, Slope tileh_new)
Tile callback function signature of the terraforming callback.
Definition tile_cmd.h:138
void GetTileDescProc(TileIndex tile, TileDesc &td)
Tile callback function signature for obtaining a tile description.
Definition tile_cmd.h:92
bool MayAnimateTile(TileIndex tile)
Test if a tile may be animated.
Definition tile_cmd.h:199
TrackStatus GetTileTrackStatus(TileIndex tile, TransportType mode, uint sub_mode, DiagDirection side=INVALID_DIAGDIR)
Returns information about trackdirs and signal states.
Map writing/reading functions for tiles.
static TileType GetTileType(Tile tile)
Get the tiletype of a given tile.
Definition tile_map.h:96
TileType
The different types of tiles.
Definition tile_type.h:48
@ MaxSize
The maximum possible number of tile types to be stored in map.
Definition of the game-calendar-timer.
All types related to tracks.
TransportType
Available types of transport.
Types related to vehicles.