Public Member Functions | Static Public Member Functions | Data Fields | Static Private Attributes | Friends
CargoSpec Struct Reference

Specification of a cargo type. More...

#include <cargotype.h>

Public Member Functions

CargoID Index () const
 Determines index of this cargospec. More...
bool IsValid () const
 Tests for validity of this cargospec. More...
SpriteID GetCargoIcon () const
 Get sprite for showing cargo of this type. More...

Static Public Member Functions

static size_t GetArraySize ()
 Total number of cargospecs, both valid and invalid. More...
static CargoSpecGet (size_t index)
 Retrieve cargo details for the given cargo ID. More...

Data Fields

uint8 bitnum
 Cargo bit number, is INVALID_CARGO for a non-used spec.
CargoLabel label
 Unique label of the cargo type.
uint8 legend_colour
uint8 rating_colour
uint8 weight
 Weight of a single unit of this cargo type in 1/16 ton (62.5 kg).
uint16 multiplier
 Capacity multiplier for vehicles. (8 fractional bits)
uint16 initial_payment
uint8 transit_days [2]
bool is_freight
 Cargo type is considered to be freight (affects train freight multiplier).
TownEffect town_effect
 The effect that delivering this cargo type has on towns. Also affects destination of subsidies.
uint16 multipliertowngrowth
 Size of the effect.
uint8 callback_mask
 Bitmask of cargo callbacks that have to be called.
StringID name
 Name of this type of cargo.
StringID name_single
 Name of a single entity of this type of cargo.
StringID units_volume
 Name of a single unit of cargo of this type.
StringID quantifier
 Text for multiple units of cargo of this type.
StringID abbrev
 Two letter abbreviation for this cargo type.
SpriteID sprite
 Icon to display this cargo type, may be 0xFFF (which means to resolve an action123 chain).
uint16 classes
 Classes of this cargo type. More...
const struct GRFFilegrffile
 NewGRF where #group belongs to.
const struct SpriteGroupgroup
Money current_payment

Static Private Attributes

static CargoSpec array [NUM_CARGO]
 Array holding all CargoSpecs.


void SetupCargoForClimate (LandscapeID l)
 Set up the default cargo types for the given landscape type. More...

Detailed Description

Specification of a cargo type.

Definition at line 56 of file cargotype.h.

Member Function Documentation

◆ Get()

static CargoSpec* CargoSpec::Get ( size_t  index)

◆ GetArraySize()

static size_t CargoSpec::GetArraySize ( )

Total number of cargospecs, both valid and invalid.

length of CargoSpec::array

Definition at line 108 of file cargotype.h.

References array, and lengthof.

◆ GetCargoIcon()

SpriteID CargoSpec::GetCargoIcon ( ) const

Get sprite for showing cargo of this type.

Sprite number to use.

Definition at line 122 of file cargotype.cpp.

References GetCustomCargoSprite(), and sprite.

◆ Index()

CargoID CargoSpec::Index ( ) const

Determines index of this cargospec.

index (in the CargoSpec::array array)

Definition at line 89 of file cargotype.h.

References array.

Referenced by BuildLinkStatsLegend(), RefitWindow::BuildRefitList(), BuildVehicleWindow::SetCargoFilterArray(), CompanyStationsWindow::SortStationsList(), and TruncateCargo().

◆ IsValid()

bool CargoSpec::IsValid ( ) const

Tests for validity of this cargospec.

is this cargospec valid?
assert(cs->IsValid()) can be triggered when GRF config is modified

Definition at line 99 of file cargotype.h.


Referenced by BuildCargoTranslationMap(), CargoChangeInfo(), FinaliseCargoArray(), IndustryCargoesWindow::OnInit(), and TownHouseChangeInfo().

Friends And Related Function Documentation

◆ SetupCargoForClimate

void SetupCargoForClimate ( LandscapeID  l)

Set up the default cargo types for the given landscape type.


Definition at line 42 of file cargotype.cpp.

Field Documentation

◆ classes

uint16 CargoSpec::classes

Classes of this cargo type.

See also

Definition at line 79 of file cargotype.h.

Referenced by CargoChangeInfo(), CMSAMine(), GetRefitCostFactor(), VehicleScopeResolver::GetVariable(), and IsCargoInClass().

The documentation for this struct was generated from the following files: