OpenTTD Source  20240917-master-g9ab0a47812
clear_map.h File Reference
#include "bridge_map.h"
#include "industry_type.h"

Go to the source code of this file.

Enumerations

enum  ClearGround {
  CLEAR_GRASS = 0, CLEAR_ROUGH = 1, CLEAR_ROCKS = 2, CLEAR_FIELDS = 3,
  CLEAR_SNOW = 4, CLEAR_DESERT = 5
}
 Ground types. More...
 

Functions

bool IsSnowTile (Tile t)
 Test if a tile is covered with snow. More...
 
ClearGround GetRawClearGround (Tile t)
 Get the type of clear tile but never return CLEAR_SNOW. More...
 
ClearGround GetClearGround (Tile t)
 Get the type of clear tile. More...
 
bool IsClearGround (Tile t, ClearGround ct)
 Set the type of clear tile. More...
 
uint GetClearDensity (Tile t)
 Get the density of a non-field clear tile. More...
 
void AddClearDensity (Tile t, int d)
 Increment the density of a non-field clear tile. More...
 
void SetClearDensity (Tile t, uint d)
 Set the density of a non-field clear tile. More...
 
uint GetClearCounter (Tile t)
 Get the counter used to advance to the next clear density/field type. More...
 
void AddClearCounter (Tile t, int c)
 Increments the counter used to advance to the next clear density/field type. More...
 
void SetClearCounter (Tile t, uint c)
 Sets the counter used to advance to the next clear density/field type. More...
 
void SetClearGroundDensity (Tile t, ClearGround type, uint density)
 Sets ground type and density in one go, also sets the counter to 0. More...
 
uint GetFieldType (Tile t)
 Get the field type (production stage) of the field. More...
 
void SetFieldType (Tile t, uint f)
 Set the field type (production stage) of the field. More...
 
IndustryID GetIndustryIndexOfField (Tile t)
 Get the industry (farm) that made the field. More...
 
void SetIndustryIndexOfField (Tile t, IndustryID i)
 Set the industry (farm) that made the field. More...
 
uint GetFence (Tile t, DiagDirection side)
 Is there a fence at the given border? More...
 
void SetFence (Tile t, DiagDirection side, uint h)
 Sets the type of fence (and whether there is one) for the given border. More...
 
void MakeClear (Tile t, ClearGround g, uint density)
 Make a clear tile. More...
 
void MakeField (Tile t, uint field_type, IndustryID industry)
 Make a (farm) field tile. More...
 
void MakeSnow (Tile t, uint density=0)
 Make a snow tile. More...
 
void ClearSnow (Tile t)
 Clear the snow from a tile and return it to its previous type. More...
 

Detailed Description

Map accessors for 'clear' tiles

Definition in file clear_map.h.

Enumeration Type Documentation

◆ ClearGround

Ground types.

Valid densities in comments after the enum.

Enumerator
CLEAR_GRASS 

0-3

CLEAR_ROUGH 

3

CLEAR_ROCKS 

3

CLEAR_FIELDS 

3

CLEAR_SNOW 

0-3

CLEAR_DESERT 

1,3

Definition at line 19 of file clear_map.h.

Function Documentation

◆ AddClearCounter()

void AddClearCounter ( Tile  t,
int  c 
)
inline

Increments the counter used to advance to the next clear density/field type.

Parameters
tthe tile to increment the counter of
cthe amount to increment the counter with
Precondition
IsTileType(t, MP_CLEAR)

Definition at line 132 of file clear_map.h.

References IsTileType(), Tile::m5(), and MP_CLEAR.

◆ AddClearDensity()

void AddClearDensity ( Tile  t,
int  d 
)
inline

Increment the density of a non-field clear tile.

Parameters
tthe tile to increment the density of
dthe amount to increment the density with
Precondition
IsTileType(t, MP_CLEAR)

Definition at line 95 of file clear_map.h.

References IsTileType(), Tile::m5(), and MP_CLEAR.

Referenced by TileLoopClearAlps().

◆ ClearSnow()

void ClearSnow ( Tile  t)
inline

Clear the snow from a tile and return it to its previous type.

Parameters
tthe tile to clear of snow
Precondition
GetClearGround(t) == CLEAR_SNOW

Definition at line 316 of file clear_map.h.

References CLEAR_SNOW, ClrBit(), GetClearGround(), Tile::m3(), and SetClearDensity().

