OpenTTD Source 20241224-master-gf74b0cf984
newgrf.cpp File Reference

Base of all NewGRF support. More...

#include "stdafx.h"
#include "core/backup_type.hpp"
#include "core/container_func.hpp"
#include "debug.h"
#include "fileio_func.h"
#include "engine_func.h"
#include "engine_base.h"
#include "bridge.h"
#include "town.h"
#include "newgrf_engine.h"
#include "newgrf_text.h"
#include "fontcache.h"
#include "currency.h"
#include "landscape.h"
#include "newgrf_cargo.h"
#include "newgrf_house.h"
#include "newgrf_sound.h"
#include "newgrf_station.h"
#include "industrytype.h"
#include "industry_map.h"
#include "newgrf_act5.h"
#include "newgrf_canal.h"
#include "newgrf_townname.h"
#include "newgrf_industries.h"
#include "newgrf_airporttiles.h"
#include "newgrf_airport.h"
#include "newgrf_object.h"
#include "rev.h"
#include "fios.h"
#include "strings_func.h"
#include "timer/timer_game_tick.h"
#include "timer/timer_game_calendar.h"
#include "string_func.h"
#include "network/core/config.h"
#include "smallmap_gui.h"
#include "genworld.h"
#include "error.h"
#include "error_func.h"
#include "vehicle_func.h"
#include "language.h"
#include "vehicle_base.h"
#include "road.h"
#include "newgrf_roadstop.h"
#include "table/strings.h"
#include "table/build_industry.h"
#include "safeguards.h"

Go to the source code of this file.

Data Structures

struct  GrfProcessingState
 Temporary data during loading of GRFs. More...
 
struct  GrfProcessingState::SpriteSet
 Definition of a single Action1 spriteset. More...
 
class  OTTDByteReaderSignal
 
class  ByteReader
 Class to read from a NewGRF file. More...
 
struct  GRFTempEngineData
 Temporary engine data used when loading only. More...
 
struct  GRFLocation
 
struct  StringIDMapping
 Information for mapping static StringIDs. More...
 
struct  AllowedSubtags
 Data structure to store the allowed id/type combinations for action 14. More...
 

Macros

#define TEXTID_TO_STRINGID(begin, end, stringid, stringend)
 

Typedefs

typedef void(* SpecialSpriteHandler) (ByteReader &buf)
 
typedef std::map< GRFLocation, std::vector< uint8_t > > GRFLineToSpriteOverride
 
typedef ChangeInfoResult(* VCI_Handler) (uint engine, int numinfo, int prop, ByteReader &buf)
 
using CachedCallback = std::pair< uint16_t, SpriteGroupID >
 
typedef bool(* DataHandler) (size_t, ByteReader &)
 Type of callback function for binary nodes.
 
typedef bool(* TextHandler) (uint8_t, std::string_view str)
 Type of callback function for text nodes.
 
typedef bool(* BranchHandler) (ByteReader &)
 Type of callback function for branch nodes.
 

Enumerations

enum  ChangeInfoResult {
  CIR_SUCCESS , CIR_DISABLED , CIR_UNHANDLED , CIR_UNKNOWN ,
  CIR_INVALID_ID
}
 Possible return values for the FeatureChangeInfo functions. More...
 

Functions

const std::vector< GRFFile * > & GetAllGRFFiles ()
 
template<VehicleType T>
static bool IsValidNewGRFImageIndex (uint8_t image_index)
 Helper to check whether an image index is valid for a particular NewGRF vehicle.
 
void GrfMsgI (int severity, const std::string &msg)
 Debug() function dedicated to newGRF debugging messages Function is essentially the same as Debug(grf, severity, ...) with the addition of file:line information when parsing grf files.
 
static GRFFileGetFileByGRFID (uint32_t grfid)
 Obtain a NewGRF file by its grfID.
 
static GRFFileGetFileByFilename (const std::string &filename)
 Obtain a NewGRF file by its filename.
 
static void ClearTemporaryNewGRFData (GRFFile *gf)
 Reset all NewGRFData that was used only while processing data.
 
static GRFErrorDisableGrf (StringID message=STR_NULL, GRFConfig *config=nullptr)
 Disable a GRF.
 
static void AddStringForMapping (StringID source, std::function< void(StringID)> &&func)
 Record a static StringID for getting translated later.
 
static void AddStringForMapping (StringID source, StringID *target)
 Record a static StringID for getting translated later.
 
static StringID TTDPStringIDToOTTDStringIDMapping (StringID str)
 Perform a mapping from TTDPatch's string IDs to OpenTTD's string IDs, but only for the ones we are aware off; the rest like likely unused and will show a warning.
 
StringID MapGRFStringID (uint32_t grfid, StringID str)
 Used when setting an object's property to map to the GRF's strings while taking in consideration the "drift" between TTDPatch string system and OpenTTD's one.
 
static void SetNewGRFOverride (uint32_t source_grfid, uint32_t target_grfid)
 Set the override for a NewGRF.
 
static GRFFileGetCurrentGRFOverride ()
 Get overridden GRF for current GRF if present.
 
static EngineGetNewEngine (const GRFFile *file, VehicleType type, uint16_t internal_id, bool static_access=false)
 Returns the engine associated to a certain internal_id, resp.
 
EngineID GetNewEngineID (const GRFFile *file, VehicleType type, uint16_t internal_id)
 Return the ID of a new engine.
 
static void MapSpriteMappingRecolour (PalSpriteID *grf_sprite)
 Map the colour modifiers of TTDPatch to those that Open is using.
 
static TileLayoutFlags ReadSpriteLayoutSprite (ByteReader &buf, bool read_flags, bool invert_action1_flag, bool use_cur_spritesets, int feature, PalSpriteID *grf_sprite, uint16_t *max_sprite_offset=nullptr, uint16_t *max_palette_offset=nullptr)
 Read a sprite and a palette from the GRF and convert them into a format suitable to OpenTTD.
 
static void ReadSpriteLayoutRegisters (ByteReader &buf, TileLayoutFlags flags, bool is_parent, NewGRFSpriteLayout *dts, uint index)
 Preprocess the TileLayoutFlags and read register modifiers from the GRF.
 
static bool ReadSpriteLayout (ByteReader &buf, uint num_building_sprites, bool use_cur_spritesets, uint8_t feature, bool allow_var10, bool no_z_position, NewGRFSpriteLayout *dts)
 Read a spritelayout from the GRF.
 
static CargoTypes TranslateRefitMask (uint32_t refit_mask)
 Translate the refit mask.
 
static void ConvertTTDBasePrice (uint32_t base_pointer, const char *error_location, Price *index)
 Converts TTD(P) Base Price pointers into the enum used by OTTD See http://wiki.ttdpatch.net/tiki-index.php?page=BaseCosts.
 
static ChangeInfoResult CommonVehicleChangeInfo (EngineInfo *ei, int prop, ByteReader &buf)
 Define properties common to all vehicles.
 
static ChangeInfoResult RailVehicleChangeInfo (uint engine, int numinfo, int prop, ByteReader &buf)
 Define properties for rail vehicles.
 
static ChangeInfoResult RoadVehicleChangeInfo (uint engine, int numinfo, int prop, ByteReader &buf)
 Define properties for road vehicles.
 
static ChangeInfoResult ShipVehicleChangeInfo (uint engine, int numinfo, int prop, ByteReader &buf)
 Define properties for ships.
 
static ChangeInfoResult AircraftVehicleChangeInfo (uint engine, int numinfo, int prop, ByteReader &buf)
 Define properties for aircraft.
 
static ChangeInfoResult StationChangeInfo (uint stid, int numinfo, int prop, ByteReader &buf)
 Define properties for stations.
 
static ChangeInfoResult CanalChangeInfo (uint id, int numinfo, int prop, ByteReader &buf)
 Define properties for water features.
 
static ChangeInfoResult BridgeChangeInfo (uint brid, int numinfo, int prop, ByteReader &buf)
 Define properties for bridges.
 
static ChangeInfoResult IgnoreTownHouseProperty (int prop, ByteReader &buf)
 Ignore a house property.
 
static ChangeInfoResult TownHouseChangeInfo (uint hid, int numinfo, int prop, ByteReader &buf)
 Define properties for houses.
 
template<typename T , typename TGetTableFunc >
static ChangeInfoResult LoadTranslationTable (uint gvid, int numinfo, ByteReader &buf, TGetTableFunc gettable, std::string_view name)
 Load a cargo- or railtype-translation table.
 
static std::string ReadDWordAsString (ByteReader &reader)
 Helper to read a DWord worth of bytes from the reader and to return it as a valid string.
 
static ChangeInfoResult GlobalVarChangeInfo (uint gvid, int numinfo, int prop, ByteReader &buf)
 Define properties for global variables.
 
static ChangeInfoResult GlobalVarReserveInfo (uint gvid, int numinfo, int prop, ByteReader &buf)
 
static ChangeInfoResult CargoChangeInfo (uint cid, int numinfo, int prop, ByteReader &buf)
 Define properties for cargoes.
 
static ChangeInfoResult SoundEffectChangeInfo (uint sid, int numinfo, int prop, ByteReader &buf)
 Define properties for sound effects.
 
static ChangeInfoResult IgnoreIndustryTileProperty (int prop, ByteReader &buf)
 Ignore an industry tile property.
 
static ChangeInfoResult IndustrytilesChangeInfo (uint indtid, int numinfo, int prop, ByteReader &buf)
 Define properties for industry tiles.
 
static ChangeInfoResult IgnoreIndustryProperty (int prop, ByteReader &buf)
 Ignore an industry property.
 
static bool ValidateIndustryLayout (const IndustryTileLayout &layout)
 Validate the industry layout; e.g.
 
static ChangeInfoResult IndustriesChangeInfo (uint indid, int numinfo, int prop, ByteReader &buf)
 Define properties for industries.
 
static ChangeInfoResult AirportChangeInfo (uint airport, int numinfo, int prop, ByteReader &buf)
 Define properties for airports.
 
static ChangeInfoResult IgnoreObjectProperty (uint prop, ByteReader &buf)
 Ignore properties for objects.
 
static ChangeInfoResult ObjectChangeInfo (uint id, int numinfo, int prop, ByteReader &buf)
 Define properties for objects.
 
static ChangeInfoResult RailTypeChangeInfo (uint id, int numinfo, int prop, ByteReader &buf)
 Define properties for railtypes.
 
static ChangeInfoResult RailTypeReserveInfo (uint id, int numinfo, int prop, ByteReader &buf)
 
static ChangeInfoResult RoadTypeChangeInfo (uint id, int numinfo, int prop, ByteReader &buf, RoadTramType rtt)
 Define properties for roadtypes.
 
static ChangeInfoResult RoadTypeChangeInfo (uint id, int numinfo, int prop, ByteReader &buf)
 
static ChangeInfoResult TramTypeChangeInfo (uint id, int numinfo, int prop, ByteReader &buf)
 
static ChangeInfoResult RoadTypeReserveInfo (uint id, int numinfo, int prop, ByteReader &buf, RoadTramType rtt)
 
static ChangeInfoResult RoadTypeReserveInfo (uint id, int numinfo, int prop, ByteReader &buf)
 
static ChangeInfoResult TramTypeReserveInfo (uint id, int numinfo, int prop, ByteReader &buf)
 
static ChangeInfoResult AirportTilesChangeInfo (uint airtid, int numinfo, int prop, ByteReader &buf)
 
static ChangeInfoResult IgnoreRoadStopProperty (uint prop, ByteReader &buf)
 Ignore properties for roadstops.
 
static ChangeInfoResult RoadStopChangeInfo (uint id, int numinfo, int prop, ByteReader &buf)
 
static bool HandleChangeInfoResult (const char *caller, ChangeInfoResult cir, uint8_t feature, uint8_t property)
 
static void FeatureChangeInfo (ByteReader &buf)
 
static void SafeChangeInfo (ByteReader &buf)
 
static void ReserveChangeInfo (ByteReader &buf)
 
static void NewSpriteSet (ByteReader &buf)
 
static void SkipAct1 (ByteReader &buf)
 
static const SpriteGroupGetCallbackResultGroup (uint16_t value)
 
static const SpriteGroupGetGroupFromGroupID (uint8_t setid, uint8_t type, uint16_t groupid)
 
static const SpriteGroupCreateGroupFromGroupID (uint8_t feature, uint8_t setid, uint8_t type, uint16_t spriteid)
 Helper function to either create a callback or a result sprite group.
 
static void NewSpriteGroup (ByteReader &buf)
 
std::span< const CargoLabelGetCargoTranslationTable (const GRFFile &grffile)
 Get the cargo translation table to use for the given GRF file.
 
static CargoID TranslateCargo (uint8_t feature, uint8_t ctype)
 
