OpenTTD Source 20260531-master-g0e951f3528
track_data.h File Reference

Data related to rail tracks. More...

Go to the source code of this file.

Variables

const DiagDirectionIndexArray< TrackdirBits_exitdir_reaches_trackdirs
 Maps a diagonal direction to the all trackdirs that are connected to any track entering in this direction (including those making 90 degree turns).
const TrackdirIndexArray< Trackdir_next_trackdir
 Next trackdir to use when moving to a new tile for each current trackdir.
const TrackIndexArray< TrackdirBits_track_crosses_trackdirs
 Maps a trackdir to all trackdirs that make 90 deg turns with it.
const TrackIndexArray< TrackBits_track_crosses_tracks
 Maps a track to all tracks that make 90 deg turns with it.
const TrackdirIndexArray< DiagDirection_trackdir_to_exitdir
 Maps a trackdir to the (4-way) direction the tile is exited when following that trackdir.
const TrackIndexArray< DiagDirectionIndexArray< Trackdir > > _track_exitdir_to_trackdir
 Maps a track and an (4-way) dir to the trackdir that represents the track with the exit in the given direction.
const TrackIndexArray< DiagDirectionIndexArray< Trackdir > > _track_enterdir_to_trackdir
 Maps a track and an (4-way) dir to the trackdir that represents the track with the entry in the given direction.
const TrackIndexArray< DirectionIndexArray< Trackdir > > _track_direction_to_trackdir
 Maps a track and a full (8-way) direction to the trackdir that represents the track running in the given direction.
const DiagDirectionIndexArray< Trackdir_dir_to_diag_trackdir
 Maps a (4-way) direction to the diagonal trackdir that runs in that direction.
const CornerIndexArray< TrackBits_corner_to_trackbits
 Maps a single horizontal/vertical trackbit that is in a specific tile corner.
const TrackdirBits _uphill_trackdirs []

Detailed Description

Data related to rail tracks.

Definition in file track_data.h.

Variable Documentation

◆ _corner_to_trackbits

const CornerIndexArray<TrackBits> _corner_to_trackbits
extern
Initial value:
{
}
@ TRACK_BIT_UPPER
Upper track.
Definition track_type.h:46
@ TRACK_BIT_LEFT
Left track.
Definition track_type.h:48
@ TRACK_BIT_LOWER
Lower track.
Definition track_type.h:47
@ TRACK_BIT_RIGHT
Right track.
Definition track_type.h:49

Maps a single horizontal/vertical trackbit that is in a specific tile corner.

Referenced by CornerToTrackBits().

◆ _dir_to_diag_trackdir

const DiagDirectionIndexArray<Trackdir> _dir_to_diag_trackdir
extern
Initial value:
{
}
@ TRACKDIR_X_NE
X-axis and direction to north-east.
Definition track_type.h:75
@ TRACKDIR_Y_SE
Y-axis and direction to south-east.
Definition track_type.h:76
@ TRACKDIR_X_SW
X-axis and direction to south-west.
Definition track_type.h:83
@ TRACKDIR_Y_NW
Y-axis and direction to north-west.
Definition track_type.h:84

Maps a (4-way) direction to the diagonal trackdir that runs in that direction.

Referenced by DiagDirToDiagTrackdir().

◆ _exitdir_reaches_trackdirs

const DiagDirectionIndexArray<TrackdirBits> _exitdir_reaches_trackdirs
extern
Initial value:
{
}
@ TRACKDIR_BIT_LEFT_S
Track left, direction south.
Definition track_type.h:117
@ TRACKDIR_BIT_Y_NW
Track y-axis, direction north-west.
Definition track_type.h:121
@ TRACKDIR_BIT_UPPER_E
Track upper, direction east.
Definition track_type.h:115
@ TRACKDIR_BIT_X_NE
Track x-axis, direction north-east.
Definition track_type.h:113
@ TRACKDIR_BIT_LOWER_E
Track lower, direction east.
Definition track_type.h:116
@ TRACKDIR_BIT_LEFT_N
Track left, direction north.
Definition track_type.h:124
@ TRACKDIR_BIT_RIGHT_S
Track right, direction south.
Definition track_type.h:118
@ TRACKDIR_BIT_Y_SE
Track y-axis, direction south-east.
Definition track_type.h:114
@ TRACKDIR_BIT_RIGHT_N
Track right, direction north.
Definition track_type.h:125
@ TRACKDIR_BIT_UPPER_W
Track upper, direction west.
Definition track_type.h:122
@ TRACKDIR_BIT_LOWER_W
Track lower, direction west.
Definition track_type.h:123
@ TRACKDIR_BIT_X_SW
Track x-axis, direction south-west.
Definition track_type.h:120

Maps a diagonal direction to the all trackdirs that are connected to any track entering in this direction (including those making 90 degree turns).

Referenced by DiagdirReachesTrackdirs(), and TrackdirReachesTrackdirs().

◆ _next_trackdir

const TrackdirIndexArray<Trackdir> _next_trackdir
extern
Initial value:
{
}
@ TRACKDIR_LOWER_E
Lower track and direction to east.
Definition track_type.h:78
@ TRACKDIR_RIGHT_N
Right track and direction to north.
Definition track_type.h:88
@ INVALID_TRACKDIR
Flag for an invalid trackdir.
Definition track_type.h:92
@ TRACKDIR_UPPER_E
Upper track and direction to east.
Definition track_type.h:77
@ TRACKDIR_LEFT_S
Left track and direction to south.
Definition track_type.h:79
@ TRACKDIR_UPPER_W
Upper track and direction to west.
Definition track_type.h:85
@ TRACKDIR_LOWER_W
Lower track and direction to west.
Definition track_type.h:86
@ TRACKDIR_RIGHT_S
Right track and direction to south.
Definition track_type.h:80
@ TRACKDIR_LEFT_N
Left track and direction to north.
Definition track_type.h:87

Next trackdir to use when moving to a new tile for each current trackdir.

Referenced by NextTrackdir().

◆ _track_crosses_trackdirs

◆ _track_crosses_tracks

const TrackIndexArray<TrackBits> _track_crosses_tracks
extern
Initial value:
{
}
@ TRACK_BIT_Y
Y-axis track.
Definition track_type.h:45
@ TRACK_BIT_HORZ
Upper and lower track.
Definition track_type.h:51
@ TRACK_BIT_X
X-axis track.
Definition track_type.h:44
@ TRACK_BIT_VERT
Left and right track.
Definition track_type.h:52

Maps a track to all tracks that make 90 deg turns with it.

Referenced by TrackCrossesTracks().

◆ _track_direction_to_trackdir

◆ _track_enterdir_to_trackdir

◆ _track_exitdir_to_trackdir

◆ _trackdir_to_exitdir

const TrackdirIndexArray<DiagDirection> _trackdir_to_exitdir
extern
Initial value:

Maps a trackdir to the (4-way) direction the tile is exited when following that trackdir.

Referenced by TrackdirToExitdir().