Referenced by TileLoopClearAlps().

◆ GetClearCounter()

uint GetClearCounter ( Tile  t)
inline

Get the counter used to advance to the next clear density/field type.

Parameters
tthe tile to get the counter of
Precondition
IsTileType(t, MP_CLEAR)
Returns
the value of the counter

Definition at line 120 of file clear_map.h.

References GB(), IsTileType(), Tile::m5(), and MP_CLEAR.

◆ GetClearDensity()

uint GetClearDensity ( Tile  t)
inline

Get the density of a non-field clear tile.

Parameters
tthe tile to get the density of
Precondition
IsTileType(t, MP_CLEAR)
Returns
the density

Definition at line 83 of file clear_map.h.

References GB(), IsTileType(), Tile::m5(), and MP_CLEAR.

Referenced by GetSmallMapVegetationPixels(), PlantTreesOnTile(), and TileLoopClearAlps().

◆ GetClearGround()

ClearGround GetClearGround ( Tile  t)
inline

Get the type of clear tile.

Parameters
tthe tile to get the clear ground type of
Precondition
IsTileType(t, MP_CLEAR)
Returns
the ground type

Definition at line 59 of file clear_map.h.

References CLEAR_SNOW, GetRawClearGround(), and IsSnowTile().

Referenced by ClearSnow(), GetFieldType(), GetIndustryIndexOfField(), IsClearGround(), MakeSnow(), PlantTreesOnTile(), SetFieldType(), and SetIndustryIndexOfField().

◆ GetFence()

uint GetFence ( Tile  t,
DiagDirection  side 
)
inline

Is there a fence at the given border?

Parameters
tthe tile to check for fences
sidethe border to check
Precondition
IsClearGround(t, CLEAR_FIELDS)
Returns
0 if there is no fence, otherwise the fence type

Definition at line 221 of file clear_map.h.

References CLEAR_FIELDS, and IsClearGround().

Referenced by SetupFarmFieldFence().

◆ GetFieldType()

uint GetFieldType ( Tile  t)
inline

Get the field type (production stage) of the field.

Parameters
tthe field to get the type of
Precondition
GetClearGround(t) == CLEAR_FIELDS
Returns
the field type

Definition at line 171 of file clear_map.h.

References CLEAR_FIELDS, GB(), GetClearGround(), and Tile::m3().

◆ GetIndustryIndexOfField()

IndustryID GetIndustryIndexOfField ( Tile  t)
inline

Get the industry (farm) that made the field.

Parameters
tthe field to get creating industry of
Precondition
GetClearGround(t) == CLEAR_FIELDS
Returns
the industry that made the field

Definition at line 195 of file clear_map.h.

References CLEAR_FIELDS, GetClearGround(), and Tile::m2().

◆ GetRawClearGround()

ClearGround GetRawClearGround ( Tile  t)
inline

Get the type of clear tile but never return CLEAR_SNOW.

Parameters
tthe tile to get the clear ground type of
Precondition
IsTileType(t, MP_CLEAR)
Returns
the ground type

Definition at line 47 of file clear_map.h.

References GB(), IsTileType(), Tile::m5(), and MP_CLEAR.

Referenced by CanPlantTreesOnTile(), GetClearGround(), MakeSnow(), and PlantTreesOnTile().

◆ IsClearGround()

bool IsClearGround ( Tile  t,
ClearGround  ct 
)
inline

Set the type of clear tile.

Parameters
tthe tile to set the clear ground type of
ctthe ground type
Precondition
IsTileType(t, MP_CLEAR)

Definition at line 71 of file clear_map.h.

References GetClearGround().

Referenced by CanPlantTreesOnTile(), GetFence(), GetSmallMapVegetationPixels(), IsSuitableForFarmField(), SetFence(), and SetupFarmFieldFence().

◆ IsSnowTile()

bool IsSnowTile ( Tile  t)
inline

Test if a tile is covered with snow.

Parameters
tthe tile to check
Precondition
IsTileType(t, MP_CLEAR)
Returns
whether the tile is covered with snow.

Definition at line 35 of file clear_map.h.

References HasBit(), IsTileType(), Tile::m3(), and MP_CLEAR.

Referenced by GetClearGround(), and TileLoopClearAlps().

◆ MakeClear()

void MakeClear ( Tile  t,
ClearGround  g,
uint  density 
)
inline