static bool IsValidGroupID (uint16_t groupid, const char *function)
 
static void VehicleMapSpriteGroup (ByteReader &buf, uint8_t feature, uint8_t idcount)
 
static void CanalMapSpriteGroup (ByteReader &buf, uint8_t idcount)
 
static void StationMapSpriteGroup (ByteReader &buf, uint8_t idcount)
 
static void TownHouseMapSpriteGroup (ByteReader &buf, uint8_t idcount)
 
static void IndustryMapSpriteGroup (ByteReader &buf, uint8_t idcount)
 
static void IndustrytileMapSpriteGroup (ByteReader &buf, uint8_t idcount)
 
static void CargoMapSpriteGroup (ByteReader &buf, uint8_t idcount)
 
static void ObjectMapSpriteGroup (ByteReader &buf, uint8_t idcount)
 
static void RailTypeMapSpriteGroup (ByteReader &buf, uint8_t idcount)
 
static void RoadTypeMapSpriteGroup (ByteReader &buf, uint8_t idcount, RoadTramType rtt)
 
static void AirportMapSpriteGroup (ByteReader &buf, uint8_t idcount)
 
static void AirportTileMapSpriteGroup (ByteReader &buf, uint8_t idcount)
 
static void RoadStopMapSpriteGroup (ByteReader &buf, uint8_t idcount)
 
static void FeatureMapSpriteGroup (ByteReader &buf)
 
static void FeatureNewName (ByteReader &buf)
 
static uint16_t SanitizeSpriteOffset (uint16_t &num, uint16_t offset, int max_sprites, const std::string_view name)
 Sanitize incoming sprite offsets for Action 5 graphics replacements.
 
std::span< const Action5TypeGetAction5Types ()
 Get list of all action 5 types.
 
static void GraphicsNew (ByteReader &buf)
 
static void SkipAct5 (ByteReader &buf)
 
bool GetGlobalVariable (uint8_t param, uint32_t *value, const GRFFile *grffile)
 Reads a variable common to VarAction2 and Action7/9/D.
 
static uint32_t GetParamVal (uint8_t param, uint32_t *cond_val)
 
static void CfgApply (ByteReader &buf)
 
static void DisableStaticNewGRFInfluencingNonStaticNewGRFs (GRFConfig *c)
 Disable a static NewGRF when it is influencing another (non-static) NewGRF as this could cause desyncs.
 
static void SkipIf (ByteReader &buf)
 
static void ScanInfo (ByteReader &buf)
 
static void GRFInfo (ByteReader &buf)
 
static bool IsGRMReservedSprite (SpriteID first_sprite, uint16_t num_sprites)
 Check if a sprite ID range is within the GRM reversed range for the currently loading NewGRF.
 
static void SpriteReplace (ByteReader &buf)
 
static void SkipActA (ByteReader &buf)
 
static void GRFLoadError (ByteReader &buf)
 
static void GRFComment (ByteReader &buf)
 
static void SafeParamSet (ByteReader &buf)
 
static uint32_t GetPatchVariable (uint8_t param)
 
static uint32_t PerformGRM (uint32_t *grm, uint16_t num_ids, uint16_t count, uint8_t op, uint8_t target, const char *type)
 
static void ParamSet (ByteReader &buf)
 Action 0x0D: Set parameter.
 
static void SafeGRFInhibit (ByteReader &buf)
 
static void GRFInhibit (ByteReader &buf)
 
static void FeatureTownName (ByteReader &buf)
 Action 0x0F - Define Town names.
 
static void DefineGotoLabel (ByteReader &buf)
 Action 0x10 - Define goto label.
 
static void ImportGRFSound (SoundEntry *sound)
 Process a sound import from another GRF file.
 
static void LoadGRFSound (size_t offs, SoundEntry *sound)
 Load a sound from a file.
 
static void GRFSound (ByteReader &buf)
 
static void SkipAct11 (ByteReader &buf)
 
static void LoadFontGlyph (ByteReader &buf)
 Action 0x12.
 
static void SkipAct12 (ByteReader &buf)
 Action 0x12 (SKIP)
 
static void TranslateGRFStrings (ByteReader &buf)
 Action 0x13.
 
static bool ChangeGRFName (uint8_t langid, std::string_view str)
 Callback function for 'INFO'->'NAME' to add a translation to the newgrf name.
 
static bool ChangeGRFDescription (uint8_t langid, std::string_view str)
 Callback function for 'INFO'->'DESC' to add a translation to the newgrf description.
 
static bool ChangeGRFURL (uint8_t langid, std::string_view str)
 Callback function for 'INFO'->'URL_' to set the newgrf url.
 
static bool ChangeGRFNumUsedParams (size_t len, ByteReader &buf)
 Callback function for 'INFO'->'NPAR' to set the number of valid parameters.
 
static bool ChangeGRFPalette (size_t len, ByteReader &buf)
 Callback function for 'INFO'->'PALS' to set the number of valid parameters.
 
static bool ChangeGRFBlitter (size_t len, ByteReader &buf)
 Callback function for 'INFO'->'BLTR' to set the blitter info.
 
static bool ChangeGRFVersion (size_t len, ByteReader &buf)
 Callback function for 'INFO'->'VRSN' to the version of the NewGRF.
 
static bool ChangeGRFMinVersion (size_t len, ByteReader &buf)
 Callback function for 'INFO'->'MINV' to the minimum compatible version of the NewGRF.
 
static bool ChangeGRFParamName (uint8_t langid, std::string_view str)
 Callback function for 'INFO'->'PARAM'->param_num->'NAME' to set the name of a parameter.
 
static bool ChangeGRFParamDescription (uint8_t langid, std::string_view str)
 Callback function for 'INFO'->'PARAM'->param_num->'DESC' to set the description of a parameter.
 
static bool ChangeGRFParamType (size_t len, ByteReader &buf)
 Callback function for 'INFO'->'PARAM'->param_num->'TYPE' to set the typeof a parameter.
 
static bool ChangeGRFParamLimits (size_t len, ByteReader &buf)
 Callback function for 'INFO'->'PARAM'->param_num->'LIMI' to set the min/max value of a parameter.
 
static bool ChangeGRFParamMask (size_t len, ByteReader &buf)
 Callback function for 'INFO'->'PARAM'->param_num->'MASK' to set the parameter and bits to use.
 
static bool ChangeGRFParamDefault (size_t len, ByteReader &buf)
 Callback function for 'INFO'->'PARAM'->param_num->'DFLT' to set the default value.
 
static bool SkipUnknownInfo (ByteReader &buf, uint8_t type)
 Try to skip the current node and all subnodes (if it's a branch node).
 
static bool HandleNodes (ByteReader &buf, AllowedSubtags *tags)
 
static bool ChangeGRFParamValueNames (ByteReader &buf)
 Callback function for 'INFO'->'PARA'->param_num->'VALU' to set the names of some parameter values (type uint/enum) or the names of some bits (type bitmask).
 
static bool HandleParameterInfo (ByteReader &buf)
 Callback function for 'INFO'->'PARA' to set extra information about the parameters.
 
static bool HandleNode (uint8_t type, uint32_t id, ByteReader &buf, AllowedSubtags subtags[])
 Handle the nodes of an Action14.
 
static bool HandleNodes (ByteReader &buf, AllowedSubtags subtags[])
 Handle the contents of a 'C' choice of an Action14.
 
static void StaticGRFInfo (ByteReader &buf)
 Handle Action 0x14.
 
static void GRFUnsafe (ByteReader &)
 Set the current NewGRF as unsafe for static use.
 
static void InitializeGRFSpecial ()
 Initialize the TTDPatch flags.
 
static void ResetCustomStations ()
 Reset and clear all NewGRF stations.
 
static void ResetCustomHouses ()
 Reset and clear all NewGRF houses.
 
static void ResetCustomAirports ()
 Reset and clear all NewGRF airports.
 
static void ResetCustomIndustries ()
 Reset and clear all NewGRF industries.
 
static void ResetCustomObjects ()
 Reset and clear all NewObjects.
 
static void ResetCustomRoadStops ()
 
static void ResetNewGRF ()
 Reset and clear all NewGRFs.
 
static void ResetNewGRFErrors ()
 Clear all NewGRF errors.
 
void ResetNewGRFData ()
 Reset all NewGRF loaded data.
 
void ResetPersistentNewGRFData ()
 Reset NewGRF data which is stored persistently in savegames.
 
static void BuildCargoTranslationMap ()
 Construct the Cargo Mapping.
 
static void InitNewGRFFile (const GRFConfig *config)
 Prepare loading a NewGRF file with its config.
 
static CargoLabel GetActiveCargoLabel (const std::initializer_list< CargoLabel > &labels)
 Find first cargo label that exists and is active from a list of cargo labels.
 
static CargoLabel GetActiveCargoLabel (const std::variant< CargoLabel, MixedCargoType > &label)
 Get active cargo label from either a cargo label or climate-dependent mixed cargo type.
 
static void CalculateRefitMasks ()
 Precalculate refit masks from cargo classes for all vehicles.
 
static void FinaliseCanals ()
 Set to use the correct action0 properties for each canal feature.
 
static void FinaliseEngineArray ()
 Check for invalid engines.
 
void FinaliseCargoArray ()
 Check for invalid cargoes.
 
static bool IsHouseSpecValid (HouseSpec *hs, const HouseSpec *next1, const HouseSpec *next2, const HouseSpec *next3, const std::string &filename)
 Check if a given housespec is valid and disable it if it's not.
 
static void EnsureEarlyHouse (HouseZones bitmask)
 Make sure there is at least one house available in the year 0 for the given climate / housezone combination.
 
static void FinaliseHouseArray ()
 Add all new houses to the house array.
 
static void FinaliseIndustriesArray ()
 Add all new industries to the industry array.
 
static void FinaliseObjectsArray ()
 Add all new objects to the object array.
 
static void FinaliseAirportsArray ()
 Add all new airports to the airport array.
 
static void DecodeSpecialSprite (uint8_t *buf, uint num, GrfLoadingStage stage)
 
static void LoadNewGRFFileFromFile (GRFConfig *config, GrfLoadingStage stage, SpriteFile &file)
 Load a particular NewGRF from a SpriteFile.
 
void LoadNewGRFFile (GRFConfig *config, GrfLoadingStage stage, Subdirectory subdir, bool temporary)
 Load a particular NewGRF.
 
static void ActivateOldShore ()
 Relocates the old shore sprites at new positions.
 
static void ActivateOldTramDepot ()
 Replocate the old tram depot sprites to the new position, if no new ones were loaded.
 
static void FinalisePriceBaseMultipliers ()
 Decide whether price base multipliers of grfs shall apply globally or only to the grf specifying them.
 
void InitGRFTownGeneratorNames ()
 Allocate memory for the NewGRF town names.
 
static void AfterLoadGRFs ()
 Finish loading NewGRFs and execute needed post-processing.
 
void LoadNewGRF (SpriteID load_index, uint num_baseset)
 Load all the NewGRFs.
 

Variables

static std::vector< GRFFile * > _grf_files
 List of all loaded GRF files.
 
uint8_t _misc_grf_features = 0
 Miscellaneous GRF features, set by Action 0x0D, parameter 0x9E.
 
static uint32_t _ttdpatch_flags [8]
 32 * 8 = 256 flags.
 
GRFLoadedFeatures _loaded_newgrf_features
 Indicates which are the newgrf features currently loaded ingame.
 
static const uint MAX_SPRITEGROUP = UINT8_MAX
 Maximum GRF-local ID for a spritegroup.
 
static GrfProcessingState _cur
 
static const uint NUM_STATIONS_PER_GRF = UINT16_MAX - 1
 The maximum amount of stations a single GRF is allowed to add.
 
static std::vector< GRFTempEngineData_gted
 Temporary engine data used during NewGRF loading.
 
static uint32_t _grm_engines [256]
 Contains the GRF ID of the owner of a vehicle if it has been reserved.
 
static uint32_t _grm_cargoes [NUM_CARGO *2]
 Contains the GRF ID of the owner of a cargo if it has been reserved.
 
static std::map< GRFLocation, std::pair< SpriteID, uint16_t > > _grm_sprites
 
static GRFLineToSpriteOverride _grf_line_to_action6_sprite_override
 
static std::vector< StringIDMapping_string_to_grf_mapping
 Strings to be mapped during load.
 
static std::map< uint32_t, uint32_t > _grf_id_overrides
 
static std::vector< CachedCallback > _cached_callback_groups
 Sorted list of cached callback result spritegroups.
 
static constexpr auto _action5_types
 The information about action 5 types.
 
static GRFParameterInfo_cur_parameter
 The parameter which info is currently changed by the newgrf.
 
AllowedSubtags _tags_parameters []
 Action14 parameter tags.
 
AllowedSubtags _tags_info []
 Action14 tags for the INFO node.
 
AllowedSubtags _tags_root []
 Action14 root tags.
 

Detailed Description

Base of all NewGRF support.

Definition in file newgrf.cpp.

Macro Definition Documentation

◆ TEXTID_TO_STRINGID

#define TEXTID_TO_STRINGID (   begin,
  end,
  stringid,
  stringend 
)
Value:
static_assert(stringend - stringid == end - begin); \
if (str >= begin && str <= end) return str + (stringid - begin)