Make a clear tile.

Parameters
tthe tile to make a clear tile
gthe type of ground
densitythe density of the grass/snow/desert etc

Definition at line 259 of file clear_map.h.

References Tile::m1(), Tile::m2(), Tile::m3(), Tile::m4(), Tile::m6(), Tile::m7(), Tile::m8(), MP_CLEAR, OWNER_NONE, SetClearGroundDensity(), SetTileOwner(), and SetTileType().

Referenced by TgenSetTileHeight().

◆ MakeField()

void MakeField ( Tile  t,
uint  field_type,
IndustryID  industry 
)
inline

Make a (farm) field tile.

Parameters
tthe tile to make a farm field
field_typethe 'growth' level of the field
industrythe industry this tile belongs to

Definition at line 280 of file clear_map.h.

References CLEAR_FIELDS, Tile::m1(), Tile::m2(), Tile::m3(), Tile::m4(), Tile::m6(), Tile::m7(), Tile::m8(), MP_CLEAR, OWNER_NONE, SB(), SetClearGroundDensity(), SetTileOwner(), and SetTileType().

◆ MakeSnow()

void MakeSnow ( Tile  t,
uint  density = 0 
)
inline

Make a snow tile.

Parameters
tthe tile to make snowy
densityThe density of snowiness.
Precondition
GetClearGround(t) != CLEAR_SNOW

Definition at line 300 of file clear_map.h.

References CLEAR_FIELDS, CLEAR_GRASS, CLEAR_SNOW, GetClearGround(), GetRawClearGround(), Tile::m3(), SetBit(), SetClearDensity(), and SetClearGroundDensity().

Referenced by TileLoopClearAlps().

◆ SetClearCounter()

void SetClearCounter ( Tile  t,
uint  c 
)
inline

Sets the counter used to advance to the next clear density/field type.

Parameters
tthe tile to set the counter of
cthe amount to set the counter to
Precondition
IsTileType(t, MP_CLEAR)

Definition at line 144 of file clear_map.h.

References IsTileType(), Tile::m5(), MP_CLEAR, and SB().

◆ SetClearDensity()

void SetClearDensity ( Tile  t,
uint  d 
)
inline

Set the density of a non-field clear tile.

Parameters
tthe tile to set the density of
dthe new density
Precondition
IsTileType(t, MP_CLEAR)

Definition at line 107 of file clear_map.h.

References IsTileType(), Tile::m5(), MP_CLEAR, and SB().

Referenced by ClearSnow(), and MakeSnow().

◆ SetClearGroundDensity()

void SetClearGroundDensity ( Tile  t,
ClearGround  type,
uint  density 
)
inline

Sets ground type and density in one go, also sets the counter to 0.

Parameters
tthe tile to set the ground type and density for
typethe new ground type of the tile
densitythe density of the ground tile
Precondition
IsTileType(t, MP_CLEAR)

Definition at line 158 of file clear_map.h.

References IsTileType(), Tile::m5(), and MP_CLEAR.

Referenced by MakeClear(), MakeField(), and MakeSnow().

◆ SetFence()

void SetFence ( Tile  t,
DiagDirection  side,
uint  h 
)
inline

Sets the type of fence (and whether there is one) for the given border.

Parameters
tthe tile to check for fences
sidethe border to check
h0 if there is no fence, otherwise the fence type
Precondition
IsClearGround(t, CLEAR_FIELDS)

Definition at line 240 of file clear_map.h.

References CLEAR_FIELDS, and IsClearGround().

Referenced by SetupFarmFieldFence().

◆ SetFieldType()

void SetFieldType ( Tile  t,
uint  f 
)
inline

Set the field type (production stage) of the field.

Parameters
tthe field to get the type of
fthe field type
Precondition
GetClearGround(t) == CLEAR_FIELDS

Definition at line 183 of file clear_map.h.

References CLEAR_FIELDS, GetClearGround(), Tile::m3(), and SB().

◆ SetIndustryIndexOfField()

void SetIndustryIndexOfField ( Tile  t,
IndustryID  i 
)
inline

Set the industry (farm) that made the field.

Parameters
tthe field to get creating industry of
ithe industry that made the field
Precondition
GetClearGround(t) == CLEAR_FIELDS

Definition at line 207 of file clear_map.h.

References CLEAR_FIELDS, GetClearGround(), and Tile::m2().