Typedef Documentation

◆ BranchHandler

typedef bool(* BranchHandler) (ByteReader &)

Type of callback function for branch nodes.

Definition at line 8365 of file newgrf.cpp.

◆ CachedCallback

using CachedCallback = std::pair<uint16_t, SpriteGroupID>

Definition at line 5155 of file newgrf.cpp.

◆ DataHandler

typedef bool(* DataHandler) (size_t, ByteReader &)

Type of callback function for binary nodes.

Definition at line 8363 of file newgrf.cpp.

◆ GRFLineToSpriteOverride

typedef std::map<GRFLocation, std::vector<uint8_t> > GRFLineToSpriteOverride

Definition at line 377 of file newgrf.cpp.

◆ SpecialSpriteHandler

typedef void(* SpecialSpriteHandler) (ByteReader &buf)

Definition at line 309 of file newgrf.cpp.

◆ TextHandler

typedef bool(* TextHandler) (uint8_t, std::string_view str)

Type of callback function for text nodes.

Definition at line 8364 of file newgrf.cpp.

◆ VCI_Handler

typedef ChangeInfoResult(* VCI_Handler) (uint engine, int numinfo, int prop, ByteReader &buf)

Definition at line 1008 of file newgrf.cpp.

Enumeration Type Documentation

◆ ChangeInfoResult

Possible return values for the FeatureChangeInfo functions.

Enumerator
CIR_SUCCESS 

Variable was parsed and read.

CIR_DISABLED 

GRF was disabled due to error.

CIR_UNHANDLED 

Variable was parsed but unread.

CIR_UNKNOWN 

Variable is unknown.

CIR_INVALID_ID 

Attempt to modify an invalid ID.

Definition at line 1000 of file newgrf.cpp.

Function Documentation

◆ ActivateOldShore()

static void ActivateOldShore ( )
static

Relocates the old shore sprites at new positions.

  1. If shore sprites are neither loaded by Action5 nor ActionA, the extra sprites from openttd(w/d).grf are used. (SHORE_REPLACE_ONLY_NEW)
  2. If a newgrf replaces some shore sprites by ActionA. The (maybe also replaced) grass tiles are used for corner shores. (SHORE_REPLACE_ACTION_A)
  3. If a newgrf replaces shore sprites by Action5 any shore replacement by ActionA has no effect. (SHORE_REPLACE_ACTION_5)

Definition at line 9826 of file newgrf.cpp.

References _loaded_newgrf_features, GRFLoadedFeatures::shore, SHORE_REPLACE_ACTION_5, SHORE_REPLACE_ACTION_A, SHORE_REPLACE_NONE, and SPR_SHORE_BASE.

Referenced by AfterLoadGRFs().

◆ ActivateOldTramDepot()

static void ActivateOldTramDepot ( )
static

Replocate the old tram depot sprites to the new position, if no new ones were loaded.

Definition at line 9863 of file newgrf.cpp.

References _loaded_newgrf_features, GRFLoadedFeatures::tram, and TRAMWAY_REPLACE_DEPOT_WITH_TRACK.

Referenced by AfterLoadGRFs().

◆ AddStringForMapping() [1/2]

static void AddStringForMapping ( StringID  source,
std::function< void(StringID)> &&  func 
)
static

Record a static StringID for getting translated later.

Parameters
sourceSource StringID (GRF local).
funcFunction to call to set the mapping result.

Definition at line 473 of file newgrf.cpp.

References _string_to_grf_mapping, and GrfProcessingState::grffile.

Referenced by AddStringForMapping(), AirportChangeInfo(), CargoChangeInfo(), IndustriesChangeInfo(), ObjectChangeInfo(), RailTypeChangeInfo(), RoadTypeChangeInfo(), StationChangeInfo(), and TownHouseChangeInfo().

◆ AddStringForMapping() [2/2]

static void AddStringForMapping ( StringID  source,
StringID target 
)
static

Record a static StringID for getting translated later.

Parameters
sourceSource StringID (GRF local).
targetDestination for the mapping result.

Definition at line 484 of file newgrf.cpp.

References AddStringForMapping().

◆ AfterLoadGRFs()

◆ AircraftVehicleChangeInfo()

◆ AirportChangeInfo()

static ChangeInfoResult AirportChangeInfo ( uint  airport,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Define properties for airports.

Parameters
airportLocal ID of the airport.
numinfoNumber of subsequent airport IDs to change the property for.
propThe property to change.
bufThe property value.
Returns
ChangeInfoResult.

Definition at line 3935 of file newgrf.cpp.

References OverrideManagerBase::Add(), AddStringForMapping(), CIR_INVALID_ID, CIR_SUCCESS, CIR_UNKNOWN, Clamp(), DIR_E, DIR_W, AirportSpec::enabled, GB(), OverrideManagerBase::GetID(), AirportSpec::GetWithoutOverride(), GrfProcessingState::grffile, INVALID_AIRPORTTILE, MAX_CATCHMENT, TimerGameConst< struct Calendar >::MAX_YEAR, NEW_AIRPORT_OFFSET, and NUM_AIRPORTS_PER_GRF.

◆ AirportMapSpriteGroup()

static void AirportMapSpriteGroup ( ByteReader buf,
uint8_t  idcount 
)
static

Definition at line 6058 of file newgrf.cpp.

◆ AirportTileMapSpriteGroup()

static void AirportTileMapSpriteGroup ( ByteReader buf,
uint8_t  idcount 
)
static

Definition at line 6090 of file newgrf.cpp.

◆ AirportTilesChangeInfo()

static ChangeInfoResult AirportTilesChangeInfo ( uint  airtid,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Definition at line 4701 of file newgrf.cpp.

◆ BridgeChangeInfo()

static ChangeInfoResult BridgeChangeInfo ( uint  brid,
int  numinfo,
int  prop,
ByteReader buf 
)
static

◆ BuildCargoTranslationMap()

static void BuildCargoTranslationMap ( )
static

Construct the Cargo Mapping.

Note
This is the reverse of a cargo translation table

Definition at line 8941 of file newgrf.cpp.

References GRFFile::cargo_map, find_index(), GetCargoTranslationTable(), GrfProcessingState::grffile, and CargoSpec::Iterate().

Referenced by LoadNewGRF().

◆ CalculateRefitMasks()

◆ CanalChangeInfo()

static ChangeInfoResult CanalChangeInfo ( uint  id,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Define properties for water features.

Parameters
idType of the first water feature.
numinfoNumber of subsequent water feature ids to change the property for.
propThe property to change.
bufThe property value.
Returns
ChangeInfoResult.

Definition at line 2213 of file newgrf.cpp.

References CanalProperties::callback_mask, GRFFile::canal_local_properties, CIR_INVALID_ID, CIR_SUCCESS, CIR_UNKNOWN, CanalProperties::flags, and GrfProcessingState::grffile.

◆ CanalMapSpriteGroup()

static void CanalMapSpriteGroup ( ByteReader buf,
uint8_t  idcount 
)
static

Definition at line 5724 of file newgrf.cpp.

◆ CargoChangeInfo()

◆ CargoMapSpriteGroup()

static void CargoMapSpriteGroup ( ByteReader buf,
uint8_t  idcount 
)
static

Definition at line 5905 of file newgrf.cpp.

◆ CfgApply()

static void CfgApply ( ByteReader buf)
static

Definition at line 6760 of file newgrf.cpp.

◆ ChangeGRFBlitter()

static bool ChangeGRFBlitter ( size_t  len,
ByteReader buf 
)
static

Callback function for 'INFO'->'BLTR' to set the blitter info.

Definition at line 8220 of file newgrf.cpp.

References GrfProcessingState::grfconfig, GRFP_BLT_32BPP, GRFP_BLT_UNSET, and GRFConfig::palette.

◆ ChangeGRFDescription()

static bool ChangeGRFDescription ( uint8_t  langid,
std::string_view  str 
)
static

Callback function for 'INFO'->'DESC' to add a translation to the newgrf description.

Definition at line 8168 of file newgrf.cpp.

References AddGRFTextToList(), GrfProcessingState::grfconfig, GRFIdentifier::grfid, GRFConfig::ident, and GRFConfig::info.

◆ ChangeGRFMinVersion()

static bool ChangeGRFMinVersion ( size_t  len,
ByteReader buf 
)
static

Callback function for 'INFO'->'MINV' to the minimum compatible version of the NewGRF.

Definition at line 8255 of file newgrf.cpp.

References GrfProcessingState::grfconfig, GRFConfig::min_loadable_version, and GRFConfig::version.

◆ ChangeGRFName()

static bool ChangeGRFName ( uint8_t  langid,
std::string_view  str 
)
static

Callback function for 'INFO'->'NAME' to add a translation to the newgrf name.

Definition at line 8161 of file newgrf.cpp.

References AddGRFTextToList(), GrfProcessingState::grfconfig, GRFIdentifier::grfid, GRFConfig::ident, and GRFConfig::name.

◆ ChangeGRFNumUsedParams()

static bool ChangeGRFNumUsedParams ( size_t  len,
ByteReader buf 
)
static

Callback function for 'INFO'->'NPAR' to set the number of valid parameters.

Definition at line 8182 of file newgrf.cpp.

References GrfProcessingState::grfconfig, and GRFConfig::num_valid_params.

◆ ChangeGRFPalette()

static bool ChangeGRFPalette ( size_t  len,
ByteReader buf 
)
static

Callback function for 'INFO'->'PALS' to set the number of valid parameters.

Definition at line 8194 of file newgrf.cpp.

References GrfProcessingState::grfconfig, GRFP_GRF_ANY, GRFP_GRF_DOS, GRFP_GRF_UNSET, GRFP_GRF_WINDOWS, and GRFConfig::palette.

◆ ChangeGRFParamDefault()

static bool ChangeGRFParamDefault ( size_t  len,
ByteReader buf 
)
static

Callback function for 'INFO'->'PARAM'->param_num->'DFLT' to set the default value.

Definition at line 8351 of file newgrf.cpp.

References _cur_parameter, GRFParameterInfo::def_value, GrfProcessingState::grfconfig, and GRFConfig::has_param_defaults.

◆ ChangeGRFParamDescription()

static bool ChangeGRFParamDescription ( uint8_t  langid,
std::string_view  str 
)
static

Callback function for 'INFO'->'PARAM'->param_num->'DESC' to set the description of a parameter.

Definition at line 8284 of file newgrf.cpp.

References _cur_parameter, AddGRFTextToList(), GRFParameterInfo::desc, GrfProcessingState::grfconfig, GRFIdentifier::grfid, and GRFConfig::ident.

◆ ChangeGRFParamLimits()

static bool ChangeGRFParamLimits ( size_t  len,
ByteReader buf 
)
static

Callback function for 'INFO'->'PARAM'->param_num->'LIMI' to set the min/max value of a parameter.

Definition at line 8308 of file newgrf.cpp.

References _cur_parameter, GRFParameterInfo::max_value, GRFParameterInfo::min_value, PTYPE_UINT_ENUM, and GRFParameterInfo::type.

◆ ChangeGRFParamMask()

static bool ChangeGRFParamMask ( size_t  len,
ByteReader buf 
)
static

Callback function for 'INFO'->'PARAM'->param_num->'MASK' to set the parameter and bits to use.

Definition at line 8330 of file newgrf.cpp.

References _cur_parameter, GRFParameterInfo::first_bit, GRFParameterInfo::num_bit, and GRFParameterInfo::param_nr.

◆ ChangeGRFParamName()

static bool ChangeGRFParamName ( uint8_t  langid,
std::string_view  str 
)
static

Callback function for 'INFO'->'PARAM'->param_num->'NAME' to set the name of a parameter.

Definition at line 8277 of file newgrf.cpp.

References _cur_parameter, AddGRFTextToList(), GrfProcessingState::grfconfig, GRFIdentifier::grfid, GRFConfig::ident, and GRFParameterInfo::name.

◆ ChangeGRFParamType()

static bool ChangeGRFParamType ( size_t  len,
ByteReader buf 
)
static

Callback function for 'INFO'->'PARAM'->param_num->'TYPE' to set the typeof a parameter.

Definition at line 8291 of file newgrf.cpp.

References _cur_parameter, PTYPE_END, and GRFParameterInfo::type.

◆ ChangeGRFParamValueNames()

static bool ChangeGRFParamValueNames ( ByteReader buf)
static

Callback function for 'INFO'->'PARA'->param_num->'VALU' to set the names of some parameter values (type uint/enum) or the names of some bits (type bitmask).

In both cases the format is the same: Each subnode should be a text node with the value/bit number as id.

Definition at line 8455 of file newgrf.cpp.

References _cur_parameter, AddGRFTextToList(), GrfProcessingState::grfconfig, GRFIdentifier::grfid, GRFConfig::ident, GRFParameterInfo::max_value, SkipUnknownInfo(), and GRFParameterInfo::value_names.

◆ ChangeGRFURL()

static bool ChangeGRFURL ( uint8_t  langid,
std::string_view  str 
)
static

Callback function for 'INFO'->'URL_' to set the newgrf url.

Definition at line 8175 of file newgrf.cpp.

References AddGRFTextToList(), GrfProcessingState::grfconfig, GRFIdentifier::grfid, GRFConfig::ident, and GRFConfig::url.

◆ ChangeGRFVersion()

static bool ChangeGRFVersion ( size_t  len,
ByteReader buf 
)
static

Callback function for 'INFO'->'VRSN' to the version of the NewGRF.

Definition at line 8242 of file newgrf.cpp.

References GrfProcessingState::grfconfig, GRFConfig::min_loadable_version, and GRFConfig::version.

◆ ClearTemporaryNewGRFData()

static void ClearTemporaryNewGRFData ( GRFFile gf)
static

Reset all NewGRFData that was used only while processing data.

Definition at line 422 of file newgrf.cpp.

References GRFFile::labels.

Referenced by DisableGrf(), and LoadNewGRF().

◆ CommonVehicleChangeInfo()

static ChangeInfoResult CommonVehicleChangeInfo ( EngineInfo ei,
int  prop,
ByteReader buf 
)
static

Define properties common to all vehicles.

Parameters
eiEngine info.
propThe property to change.
bufThe property value.
Returns
ChangeInfoResult.

Definition at line 1017 of file newgrf.cpp.

References EngineInfo::base_intro, EngineInfo::base_life, CIR_SUCCESS, CIR_UNKNOWN, EngineInfo::climates, TimerGameConst< struct Calendar >::DAYS_TILL_ORIGINAL_BASE_YEAR, EngineInfo::lifelength, and PROP_VEHICLE_LOAD_AMOUNT.

Referenced by AircraftVehicleChangeInfo(), RailVehicleChangeInfo(), RoadVehicleChangeInfo(), and ShipVehicleChangeInfo().

◆ ConvertTTDBasePrice()

static void ConvertTTDBasePrice ( uint32_t  base_pointer,
const char *  error_location,
Price index 
)
static

Converts TTD(P) Base Price pointers into the enum used by OTTD See http://wiki.ttdpatch.net/tiki-index.php?page=BaseCosts.

Parameters
base_pointerTTD(P) Base Price Pointer
error_locationFunction name for grf error messages
[out]indexIf base_pointer is valid, index is assigned to the matching price; else it is left unchanged

< Position of first base price

< Size of each base price record

Definition at line 980 of file newgrf.cpp.

Referenced by RailVehicleChangeInfo(), and RoadVehicleChangeInfo().

◆ CreateGroupFromGroupID()

static const SpriteGroup * CreateGroupFromGroupID ( uint8_t  feature,
uint8_t  setid,
uint8_t  type,
uint16_t  spriteid 
)
static

Helper function to either create a callback or a result sprite group.

Parameters
featureGrfSpecFeature to define spritegroup for.
setidSetID of the currently being parsed Action2. (only for debug output)
typeType of the currently being parsed Action2. (only for debug output)
spriteidRaw value from the GRF for the new spritegroup; describes either the return value or the referenced spritegroup.
Returns
Created spritegroup.

Definition at line 5201 of file newgrf.cpp.

References Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_spritegroup_pool >::CanAllocateItem(), GrfProcessingState::GetNumEnts(), GrfProcessingState::GetSprite(), HasBit(), GrfProcessingState::IsValidSpriteSet(), and GrfProcessingState::spriteid.

◆ DecodeSpecialSprite()

static void DecodeSpecialSprite ( uint8_t *  buf,
uint  num,
GrfLoadingStage  stage 
)
static

Definition at line 9618 of file newgrf.cpp.

◆ DefineGotoLabel()

static void DefineGotoLabel ( ByteReader buf)
static

◆ DisableGrf()

static GRFError * DisableGrf ( StringID  message = STR_NULL,
GRFConfig config = nullptr 
)
static

◆ DisableStaticNewGRFInfluencingNonStaticNewGRFs()

static void DisableStaticNewGRFInfluencingNonStaticNewGRFs ( GRFConfig c)
static

Disable a static NewGRF when it is influencing another (non-static) NewGRF as this could cause desyncs.

We could just tell the NewGRF querying that the file doesn't exist, but that might give unwanted results. Disabling the NewGRF gives the best result as no NewGRF author can complain about that.

Parameters
cThe NewGRF to disable.

Definition at line 6862 of file newgrf.cpp.

References GRFError::data, DisableGrf(), GRFConfig::GetName(), and GrfProcessingState::grfconfig.

Referenced by ParamSet().

◆ EnsureEarlyHouse()

static void EnsureEarlyHouse ( HouseZones  bitmask)
static

Make sure there is at least one house available in the year 0 for the given climate / housezone combination.

Parameters
bitmaskThe climate and housezone to check for. Exactly one climate bit and one housezone bit should be set.

Definition at line 9400 of file newgrf.cpp.

References HouseSpec::building_availability, HouseSpec::enabled, TimerGameConst< struct Calendar >::MAX_YEAR, HouseSpec::min_year, and HouseSpec::Specs().

Referenced by FinaliseHouseArray().

◆ FeatureChangeInfo()

static void FeatureChangeInfo ( ByteReader buf)
static

Definition at line 4943 of file newgrf.cpp.

◆ FeatureMapSpriteGroup()

static void FeatureMapSpriteGroup ( ByteReader buf)
static

Definition at line 6181 of file newgrf.cpp.

◆ FeatureNewName()

static void FeatureNewName ( ByteReader buf)
static

Definition at line 6290 of file newgrf.cpp.

◆ FeatureTownName()

◆ FinaliseAirportsArray()

static void FinaliseAirportsArray ( )
static

Add all new airports to the airport array.

Airport properties can be set at any time in the GRF file, so we can only add a airport spec to the airport array after the file has finished loading.

Definition at line 9595 of file newgrf.cpp.

References _grf_files, and AirportSpec::enabled.

Referenced by AfterLoadGRFs().

◆ FinaliseCanals()

static void FinaliseCanals ( )
static

Set to use the correct action0 properties for each canal feature.

Definition at line 9246 of file newgrf.cpp.

References _water_feature, CanalProperties::callback_mask, WaterFeature::callback_mask, GRFFile::canal_local_properties, CanalProperties::flags, WaterFeature::flags, and WaterFeature::grffile.

Referenced by AfterLoadGRFs().

◆ FinaliseCargoArray()

void FinaliseCargoArray ( )

Check for invalid cargoes.

Definition at line 9324 of file newgrf.cpp.

Referenced by AfterLoadGRFs().

◆ FinaliseEngineArray()

◆ FinaliseHouseArray()

static void FinaliseHouseArray ( )
static

Add all new houses to the house array.

House properties can be set at any time in the GRF file, so we can only add a house spec to the house array after the file has finished loading. We also need to check the dates, due to the TTDPatch behaviour described below that we need to emulate.

Definition at line 9425 of file newgrf.cpp.

References _grf_files, _settings_game, HouseSpec::accepts_cargo, HouseSpec::accepts_cargo_label, HouseSpec::building_flags, HouseSpec::cargo_acceptance, EnsureEarlyHouse(), RandomAccessFile::filename, GameSettings::game_creation, HouseSpec::Get(), HZ_SUBARTC_ABOVE, HZ_ZON1, HZ_ZON5, IsHouseSpecValid(), IsValidCargoID(), GameCreationSettings::landscape, lengthof, NUM_HOUSES, HouseOverrideManager::SetEntitySpec(), and HouseSpec::Specs().

Referenced by AfterLoadGRFs().

◆ FinaliseIndustriesArray()

◆ FinaliseObjectsArray()

static void FinaliseObjectsArray ( )
static

Add all new objects to the object array.

Object properties can be set at any time in the GRF file, so we can only add an object spec to the object array after the file has finished loading.

Definition at line 9577 of file newgrf.cpp.

References _grf_files, ObjectSpec::BindToClasses(), and ObjectOverrideManager::SetEntitySpec().

Referenced by AfterLoadGRFs().

◆ FinalisePriceBaseMultipliers()

static void FinalisePriceBaseMultipliers ( )
static

Decide whether price base multipliers of grfs shall apply globally or only to the grf specifying them.

Features, to which '_grf_id_overrides' applies. Currently vehicle features only.

Definition at line 9878 of file newgrf.cpp.

References _grf_files, Debug, PriceBaseSpec::fallback_price, RandomAccessFile::filename, find_index(), GetFileByGRFID(), PriceBaseSpec::grf_feature, GRFFile::grf_features, HasBit(), GRFFile::price_base_multipliers, and SetPriceBaseMultiplier().

Referenced by AfterLoadGRFs().

◆ GetAction5Types()

std::span< const Action5Type > GetAction5Types ( )

Get list of all action 5 types.

Returns
Read-only span of action 5 type information.

Definition at line 6467 of file newgrf.cpp.

References _action5_types.

Referenced by SpriteAlignerWindow::SetStringParameters().

◆ GetActiveCargoLabel() [1/2]

static CargoLabel GetActiveCargoLabel ( const std::initializer_list< CargoLabel > &  labels)
static

Find first cargo label that exists and is active from a list of cargo labels.

Parameters
labelsList of cargo labels.
Returns
First cargo label in list that exists, or CT_INVALID if none exist.

Definition at line 9015 of file newgrf.cpp.

References CT_INVALID.

Referenced by CalculateRefitMasks(), FinaliseIndustriesArray(), and GetActiveCargoLabel().

◆ GetActiveCargoLabel() [2/2]

static CargoLabel GetActiveCargoLabel ( const std::variant< CargoLabel, MixedCargoType > &  label)
static

Get active cargo label from either a cargo label or climate-dependent mixed cargo type.

Parameters
labelCargo label or climate-dependent mixed cargo type.
Returns
Active cargo label, or CT_INVALID if cargo label is not active.

Definition at line 9029 of file newgrf.cpp.

References GetActiveCargoLabel(), MCT_GRAIN_WHEAT_MAIZE, MCT_LIVESTOCK_FRUIT, and MCT_VALUABLES_GOLD_DIAMONDS.

◆ GetAllGRFFiles()

const std::vector< GRFFile * > & GetAllGRFFiles ( )

Definition at line 72 of file newgrf.cpp.

◆ GetCallbackResultGroup()

static const SpriteGroup * GetCallbackResultGroup ( uint16_t  value)
static

Definition at line 5158 of file newgrf.cpp.

◆ GetCargoTranslationTable()

std::span< const CargoLabel > GetCargoTranslationTable ( const GRFFile grffile)

Get the cargo translation table to use for the given GRF file.

Parameters
grffileGRF file.
Returns
Readonly cargo translation table to use.

Definition at line 5591 of file newgrf.cpp.

References GRFFile::cargo_list, GetClimateDependentCargoTranslationTable(), and GetClimateIndependentCargoTranslationTable().

Referenced by BuildCargoTranslationMap().

◆ GetCurrentGRFOverride()

static GRFFile * GetCurrentGRFOverride ( )
static

Get overridden GRF for current GRF if present.

Returns
Overridden GRFFile if present, or nullptr.

Definition at line 609 of file newgrf.cpp.

References GetFileByGRFID(), and GrfProcessingState::grffile.

Referenced by LoadTranslationTable().

◆ GetFileByFilename()

static GRFFile * GetFileByFilename ( const std::string &  filename)
static

Obtain a NewGRF file by its filename.

Parameters
filenameThe filename to obtain the file for.
Returns
The file.

Definition at line 413 of file newgrf.cpp.

References _grf_files.

Referenced by InitNewGRFFile(), and LoadNewGRFFile().

◆ GetFileByGRFID()

static GRFFile * GetFileByGRFID ( uint32_t  grfid)
static

Obtain a NewGRF file by its grfID.

Parameters
grfidThe grfID to obtain the file for
Returns
The file.

Definition at line 400 of file newgrf.cpp.

References _grf_files.

Referenced by DisableGrf(), FinalisePriceBaseMultipliers(), GetCurrentGRFOverride(), LanguageMap::GetLanguageMap(), GetNewEngine(), ImportGRFSound(), LoadNewGRF(), and ParamSet().

◆ GetGlobalVariable()

bool GetGlobalVariable ( uint8_t  param,
uint32_t *  value,
const GRFFile grffile 
)

Reads a variable common to VarAction2 and Action7/9/D.

Returns VarAction2 variable 'param' resp. Action7/9/D variable '0x80 + param'. If a variable is not accessible from all four actions, it is handled in the action specific functions.

Parameters
paramvariable number (as for VarAction2, for Action7/9/D you have to subtract 0x80 first).
valuereturns the value of the variable.
grffileNewGRF querying the variable
Returns
true iff the variable is known and the value is returned in 'value'.

Definition at line 6584 of file newgrf.cpp.

References _misc_grf_features, _settings_game, Clamp(), GameSettings::construction, TimerGameCalendar::ConvertDateToYMD(), TimerGameCalendar::ConvertYMDToDate(), TimerGameTick::counter, TimerGameCalendar::date, TimerGameCalendar::date_fract, TimerGameConst< struct Calendar >::DAYS_TILL_ORIGINAL_BASE_YEAR, VehicleSettings::disable_elrails, GameSettings::game_creation, GB(), GetRailTypeInfo(), GetSnowLine(), GMB_TRAIN_WIDTH_32_PIXELS, GrfProcessingState::grfconfig, GrfProcessingState::grffile, GRFP_USE_MASK, HasBit(), TimerGame< struct Calendar >::IsLeapYear(), GameCreationSettings::landscape, ConstructionSettings::map_height_limit, TimerGameConst< struct Calendar >::ORIGINAL_BASE_YEAR, TimerGameConst< struct Calendar >::ORIGINAL_MAX_YEAR, GRFConfig::palette, RAILTYPE_ELECTRIC, RAILTYPE_MAGLEV, RAILTYPE_MONO, RAILTYPE_RAIL, VehicleSettings::road_side, SB(), SetBit(), SP_CUSTOM, TILE_HEIGHT, GRFFile::traininfo_vehicle_pitch, GRFFile::traininfo_vehicle_width, GameSettings::vehicle, and TimerGameCalendar::year.

◆ GetGroupFromGroupID()

static const SpriteGroup * GetGroupFromGroupID ( uint8_t  setid,
uint8_t  type,
uint16_t  groupid 
)
static

Definition at line 5181 of file newgrf.cpp.

◆ GetNewEngine()

static Engine * GetNewEngine ( const GRFFile file,
VehicleType  type,
uint16_t  internal_id,
bool  static_access = false 
)
static

◆ GetNewEngineID()

EngineID GetNewEngineID ( const GRFFile file,
VehicleType  type,
uint16_t  internal_id 
)

Return the ID of a new engine.

Parameters
fileThe NewGRF file providing the engine.
typeThe Vehicle type.
internal_idNewGRF-internal ID of the engine.
Returns
The new EngineID.
Note
depending on the dynamic_engine setting and a possible override property the grfID may be unique or overwriting or partially re-defining properties of an existing engine.

Definition at line 711 of file newgrf.cpp.

References _settings_game, VehicleSettings::dynamic_engines, EngineOverrideManager::GetID(), and GameSettings::vehicle.

Referenced by FinaliseEngineArray(), and GetNextArticulatedPart().

◆ GetParamVal()

static uint32_t GetParamVal ( uint8_t  param,
uint32_t *  cond_val 
)
static

Definition at line 6715 of file newgrf.cpp.

◆ GetPatchVariable()

static uint32_t GetPatchVariable ( uint8_t  param)
static

Definition at line 7327 of file newgrf.cpp.

◆ GlobalVarChangeInfo()

◆ GlobalVarReserveInfo()

static ChangeInfoResult GlobalVarReserveInfo ( uint  gvid,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Definition at line 2973 of file newgrf.cpp.

◆ GraphicsNew()

static void GraphicsNew ( ByteReader buf)
static

Definition at line 6473 of file newgrf.cpp.

◆ GRFComment()

static void GRFComment ( ByteReader buf)
static

Definition at line 7295 of file newgrf.cpp.

◆ GRFInfo()

static void GRFInfo ( ByteReader buf)
static

Definition at line 7079 of file newgrf.cpp.

◆ GRFInhibit()

static void GRFInhibit ( ByteReader buf)
static

Definition at line 7780 of file newgrf.cpp.

◆ GRFLoadError()

static void GRFLoadError ( ByteReader buf)
static

Definition at line 7187 of file newgrf.cpp.

◆ GrfMsgI()

void GrfMsgI ( int  severity,
const std::string &  msg 
)

Debug() function dedicated to newGRF debugging messages Function is essentially the same as Debug(grf, severity, ...) with the addition of file:line information when parsing grf files.

NOTE: for the above reason(s) GrfMsg() should ONLY be used for loading/parsing grf files, not for runtime debug messages as there is no file information available during that time.

Parameters
severitydebugging severity level, see debug.h
msgthe message

Definition at line 390 of file newgrf.cpp.

References Debug, GRFConfig::filename, GrfProcessingState::grfconfig, and GrfProcessingState::nfo_line.

◆ GRFSound()

static void GRFSound ( ByteReader buf)
static

Definition at line 7946 of file newgrf.cpp.

◆ GRFUnsafe()

static void GRFUnsafe ( ByteReader )
static

Set the current NewGRF as unsafe for static use.

Note
Used during safety scan on unsafe actions.

Definition at line 8658 of file newgrf.cpp.

References GRFConfig::flags, GCF_UNSAFE, GrfProcessingState::grfconfig, SetBit(), and GrfProcessingState::skip_sprites.

◆ HandleChangeInfoResult()

static bool HandleChangeInfoResult ( const char *  caller,
ChangeInfoResult  cir,
uint8_t  feature,
uint8_t  property 
)
static

Definition at line 4913 of file newgrf.cpp.

◆ HandleNode()

static bool HandleNode ( uint8_t  type,
uint32_t  id,
ByteReader buf,
AllowedSubtags  subtags[] 
)
static

Handle the nodes of an Action14.

Parameters
typeType of node.
idID.
bufBuffer.
subtagsAllowed subtags.
Returns
Whether all tags could be handled.

Definition at line 8595 of file newgrf.cpp.

References AllowedSubtags::branch, BSWAP32(), AllowedSubtags::call_handler, AllowedSubtags::data, AllowedSubtags::id, SkipUnknownInfo(), AllowedSubtags::subtags, AllowedSubtags::text, and AllowedSubtags::type.

Referenced by HandleNodes().

◆ HandleNodes()

static bool HandleNodes ( ByteReader buf,
AllowedSubtags  subtags[] 
)
static

Handle the contents of a 'C' choice of an Action14.

Parameters
bufBuffer.
subtagsList of subtags.
Returns
Whether the nodes could all be handled.

Definition at line 8633 of file newgrf.cpp.

References HandleNode().

◆ HandleParameterInfo()

static bool HandleParameterInfo ( ByteReader buf)
static

Callback function for 'INFO'->'PARA' to set extra information about the parameters.

Each subnode of 'INFO'->'PARA' should be a branch node with the parameter number as id. The first parameter has id 0. The maximum parameter that can be changed is set by 'INFO'->'NPAR' which defaults to 80.

Definition at line 8502 of file newgrf.cpp.

References _cur_parameter, _tags_parameters, GrfProcessingState::grfconfig, GRFConfig::num_valid_params, GRFConfig::param_info, and SkipUnknownInfo().

◆ IgnoreIndustryProperty()

static ChangeInfoResult IgnoreIndustryProperty ( int  prop,
ByteReader buf 
)
static

Ignore an industry property.

Parameters
propThe property to ignore.
bufThe property value.
Returns
ChangeInfoResult.

Definition at line 3438 of file newgrf.cpp.

References CIR_SUCCESS, CIR_UNKNOWN, and INDUSTRY_ORIGINAL_NUM_INPUTS.

Referenced by IndustriesChangeInfo().

◆ IgnoreIndustryTileProperty()

static ChangeInfoResult IgnoreIndustryTileProperty ( int  prop,
ByteReader buf 
)
static

Ignore an industry tile property.

Parameters
propThe property to ignore.
bufThe property value.
Returns
ChangeInfoResult.

Definition at line 3263 of file newgrf.cpp.

References CIR_SUCCESS, and CIR_UNKNOWN.

Referenced by IndustrytilesChangeInfo().

◆ IgnoreObjectProperty()

static ChangeInfoResult IgnoreObjectProperty ( uint  prop,
ByteReader buf 
)
static

Ignore properties for objects.

Parameters
propThe property to ignore.
bufThe property value.
Returns
ChangeInfoResult.

Definition at line 4088 of file newgrf.cpp.

References CIR_SUCCESS, and CIR_UNKNOWN.

Referenced by ObjectChangeInfo().

◆ IgnoreRoadStopProperty()

static ChangeInfoResult IgnoreRoadStopProperty ( uint  prop,
ByteReader buf 
)
static

Ignore properties for roadstops.

Parameters
propThe property to ignore.
bufThe property value.
Returns
ChangeInfoResult.

Definition at line 4792 of file newgrf.cpp.

References CIR_SUCCESS, and CIR_UNKNOWN.

◆ IgnoreTownHouseProperty()

static ChangeInfoResult IgnoreTownHouseProperty ( int  prop,
ByteReader buf 
)
static

Ignore a house property.

Parameters
propProperty to read.
bufProperty value.
Returns
ChangeInfoResult.

Definition at line 2362 of file newgrf.cpp.

References CIR_SUCCESS, and CIR_UNKNOWN.

Referenced by TownHouseChangeInfo().

◆ ImportGRFSound()

static void ImportGRFSound ( SoundEntry sound)
static

Process a sound import from another GRF file.

Parameters
soundDestination for sound.

Definition at line 7899 of file newgrf.cpp.

References GrfProcessingState::file, GetFileByGRFID(), RandomAccessFile::ReadDword(), and RandomAccessFile::ReadWord().

◆ IndustriesChangeInfo()

static ChangeInfoResult IndustriesChangeInfo ( uint  indid,
int  numinfo,
int  prop,
ByteReader buf 
)
static

◆ IndustryMapSpriteGroup()

static void IndustryMapSpriteGroup ( ByteReader buf,
uint8_t  idcount 
)
static

Definition at line 5841 of file newgrf.cpp.

◆ IndustrytileMapSpriteGroup()

static void IndustrytileMapSpriteGroup ( ByteReader buf,
uint8_t  idcount 
)
static

Definition at line 5873 of file newgrf.cpp.

◆ IndustrytilesChangeInfo()

static ChangeInfoResult IndustrytilesChangeInfo ( uint  indtid,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Define properties for industry tiles.

Parameters
indtidLocal ID of the industry tile.
numinfoNumber of subsequent industry tile IDs to change the property for.
propThe property to change.
bufThe property value.
Returns
ChangeInfoResult.

Definition at line 3303 of file newgrf.cpp.

References OverrideManagerBase::Add(), OverrideManagerBase::AddEntityID(), CIR_DISABLED, CIR_INVALID_ID, CIR_SUCCESS, CIR_UNKNOWN, Clamp(), CT_INVALID, DisableGrf(), GB(), GetCargoTranslation(), GrfProcessingState::grffile, IgnoreIndustryTileProperty(), INDUSTRYTILE_NOANIM, NEW_INDUSTRYTILEOFFSET, NUM_INDUSTRYTILES_PER_GRF, and GRFError::param_value.

◆ InitGRFTownGeneratorNames()

void InitGRFTownGeneratorNames ( )
extern

Allocate memory for the NewGRF town names.

Definition at line 81 of file newgrf_townname.cpp.

References GRFTownName::styles.

Referenced by AfterLoadGRFs().

◆ InitializeGRFSpecial()

◆ InitNewGRFFile()

static void InitNewGRFFile ( const GRFConfig config)
static

Prepare loading a NewGRF file with its config.

Parameters
configThe NewGRF configuration struct with name, id, parameters and alike.

Definition at line 8960 of file newgrf.cpp.

References _grf_files, GRFConfig::filename, GetFileByFilename(), and GrfProcessingState::grffile.

Referenced by LoadNewGRF().

◆ IsGRMReservedSprite()

static bool IsGRMReservedSprite ( SpriteID  first_sprite,
uint16_t  num_sprites 
)
static

Check if a sprite ID range is within the GRM reversed range for the currently loading NewGRF.

Parameters
first_spriteFirst sprite of range.
num_spritesNumber of sprites in the range.
Returns
True iff the NewGRF has reserved a range equal to or greater than the provided range.

Definition at line 7115 of file newgrf.cpp.

References GrfProcessingState::grffile.

◆ IsHouseSpecValid()

static bool IsHouseSpecValid ( HouseSpec hs,
const HouseSpec next1,
const HouseSpec next2,
const HouseSpec next3,
const std::string &  filename 
)
static

Check if a given housespec is valid and disable it if it's not.

The housespecs that follow it are used to check the validity of multitile houses.

Parameters
hsThe housespec to check.
next1The housespec that follows hs.
next2The housespec that follows next1.
next3The housespec that follows next2.
filenameThe filename of the newgrf this house was defined in.
Returns
Whether the given housespec is valid.

Definition at line 9354 of file newgrf.cpp.

References HouseSpec::building_availability, HouseSpec::building_flags, Debug, HouseSpec::enabled, HouseSpec::Get(), HouseSpec::grf_prop, HZ_CLIMALL, HZ_ZONALL, GRFFilePropsBase< Tcnt >::local_id, and HouseSpec::population.

Referenced by FinaliseHouseArray().

◆ IsValidGroupID()

static bool IsValidGroupID ( uint16_t  groupid,
const char *  function 
)
static

Definition at line 5635 of file newgrf.cpp.

◆ IsValidNewGRFImageIndex()

template<VehicleType T>
static bool IsValidNewGRFImageIndex ( uint8_t  image_index)
inlinestatic

Helper to check whether an image index is valid for a particular NewGRF vehicle.

Template Parameters
TThe type of vehicle.
Parameters
image_indexThe image index to check.
Returns
True iff the image index is valid, or 0xFD (use new graphics).

Definition at line 208 of file newgrf.cpp.

◆ LoadFontGlyph()

static void LoadFontGlyph ( ByteReader buf)
static

◆ LoadGRFSound()

static void LoadGRFSound ( size_t  offs,
SoundEntry sound 
)
static

Load a sound from a file.

Parameters
offsFile offset to read sound from.
soundDestination for sound.

Definition at line 7930 of file newgrf.cpp.

References GrfProcessingState::file, SpriteFile::GetContainerVersion(), and SoundEntry::grf_container_ver.

◆ LoadNewGRF()

◆ LoadNewGRFFile()

void LoadNewGRFFile ( GRFConfig config,
GrfLoadingStage  stage,
Subdirectory  subdir,
bool  temporary 
)

Load a particular NewGRF.

Parameters
configThe configuration of the to be loaded NewGRF.
stageThe loading stage of the NewGRF.
subdirThe sub directory to find the NewGRF in.
temporaryThe NewGRF/sprite file is to be loaded temporarily and should be closed immediately, contrary to loading the SpriteFile and having it cached by the SpriteCache.

Definition at line 9790 of file newgrf.cpp.

References GRFConfig::filename, GRFConfig::flags, GCF_RESERVED, GCS_INITIALISED, GetFileByFilename(), GrfProcessingState::grffile, GRFP_USE_MASK, HasBit(), LoadNewGRFFileFromFile(), OpenCachedSpriteFile(), GRFConfig::palette, and GRFConfig::status.

Referenced by FillGRFDetails(), and LoadNewGRF().

◆ LoadNewGRFFileFromFile()

static void LoadNewGRFFileFromFile ( GRFConfig config,
GrfLoadingStage  stage,
SpriteFile file 
)
static

◆ LoadTranslationTable()

template<typename T , typename TGetTableFunc >
static ChangeInfoResult LoadTranslationTable ( uint  gvid,
int  numinfo,
ByteReader buf,
TGetTableFunc  gettable,
std::string_view  name 
)
static

Load a cargo- or railtype-translation table.

Parameters
gvidID of the global variable. This is basically only checked for zerones.
numinfoNumber of subsequent IDs to change the property for.
bufThe property value.
gettableFunction to get storage for the translation table.
nameName of the table for debug output.
Returns
ChangeInfoResult.

Definition at line 2709 of file newgrf.cpp.

References BSWAP32(), CIR_INVALID_ID, CIR_SUCCESS, GetCurrentGRFOverride(), and GrfProcessingState::grffile.

◆ MapGRFStringID()

StringID MapGRFStringID ( uint32_t  grfid,
StringID  str 
)

Used when setting an object's property to map to the GRF's strings while taking in consideration the "drift" between TTDPatch string system and OpenTTD's one.

Parameters
grfidId of the grf file.
strStringID that we want to have the equivalent in OoenTTD.
Returns
The properly adjusted StringID.

Definition at line 560 of file newgrf.cpp.

References GetGRFStringID(), IsInsideMM(), and TTDPStringIDToOTTDStringIDMapping().

Referenced by AfterLoadGRFs(), ChangeIndustryProduction(), RemapNewGRFStringControlCode(), and TranslateTTDPatchCodes().

◆ MapSpriteMappingRecolour()

static void MapSpriteMappingRecolour ( PalSpriteID grf_sprite)
static

Map the colour modifiers of TTDPatch to those that Open is using.

Parameters
grf_spritePointer to the structure been modified.

Definition at line 728 of file newgrf.cpp.

References ClrBit(), HasBit(), PalSpriteID::pal, PALETTE_MODIFIER_COLOUR, PALETTE_MODIFIER_TRANSPARENT, SetBit(), PalSpriteID::sprite, and SPRITE_MODIFIER_OPAQUE.

Referenced by BridgeChangeInfo(), and ReadSpriteLayoutSprite().

◆ NewSpriteGroup()

static void NewSpriteGroup ( ByteReader buf)
static

Definition at line 5221 of file newgrf.cpp.

◆ NewSpriteSet()

static void NewSpriteSet ( ByteReader buf)
static

Definition at line 5090 of file newgrf.cpp.

◆ ObjectChangeInfo()

static ChangeInfoResult ObjectChangeInfo ( uint  id,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Define properties for objects.

Parameters
idLocal ID of the object.
numinfoNumber of subsequent objectIDs to change the property for.
propThe property to change.
bufThe property value.
Returns
ChangeInfoResult.

Definition at line 4135 of file newgrf.cpp.

References _loaded_newgrf_features, AddStringForMapping(), NewGRFClass< Tspec, Tindex, Tmax >::Allocate(), BSWAP32(), CIR_INVALID_ID, CIR_SUCCESS, CIR_UNKNOWN, GB(), GrfProcessingState::grffile, GRFLoadedFeatures::has_2CC, IgnoreObjectProperty(), NUM_OBJECTS_PER_GRF, OBJECT_FLAG_2CC_COLOUR, and OBJECT_SIZE_1X1.

◆ ObjectMapSpriteGroup()

static void ObjectMapSpriteGroup ( ByteReader buf,
uint8_t  idcount 
)
static

Definition at line 5932 of file newgrf.cpp.

◆ ParamSet()

◆ PerformGRM()

static uint32_t PerformGRM ( uint32_t *  grm,
uint16_t  num_ids,
uint16_t  count,
uint8_t  op,
uint8_t  target,
const char *  type 
)
static

Definition at line 7405 of file newgrf.cpp.

◆ RailTypeChangeInfo()

◆ RailTypeMapSpriteGroup()

static void RailTypeMapSpriteGroup ( ByteReader buf,
uint8_t  idcount 
)
static

Definition at line 5992 of file newgrf.cpp.

◆ RailTypeReserveInfo()

static ChangeInfoResult RailTypeReserveInfo ( uint  id,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Definition at line 4395 of file newgrf.cpp.

◆ RailVehicleChangeInfo()

static ChangeInfoResult RailVehicleChangeInfo ( uint  engine,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Define properties for rail vehicles.

Parameters
engine:ocal ID of the first vehicle.
numinfoNumber of subsequent IDs to change the property for.
propThe property to change.
bufThe property value.
Returns
ChangeInfoResult.

Definition at line 1060 of file newgrf.cpp.

References _gted, _loaded_newgrf_features, RailVehicleInfo::ai_passenger_only, RailVehicleInfo::air_drag, AlterVehicleListOrder(), EngineInfo::base_intro, EngineInfo::callback_mask, RailVehicleInfo::capacity, EngineInfo::cargo_age_period, CIR_INVALID_ID, CIR_SUCCESS, CommonVehicleChangeInfo(), ConvertTTDBasePrice(), RailVehicleInfo::cost_factor, CT_INVALID, RailVehicleInfo::curve_speed_mod, EC_DIESEL, EC_ELECTRIC, EC_MAGLEV, EC_MONORAIL, EC_STEAM, EF_USES_2CC, RailVehicleInfo::engclass, GetCargoTranslation(), GetNewEngine(), GrfProcessingState::grffile, GRFLoadedFeatures::has_2CC, HasBit(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, IsValidCargoID(), RailVehicleInfo::max_speed, EngineInfo::misc_flags, RailVehicleInfo::pow_wag_power, RailVehicleInfo::pow_wag_weight, RailVehicleInfo::power, PROP_TRAIN_CARGO_AGE_PERIOD, PROP_TRAIN_CARGO_CAPACITY, PROP_TRAIN_COST_FACTOR, PROP_TRAIN_CURVE_SPEED_MOD, PROP_TRAIN_POWER, PROP_TRAIN_RUNNING_COST_FACTOR, PROP_TRAIN_SHORTEN_FACTOR, PROP_TRAIN_SPEED, PROP_TRAIN_TRACTIVE_EFFORT, PROP_TRAIN_USER_DATA, PROP_TRAIN_WEIGHT, GRFFile::railtype_list, RAILVEH_MULTIHEAD, RAILVEH_SINGLEHEAD, RAILVEH_WAGON, EngineInfo::retire_early, RailVehicleInfo::running_cost, SB(), SetBit(), RailVehicleInfo::shorten_factor, RailVehicleInfo::tractive_effort, TranslateRefitMask(), RailVehicleInfo::user_def_data, EngineInfo::variant_id, VE_DEFAULT, VE_DISABLE_EFFECT, VE_TYPE_COUNT, VE_TYPE_START, VEH_TRAIN, RailVehicleInfo::visual_effect, and RailVehicleInfo::weight.

◆ ReadDWordAsString()

static std::string ReadDWordAsString ( ByteReader reader)
static

Helper to read a DWord worth of bytes from the reader and to return it as a valid string.

Parameters
readerThe source of the DWord.
Returns
The read DWord as string.

Definition at line 2740 of file newgrf.cpp.

References StrMakeValid().

Referenced by GlobalVarChangeInfo().

◆ ReadSpriteLayout()

static bool ReadSpriteLayout ( ByteReader buf,
uint  num_building_sprites,
bool  use_cur_spritesets,
uint8_t  feature,
bool  allow_var10,
bool  no_z_position,
NewGRFSpriteLayout dts 
)
static

Read a spritelayout from the GRF.

Parameters
bufInput
num_building_spritesNumber of building sprites to read
use_cur_spritesetsWhether to use currently referenceable action 1 sets.
featureGrfSpecFeature to use spritesets from.
allow_var10Whether the spritelayout may specify var10 values for resolving multiple action-1-2-3 chains
no_z_positionWhether bounding boxes have no Z offset
dtsLayout container to output into
Returns
True on error (GRF was disabled).

Definition at line 870 of file newgrf.cpp.

References NewGRFSpriteLayout::Allocate(), NewGRFSpriteLayout::AllocateRegisters(), ClrBit(), NewGRFSpriteLayout::consistent_max_offset, DrawTileSeqStruct::delta_x, DrawTileSeqStruct::delta_z, DisableGrf(), DrawTileSprites::ground, HasBit(), DrawTileSeqStruct::IsParentSprite(), TileLayoutRegisters::max_palette_offset, TileLayoutRegisters::max_sprite_offset, ReadSpriteLayoutRegisters(), ReadSpriteLayoutSprite(), DrawTileSprites::seq, GrfProcessingState::skip_sprites, TLF_KNOWN_FLAGS, and TLF_NON_GROUND_FLAGS.

Referenced by StationChangeInfo().

◆ ReadSpriteLayoutRegisters()

static void ReadSpriteLayoutRegisters ( ByteReader buf,
TileLayoutFlags  flags,
bool  is_parent,
NewGRFSpriteLayout dts,
uint  index 
)
static

Preprocess the TileLayoutFlags and read register modifiers from the GRF.

Parameters
bufInput stream.
flagsTileLayoutFlags to process.
is_parentWhether the sprite is a parentsprite with a bounding box.
dtsSprite layout to insert data into.
indexSprite index to process; 0 for ground sprite.

Definition at line 817 of file newgrf.cpp.

References NewGRFSpriteLayout::AllocateRegisters(), TileLayoutRegisters::child, DisableGrf(), TileLayoutRegisters::dodraw, TileLayoutRegisters::flags, TileLayoutRegisters::palette, TileLayoutRegisters::palette_var10, TileLayoutRegisters::parent, TileLayoutRegisters::sprite, TileLayoutRegisters::sprite_var10, TLF_BB_XY_OFFSET, TLF_BB_Z_OFFSET, TLF_CHILD_X_OFFSET, TLF_CHILD_Y_OFFSET, TLF_DODRAW, TLF_DRAWING_FLAGS, TLF_PALETTE, TLF_PALETTE_VAR10, TLF_SPRITE, TLF_SPRITE_VAR10, and TLR_MAX_VAR10.

Referenced by ReadSpriteLayout().

◆ ReadSpriteLayoutSprite()

static TileLayoutFlags ReadSpriteLayoutSprite ( ByteReader buf,
bool  read_flags,
bool  invert_action1_flag,
bool  use_cur_spritesets,
int  feature,
PalSpriteID grf_sprite,
uint16_t *  max_sprite_offset = nullptr,
uint16_t *  max_palette_offset = nullptr 
)
static

Read a sprite and a palette from the GRF and convert them into a format suitable to OpenTTD.

Parameters
bufInput stream.
read_flagsWhether to read TileLayoutFlags.
invert_action1_flagSet to true, if palette bit 15 means 'not from action 1'.
use_cur_spritesetsWhether to use currently referenceable action 1 sets.
featureGrfSpecFeature to use spritesets from.
[out]grf_spriteRead sprite and palette.
[out]max_sprite_offsetOptionally returns the number of sprites in the spriteset of the sprite. (0 if no spritset)
[out]max_palette_offsetOptionally returns the number of sprites in the spriteset of the palette. (0 if no spritset)
Returns
Read TileLayoutFlags.

Definition at line 759 of file newgrf.cpp.

References ClrBit(), DisableGrf(), GB(), GrfProcessingState::GetNumEnts(), GrfProcessingState::GetSprite(), HasBit(), GrfProcessingState::IsValidSpriteSet(), MapSpriteMappingRecolour(), PalSpriteID::pal, SB(), SetBit(), PalSpriteID::sprite, SPRITE_MODIFIER_CUSTOM_SPRITE, SPRITE_WIDTH, TLF_CUSTOM_PALETTE, TLF_PALETTE_REG_FLAGS, TLF_PALETTE_VAR10, TLF_SPRITE_REG_FLAGS, and TLF_SPRITE_VAR10.

Referenced by ReadSpriteLayout(), and StationChangeInfo().

◆ ReserveChangeInfo()

static void ReserveChangeInfo ( ByteReader buf)
static

Definition at line 5048 of file newgrf.cpp.

◆ ResetCustomAirports()

static void ResetCustomAirports ( )
static

Reset and clear all NewGRF airports.

Definition at line 8773 of file newgrf.cpp.

References _grf_files.

Referenced by ResetNewGRFData().

◆ ResetCustomHouses()

static void ResetCustomHouses ( )
static

Reset and clear all NewGRF houses.

Definition at line 8765 of file newgrf.cpp.

References _grf_files.

Referenced by ResetNewGRFData().

◆ ResetCustomIndustries()

static void ResetCustomIndustries ( )
static

Reset and clear all NewGRF industries.

Definition at line 8782 of file newgrf.cpp.

References _grf_files.

Referenced by ResetNewGRFData().

◆ ResetCustomObjects()

static void ResetCustomObjects ( )
static

Reset and clear all NewObjects.

Definition at line 8791 of file newgrf.cpp.

References _grf_files.

Referenced by ResetNewGRFData().

◆ ResetCustomRoadStops()

static void ResetCustomRoadStops ( )
static

Definition at line 8798 of file newgrf.cpp.

◆ ResetCustomStations()

static void ResetCustomStations ( )
static

Reset and clear all NewGRF stations.

Definition at line 8757 of file newgrf.cpp.

References _grf_files.

Referenced by ResetNewGRFData().

◆ ResetNewGRF()

static void ResetNewGRF ( )
static

Reset and clear all NewGRFs.

Definition at line 8806 of file newgrf.cpp.

References _grf_files, and GrfProcessingState::grffile.

Referenced by ResetNewGRFData().

◆ ResetNewGRFData()

◆ ResetNewGRFErrors()

static void ResetNewGRFErrors ( )
static

Clear all NewGRF errors.

Definition at line 8817 of file newgrf.cpp.

References _grfconfig, GRFConfig::error, and GRFConfig::next.

Referenced by ResetNewGRFData().

◆ ResetPersistentNewGRFData()

void ResetPersistentNewGRFData ( )

Reset NewGRF data which is stored persistently in savegames.

Definition at line 8926 of file newgrf.cpp.

References OverrideManagerBase::ResetMapping(), and EngineOverrideManager::ResetToDefaultMapping().

◆ RoadStopChangeInfo()

static ChangeInfoResult RoadStopChangeInfo ( uint  id,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Definition at line 4826 of file newgrf.cpp.

◆ RoadStopMapSpriteGroup()

static void RoadStopMapSpriteGroup ( ByteReader buf,
uint8_t  idcount 
)
static

Definition at line 6122 of file newgrf.cpp.

◆ RoadTypeChangeInfo() [1/2]

static ChangeInfoResult RoadTypeChangeInfo ( uint  id,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Definition at line 4602 of file newgrf.cpp.

◆ RoadTypeChangeInfo() [2/2]

◆ RoadTypeMapSpriteGroup()

static void RoadTypeMapSpriteGroup ( ByteReader buf,
uint8_t  idcount,
RoadTramType  rtt 
)
static

Definition at line 6024 of file newgrf.cpp.

◆ RoadTypeReserveInfo() [1/2]

static ChangeInfoResult RoadTypeReserveInfo ( uint  id,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Definition at line 4691 of file newgrf.cpp.

◆ RoadTypeReserveInfo() [2/2]

static ChangeInfoResult RoadTypeReserveInfo ( uint  id,
int  numinfo,
int  prop,
ByteReader buf,
RoadTramType  rtt 
)
static

Definition at line 4613 of file newgrf.cpp.

◆ RoadVehicleChangeInfo()

static ChangeInfoResult RoadVehicleChangeInfo ( uint  engine,
int  numinfo,
int  prop,
ByteReader buf 
)
static

◆ SafeChangeInfo()

static void SafeChangeInfo ( ByteReader buf)
static

Definition at line 5011 of file newgrf.cpp.

◆ SafeGRFInhibit()

static void SafeGRFInhibit ( ByteReader buf)
static

Definition at line 7755 of file newgrf.cpp.

◆ SafeParamSet()

static void SafeParamSet ( ByteReader buf)
static

Definition at line 7308 of file newgrf.cpp.

◆ SanitizeSpriteOffset()

static uint16_t SanitizeSpriteOffset ( uint16_t &  num,
uint16_t  offset,
int  max_sprites,
const std::string_view  name 
)
static

Sanitize incoming sprite offsets for Action 5 graphics replacements.

Parameters
numThe number of sprites to load.
offsetOffset from the base.
max_spritesThe maximum number of sprites that can be loaded in this action 5.
nameUsed for error warnings.
Returns
The number of sprites that is going to be skipped.

Definition at line 6411 of file newgrf.cpp.

◆ ScanInfo()

static void ScanInfo ( ByteReader buf)
static

Definition at line 7051 of file newgrf.cpp.

◆ SetNewGRFOverride()

static void SetNewGRFOverride ( uint32_t  source_grfid,
uint32_t  target_grfid 
)
static

Set the override for a NewGRF.

Parameters
source_grfidThe grfID which wants to override another NewGRF.
target_grfidThe grfID which is being overridden.

Definition at line 594 of file newgrf.cpp.

References BSWAP32().

Referenced by LoadNewGRF().

◆ ShipVehicleChangeInfo()

◆ SkipAct1()

static void SkipAct1 ( ByteReader buf)
static

Definition at line 5137 of file newgrf.cpp.

◆ SkipAct11()

static void SkipAct11 ( ByteReader buf)
static

Definition at line 8039 of file newgrf.cpp.

◆ SkipAct12()

static void SkipAct12 ( ByteReader buf)
static

Action 0x12 (SKIP)

Definition at line 8082 of file newgrf.cpp.

References GrfProcessingState::skip_sprites.

◆ SkipAct5()

static void SkipAct5 ( ByteReader buf)
static

Definition at line 6562 of file newgrf.cpp.

◆ SkipActA()

static void SkipActA ( ByteReader buf)
static

Definition at line 7172 of file newgrf.cpp.

◆ SkipIf()

static void SkipIf ( ByteReader buf)
static

Definition at line 6870 of file newgrf.cpp.

◆ SkipUnknownInfo()

static bool SkipUnknownInfo ( ByteReader buf,
uint8_t  type 
)
static

Try to skip the current node and all subnodes (if it's a branch node).

Parameters
bufBuffer.
typeThe node type to skip.
Returns
True if we could skip the node, false if an error occurred.

Definition at line 8555 of file newgrf.cpp.

References SkipUnknownInfo().

Referenced by ChangeGRFParamValueNames(), HandleNode(), HandleParameterInfo(), and SkipUnknownInfo().

◆ SoundEffectChangeInfo()

static ChangeInfoResult SoundEffectChangeInfo ( uint  sid,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Define properties for sound effects.

Parameters
sidLocal ID of the sound.
numinfoNumber of subsequent IDs to change the property for.
propThe property to change.
bufThe property value.
Returns
ChangeInfoResult.

Definition at line 3208 of file newgrf.cpp.

References CIR_INVALID_ID, CIR_SUCCESS, CIR_UNKNOWN, Clamp(), GrfProcessingState::grffile, and ORIGINAL_SAMPLE_COUNT.

◆ SpriteReplace()

static void SpriteReplace ( ByteReader buf)
static

Definition at line 7125 of file newgrf.cpp.

◆ StaticGRFInfo()

static void StaticGRFInfo ( ByteReader buf)
static

Handle Action 0x14.

Parameters
bufBuffer.

Definition at line 8648 of file newgrf.cpp.

References _tags_root.

◆ StationChangeInfo()

◆ StationMapSpriteGroup()

static void StationMapSpriteGroup ( ByteReader buf,
uint8_t  idcount 
)
static

Definition at line 5750 of file newgrf.cpp.

◆ TownHouseChangeInfo()

static ChangeInfoResult TownHouseChangeInfo ( uint  hid,
int  numinfo,
int  prop,
ByteReader buf 
)
static

◆ TownHouseMapSpriteGroup()

static void TownHouseMapSpriteGroup ( ByteReader buf,
uint8_t  idcount 
)
static

Definition at line 5809 of file newgrf.cpp.

◆ TramTypeChangeInfo()

static ChangeInfoResult TramTypeChangeInfo ( uint  id,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Definition at line 4607 of file newgrf.cpp.

◆ TramTypeReserveInfo()

static ChangeInfoResult TramTypeReserveInfo ( uint  id,
int  numinfo,
int  prop,
ByteReader buf 
)
static

Definition at line 4696 of file newgrf.cpp.

◆ TranslateCargo()

static CargoID TranslateCargo ( uint8_t  feature,
uint8_t  ctype 
)
static

Definition at line 5603 of file newgrf.cpp.

◆ TranslateGRFStrings()

static void TranslateGRFStrings ( ByteReader buf)
static

◆ TranslateRefitMask()

static CargoTypes TranslateRefitMask ( uint32_t  refit_mask)
static

Translate the refit mask.

refit_mask is uint32_t as it has not been mapped to CargoTypes.

Definition at line 963 of file newgrf.cpp.

References GetCargoTranslation(), GrfProcessingState::grffile, IsValidCargoID(), and SetBit().

Referenced by AircraftVehicleChangeInfo(), RailVehicleChangeInfo(), RoadVehicleChangeInfo(), ShipVehicleChangeInfo(), and StationChangeInfo().

◆ TTDPStringIDToOTTDStringIDMapping()

static StringID TTDPStringIDToOTTDStringIDMapping ( StringID  str)
static

Perform a mapping from TTDPatch's string IDs to OpenTTD's string IDs, but only for the ones we are aware off; the rest like likely unused and will show a warning.

Parameters
strthe string ID to convert
Returns
the converted string ID

Definition at line 496 of file newgrf.cpp.

References Debug, and IsInsideMM().

Referenced by MapGRFStringID().

◆ ValidateIndustryLayout()

static bool ValidateIndustryLayout ( const IndustryTileLayout layout)
static

Validate the industry layout; e.g.

to prevent duplicate tiles.

Parameters
layoutThe layout to check.
Returns
True if the layout is deemed valid.

Definition at line 3528 of file newgrf.cpp.

References GFX_WATERTILE_SPECIALCHECK.

Referenced by IndustriesChangeInfo().

◆ VehicleMapSpriteGroup()

static void VehicleMapSpriteGroup ( ByteReader buf,
uint8_t  feature,
uint8_t  idcount 
)
static

Definition at line 5645 of file newgrf.cpp.

Variable Documentation

◆ _action5_types

constexpr auto _action5_types
staticconstexpr
Initial value:
= std::to_array<Action5Type>({
{ A5BLOCK_INVALID, 0, 0, 0, "Type 0x00" },
{ A5BLOCK_INVALID, 0, 0, 0, "Type 0x01" },
{ A5BLOCK_INVALID, 0, 0, 0, "Type 0x02" },
{ A5BLOCK_INVALID, 0, 0, 0, "Type 0x03" },
{ A5BLOCK_ALLOW_OFFSET, SPR_SIGNALS_BASE, 1, PRESIGNAL_SEMAPHORE_AND_PBS_SPRITE_COUNT, "Signal graphics" },
{ A5BLOCK_ALLOW_OFFSET, SPR_ELRAIL_BASE, 1, ELRAIL_SPRITE_COUNT, "Rail catenary graphics" },
{ A5BLOCK_ALLOW_OFFSET, SPR_SLOPES_BASE, 1, NORMAL_AND_HALFTILE_FOUNDATION_SPRITE_COUNT, "Foundation graphics" },
{ A5BLOCK_INVALID, 0, 75, 0, "TTDP GUI graphics" },
{ A5BLOCK_ALLOW_OFFSET, SPR_CANALS_BASE, 1, CANALS_SPRITE_COUNT, "Canal graphics" },
{ A5BLOCK_ALLOW_OFFSET, SPR_ONEWAY_BASE, 1, ONEWAY_SPRITE_COUNT, "One way road graphics" },
{ A5BLOCK_ALLOW_OFFSET, SPR_2CCMAP_BASE, 1, TWOCCMAP_SPRITE_COUNT, "2CC colour maps" },
{ A5BLOCK_ALLOW_OFFSET, SPR_TRAMWAY_BASE, 1, TRAMWAY_SPRITE_COUNT, "Tramway graphics" },
{ A5BLOCK_INVALID, 0, 133, 0, "Snowy temperate tree" },
{ A5BLOCK_FIXED, SPR_SHORE_BASE, 16, SPR_SHORE_SPRITE_COUNT, "Shore graphics" },
{ A5BLOCK_INVALID, 0, 0, 0, "New Signals graphics" },
{ A5BLOCK_ALLOW_OFFSET, SPR_TRACKS_FOR_SLOPES_BASE, 1, TRACKS_FOR_SLOPES_SPRITE_COUNT, "Sloped rail track" },
{ A5BLOCK_ALLOW_OFFSET, SPR_AIRPORTX_BASE, 1, AIRPORTX_SPRITE_COUNT, "Airport graphics" },
{ A5BLOCK_ALLOW_OFFSET, SPR_ROADSTOP_BASE, 1, ROADSTOP_SPRITE_COUNT, "Road stop graphics" },
{ A5BLOCK_ALLOW_OFFSET, SPR_AQUEDUCT_BASE, 1, AQUEDUCT_SPRITE_COUNT, "Aqueduct graphics" },
{ A5BLOCK_ALLOW_OFFSET, SPR_AUTORAIL_BASE, 1, AUTORAIL_SPRITE_COUNT, "Autorail graphics" },
{ A5BLOCK_INVALID, 0, 1, 0, "Flag graphics" },
{ A5BLOCK_ALLOW_OFFSET, SPR_OPENTTD_BASE, 1, OPENTTD_SPRITE_COUNT, "OpenTTD GUI graphics" },
{ A5BLOCK_ALLOW_OFFSET, SPR_AIRPORT_PREVIEW_BASE, 1, SPR_AIRPORT_PREVIEW_COUNT, "Airport preview graphics" },
{ A5BLOCK_ALLOW_OFFSET, SPR_RAILTYPE_TUNNEL_BASE, 1, RAILTYPE_TUNNEL_BASE_COUNT, "Railtype tunnel base" },
{ A5BLOCK_ALLOW_OFFSET, SPR_PALETTE_BASE, 1, PALETTE_SPRITE_COUNT, "Palette" },
{ A5BLOCK_ALLOW_OFFSET, SPR_ROAD_WAYPOINTS_BASE, 1, ROAD_WAYPOINTS_SPRITE_COUNT, "Road waypoints" },
})
@ A5BLOCK_ALLOW_OFFSET
Allow replacing any subset by specifiing an offset.
Definition newgrf_act5.h:16
@ A5BLOCK_INVALID
unknown/not-implemented type
Definition newgrf_act5.h:17
@ A5BLOCK_FIXED
Only allow replacing a whole block of sprites. (TTDP compatible)
Definition newgrf_act5.h:15
static const SpriteID SPR_AQUEDUCT_BASE
Sprites for the Aqueduct.
Definition sprites.h:186
static const SpriteID SPR_OPENTTD_BASE
Extra graphic spritenumbers.
Definition sprites.h:56
static const SpriteID SPR_TRACKS_FOR_SLOPES_BASE
Sprites for 'highlighting' tracks on sloped land.
Definition sprites.h:198
static const SpriteID SPR_ROAD_WAYPOINTS_BASE
Road waypoint sprites.
Definition sprites.h:311
static const SpriteID SPR_RAILTYPE_TUNNEL_BASE
Tunnel sprites with grass only for custom railtype tunnel.
Definition sprites.h:299
static const SpriteID SPR_TRAMWAY_BASE
Tramway sprites.
Definition sprites.h:272
static const SpriteID SPR_AIRPORT_PREVIEW_BASE
Airport preview sprites.
Definition sprites.h:248
static const SpriteID SPR_ONEWAY_BASE
One way road sprites.
Definition sprites.h:293
static const SpriteID SPR_SHORE_BASE
shore tiles - action 05-0D
Definition sprites.h:224

The information about action 5 types.

Definition at line 6433 of file newgrf.cpp.

Referenced by GetAction5Types().

◆ _cached_callback_groups

std::vector<CachedCallback> _cached_callback_groups
static

Sorted list of cached callback result spritegroups.

Definition at line 5156 of file newgrf.cpp.

Referenced by AfterLoadGRFs(), and ResetNewGRFData().

◆ _cur

GrfProcessingState _cur
static

Definition at line 198 of file newgrf.cpp.

◆ _cur_parameter

GRFParameterInfo* _cur_parameter
static

◆ _grf_files

◆ _grf_id_overrides

std::map<uint32_t, uint32_t> _grf_id_overrides
static

Definition at line 587 of file newgrf.cpp.

◆ _grf_line_to_action6_sprite_override

GRFLineToSpriteOverride _grf_line_to_action6_sprite_override
static

Definition at line 378 of file newgrf.cpp.

◆ _grm_cargoes

uint32_t _grm_cargoes[NUM_CARGO *2]
static

Contains the GRF ID of the owner of a cargo if it has been reserved.

Definition at line 357 of file newgrf.cpp.

Referenced by ParamSet(), and ResetNewGRFData().

◆ _grm_engines

uint32_t _grm_engines[256]
static

Contains the GRF ID of the owner of a vehicle if it has been reserved.

GRM for vehicles is only used if dynamic engine allocation is disabled, so 256 is the number of original engines.

Definition at line 354 of file newgrf.cpp.

Referenced by ParamSet(), and ResetNewGRFData().

◆ _grm_sprites

std::map<GRFLocation, std::pair<SpriteID, uint16_t> > _grm_sprites
static

Definition at line 376 of file newgrf.cpp.

◆ _gted

std::vector<GRFTempEngineData> _gted
static

◆ _loaded_newgrf_features

◆ _misc_grf_features

uint8_t _misc_grf_features = 0

Miscellaneous GRF features, set by Action 0x0D, parameter 0x9E.

Definition at line 78 of file newgrf.cpp.

Referenced by GetGlobalVariable(), HasGrfMiscBit(), ParamSet(), and ResetNewGRFData().

◆ _string_to_grf_mapping

std::vector<StringIDMapping> _string_to_grf_mapping
static

Strings to be mapped during load.

Definition at line 466 of file newgrf.cpp.

Referenced by AddStringForMapping(), and AfterLoadGRFs().

◆ _tags_info

AllowedSubtags _tags_info[]
Initial value:
= {
}
static bool ChangeGRFNumUsedParams(size_t len, ByteReader &buf)
Callback function for 'INFO'->'NPAR' to set the number of valid parameters.
Definition newgrf.cpp:8182
static bool ChangeGRFURL(uint8_t langid, std::string_view str)
Callback function for 'INFO'->'URL_' to set the newgrf url.
Definition newgrf.cpp:8175
static bool ChangeGRFMinVersion(size_t len, ByteReader &buf)
Callback function for 'INFO'->'MINV' to the minimum compatible version of the NewGRF.
Definition newgrf.cpp:8255
static bool HandleParameterInfo(ByteReader &buf)
Callback function for 'INFO'->'PARA' to set extra information about the parameters.
Definition newgrf.cpp:8502
static bool ChangeGRFName(uint8_t langid, std::string_view str)
Callback function for 'INFO'->'NAME' to add a translation to the newgrf name.
Definition newgrf.cpp:8161
static bool ChangeGRFDescription(uint8_t langid, std::string_view str)
Callback function for 'INFO'->'DESC' to add a translation to the newgrf description.
Definition newgrf.cpp:8168
static bool ChangeGRFPalette(size_t len, ByteReader &buf)
Callback function for 'INFO'->'PALS' to set the number of valid parameters.
Definition newgrf.cpp:8194
static bool ChangeGRFVersion(size_t len, ByteReader &buf)
Callback function for 'INFO'->'VRSN' to the version of the NewGRF.
Definition newgrf.cpp:8242
static bool ChangeGRFBlitter(size_t len, ByteReader &buf)
Callback function for 'INFO'->'BLTR' to set the blitter info.
Definition newgrf.cpp:8220
Data structure to store the allowed id/type combinations for action 14.
Definition newgrf.cpp:8374

Action14 tags for the INFO node.

Definition at line 8529 of file newgrf.cpp.

◆ _tags_parameters

AllowedSubtags _tags_parameters[]
Initial value:
= {
}
static bool ChangeGRFParamType(size_t len, ByteReader &buf)
Callback function for 'INFO'->'PARAM'->param_num->'TYPE' to set the typeof a parameter.
Definition newgrf.cpp:8291
static bool ChangeGRFParamLimits(size_t len, ByteReader &buf)
Callback function for 'INFO'->'PARAM'->param_num->'LIMI' to set the min/max value of a parameter.
Definition newgrf.cpp:8308
static bool ChangeGRFParamDescription(uint8_t langid, std::string_view str)
Callback function for 'INFO'->'PARAM'->param_num->'DESC' to set the description of a parameter.
Definition newgrf.cpp:8284
static bool ChangeGRFParamDefault(size_t len, ByteReader &buf)
Callback function for 'INFO'->'PARAM'->param_num->'DFLT' to set the default value.
Definition newgrf.cpp:8351
static bool ChangeGRFParamValueNames(ByteReader &buf)
Callback function for 'INFO'->'PARA'->param_num->'VALU' to set the names of some parameter values (ty...
Definition newgrf.cpp:8455
static bool ChangeGRFParamMask(size_t len, ByteReader &buf)
Callback function for 'INFO'->'PARAM'->param_num->'MASK' to set the parameter and bits to use.
Definition newgrf.cpp:8330
static bool ChangeGRFParamName(uint8_t langid, std::string_view str)
Callback function for 'INFO'->'PARAM'->param_num->'NAME' to set the name of a parameter.
Definition newgrf.cpp:8277

Action14 parameter tags.

Definition at line 8485 of file newgrf.cpp.

Referenced by HandleParameterInfo().

◆ _tags_root

AllowedSubtags _tags_root[]
Initial value:
= {
}
AllowedSubtags _tags_info[]
Action14 tags for the INFO node.
Definition newgrf.cpp:8529

Action14 root tags.

Definition at line 8543 of file newgrf.cpp.

Referenced by StaticGRFInfo().

◆ _ttdpatch_flags

uint32_t _ttdpatch_flags[8]
static

32 * 8 = 256 flags.

Apparently TTDPatch uses this many..

Definition at line 81 of file newgrf.cpp.

Referenced by InitializeGRFSpecial().

◆ MAX_SPRITEGROUP

const uint MAX_SPRITEGROUP = UINT8_MAX
static

Maximum GRF-local ID for a spritegroup.

Definition at line 86 of file newgrf.cpp.

◆ NUM_STATIONS_PER_GRF

const uint NUM_STATIONS_PER_GRF = UINT16_MAX - 1
static

The maximum amount of stations a single GRF is allowed to add.

Definition at line 312 of file newgrf.cpp.

Referenced by StationChangeInfo().