OpenTTD Source 20241224-master-gf74b0cf984
|
Different conversion functions from one kind of track to another. More...
#include "core/bitmath_func.hpp"
#include "track_type.h"
#include "direction_func.h"
#include "slope_func.h"
Go to the source code of this file.
Typedefs | |
using | SetTrackBitIterator = SetBitIterator< Track, TrackBits > |
using | SetTrackdirBitIterator = SetBitIterator< Trackdir, TrackdirBits > |
Functions | |
bool | IsValidTrack (Track track) |
Checks if a Track is valid. | |
bool | IsValidTrackdirForRoadVehicle (Trackdir trackdir) |
Checks if a Trackdir is valid for road vehicles. | |
bool | IsValidTrackdir (Trackdir trackdir) |
Checks if a Trackdir is valid for non-road vehicles. | |
Track | AxisToTrack (Axis a) |
Convert an Axis to the corresponding Track AXIS_X -> TRACK_X AXIS_Y -> TRACK_Y Uses the fact that they share the same internal encoding. | |
TrackBits | TrackToTrackBits (Track track) |
Maps a Track to the corresponding TrackBits value. | |
TrackBits | AxisToTrackBits (Axis a) |
Maps an Axis to the corresponding TrackBits value. | |
TrackBits | CornerToTrackBits (Corner corner) |
Returns a single horizontal/vertical trackbit that is in a specific tile corner. | |
TrackdirBits | TrackdirToTrackdirBits (Trackdir trackdir) |
Maps a Trackdir to the corresponding TrackdirBits value. | |
Track | RemoveFirstTrack (TrackBits *tracks) |
Removes first Track from TrackBits and returns it. | |
Trackdir | RemoveFirstTrackdir (TrackdirBits *trackdirs) |
Removes first Trackdir from TrackdirBits and returns it. | |
Track | FindFirstTrack (TrackBits tracks) |
Returns first Track from TrackBits or INVALID_TRACK. | |
Track | TrackBitsToTrack (TrackBits tracks) |
Converts TrackBits to Track. | |
Trackdir | FindFirstTrackdir (TrackdirBits trackdirs) |
Returns first Trackdir from TrackdirBits or INVALID_TRACKDIR. | |
Track | TrackToOppositeTrack (Track t) |
Find the opposite track to a given track. | |
Trackdir | ReverseTrackdir (Trackdir trackdir) |
Maps a trackdir to the reverse trackdir. | |
Track | TrackdirToTrack (Trackdir trackdir) |
Returns the Track that a given Trackdir represents. | |
Trackdir | TrackToTrackdir (Track track) |
Returns a Trackdir for the given Track. | |
TrackdirBits | TrackToTrackdirBits (Track track) |
Returns a TrackdirBit mask from a given Track. | |
TrackBits | TrackdirBitsToTrackBits (TrackdirBits bits) |
Discards all directional information from a TrackdirBits value. | |
TrackdirBits | TrackBitsToTrackdirBits (TrackBits bits) |
Converts TrackBits to TrackdirBits while allowing both directions. | |
bool | HasTrack (TrackBits tracks, Track track) |
Checks whether a TrackBits has a given Track. | |
bool | HasTrackdir (TrackdirBits trackdirs, Trackdir trackdir) |
Checks whether a TrackdirBits has a given Trackdir. | |
TrackdirBits | TrackStatusToTrackdirBits (TrackStatus ts) |
Returns the present-trackdir-information of a TrackStatus. | |
TrackBits | TrackStatusToTrackBits (TrackStatus ts) |
Returns the present-track-information of a TrackStatus. | |
TrackdirBits | TrackStatusToRedSignals (TrackStatus ts) |
Returns the red-signal-information of a TrackStatus. | |
TrackStatus | CombineTrackStatus (TrackdirBits trackdirbits, TrackdirBits red_signals) |
Builds a TrackStatus. | |
Trackdir | NextTrackdir (Trackdir trackdir) |
Maps a trackdir to the trackdir that you will end up on if you go straight ahead. | |
TrackBits | TrackCrossesTracks (Track track) |
Maps a track to all tracks that make 90 deg turns with it. | |
DiagDirection | TrackdirToExitdir (Trackdir trackdir) |
Maps a trackdir to the (4-way) direction the tile is exited when following that trackdir. | |
Trackdir | TrackExitdirToTrackdir (Track track, DiagDirection diagdir) |
Maps a track and an (4-way) dir to the trackdir that represents the track with the exit in the given direction. | |
Trackdir | TrackEnterdirToTrackdir (Track track, DiagDirection diagdir) |
Maps a track and an (4-way) dir to the trackdir that represents the track with the entry in the given direction. | |
Trackdir | TrackDirectionToTrackdir (Track track, Direction dir) |
Maps a track and a full (8-way) direction to the trackdir that represents the track running in the given direction. | |
Track | DiagDirToDiagTrack (DiagDirection diagdir) |
Maps a (4-way) direction to the diagonal track incidating with that diagdir. | |
TrackBits | DiagDirToDiagTrackBits (DiagDirection diagdir) |
Maps a (4-way) direction to the diagonal track bits incidating with that diagdir. | |
Trackdir | DiagDirToDiagTrackdir (DiagDirection diagdir) |
Maps a (4-way) direction to the diagonal trackdir that runs in that direction. | |
TrackdirBits | DiagdirReachesTrackdirs (DiagDirection diagdir) |
Returns all trackdirs that can be reached when entering a tile from a given (diagonal) direction. | |
TrackBits | DiagdirReachesTracks (DiagDirection diagdir) |
Returns all tracks that can be reached when entering a tile from a given (diagonal) direction. | |
TrackdirBits | TrackdirReachesTrackdirs (Trackdir trackdir) |
Maps a trackdir to the trackdirs that can be reached from it (ie, when entering the next tile. | |
TrackdirBits | TrackdirCrossesTrackdirs (Trackdir trackdir) |
Maps a trackdir to all trackdirs that make 90 deg turns with it. | |
bool | IsDiagonalTrack (Track track) |
Checks if a given Track is diagonal. | |
bool | IsDiagonalTrackdir (Trackdir trackdir) |
Checks if a given Trackdir is diagonal. | |
bool | TracksOverlap (TrackBits bits) |
Checks if the given tracks overlap, ie form a crossing. | |
bool | TrackOverlapsTracks (TrackBits tracks, Track track) |
Check if a given track is contained within or overlaps some other tracks. | |
bool | IsReversingRoadTrackdir (Trackdir dir) |
Checks whether the trackdir means that we are reversing. | |
bool | IsStraightRoadTrackdir (Trackdir dir) |
Checks whether the given trackdir is a straight road. | |
bool | IsUphillTrackdir (Slope slope, Trackdir dir) |
Checks whether a trackdir on a specific slope is going uphill. | |
DiagDirection | VehicleExitDir (Direction direction, TrackBits track) |
Determine the side in which the vehicle will leave the tile. | |
Different conversion functions from one kind of track to another.
Definition in file track_func.h.
using SetTrackBitIterator = SetBitIterator<Track, TrackBits> |
Definition at line 18 of file track_func.h.
Definition at line 19 of file track_func.h.
Convert an Axis to the corresponding Track AXIS_X -> TRACK_X AXIS_Y -> TRACK_Y Uses the fact that they share the same internal encoding.
a | the axis to convert |
Definition at line 66 of file track_func.h.
References IsValidAxis().
Referenced by AxisToTrackBits(), CmdBuildBridge(), CmdBuildRailStation(), CmdBuildRailWaypoint(), CmdBuildRoad(), GetCrossingRailTrack(), and GetRailStationTrack().
Maps an Axis to the corresponding TrackBits value.
a | the axis to convert |
Definition at line 88 of file track_func.h.
References AxisToTrack(), and TrackToTrackBits().
Referenced by GetCrossingRailBits(), and GetRailStationTrackBits().
|
inline |
Builds a TrackStatus.
trackdirbits | present trackdirs |
red_signals | red signals |
Definition at line 388 of file track_func.h.
Returns a single horizontal/vertical trackbit that is in a specific tile corner.
corner | The corner of a tile. |
Definition at line 99 of file track_func.h.
References IsValidCorner().
Referenced by DrawTrackBits(), FloodHalftile(), and GetRailFoundation().
|
inline |
Returns all trackdirs that can be reached when entering a tile from a given (diagonal) direction.
This will obviously include 90 degree turns, since no information is available about the exact angle of entering
diagdir | The joining direction |
Definition at line 555 of file track_func.h.
References DIAGDIR_END, and IsValidDiagDirection().
Referenced by CYapfFollowShipT< Types >::CheckShipReverse(), DiagdirReachesTracks(), CFollowTrackT< Ttr_type_, VehicleType, T90deg_turns_allowed_, Tmask_reserved_tracks >::Follow(), IsSafeWaitingPosition(), IsWaitingPositionFree(), MaskWireBits(), RoadFindPathToDest(), TrainCheckIfLineEnds(), TrainController(), TryPathReserve(), and CFollowTrackT< Ttr_type_, VehicleType, T90deg_turns_allowed_, Tmask_reserved_tracks >::TryReverse().
|
inline |
Returns all tracks that can be reached when entering a tile from a given (diagonal) direction.
This will obviously include 90 degree turns, since no information is available about the exact angle of entering
diagdir | The joining direction |
Definition at line 573 of file track_func.h.
References DiagdirReachesTrackdirs(), and TrackdirBitsToTrackBits().
Referenced by GetAvailShipTracks(), MaskWireBits(), PlaceExtraDepotRail(), and TryPathReserve().
|
inline |
Maps a (4-way) direction to the diagonal track incidating with that diagdir.
diagdir | The direction |
Definition at line 512 of file track_func.h.
References IsValidDiagDirection().
Referenced by CmdBuildTrainDepot(), CmdBuildTunnel(), CmdConvertRail(), DiagDirToDiagTrackBits(), DoClearBridge(), DoClearTunnel(), GetRailDepotTrack(), Train::ReserveTrackUnderConsist(), and TrainController().
|
inline |
Maps a (4-way) direction to the diagonal track bits incidating with that diagdir.
diagdir | The direction |
Definition at line 524 of file track_func.h.
References DiagDirToDiagTrack(), IsValidDiagDirection(), and TrackToTrackBits().
Referenced by AfterLoadGame(), CollectTrackbitsFromCrashedVehiclesEnum(), DeleteLastWagon(), GetRailTrackBitsUniversal(), and GetTunnelBridgeReservationTrackBits().
|
inline |
Maps a (4-way) direction to the diagonal trackdir that runs in that direction.
diagdir | The direction |
Definition at line 537 of file track_func.h.
References DIAGDIR_END, and IsValidDiagDirection().
Referenced by AfterLoadGame(), FollowReservation(), RoadVehicle::GetVehicleTrackdir(), Ship::GetVehicleTrackdir(), Train::GetVehicleTrackdir(), and CYapfCostRoadT< Types >::PfCalcCost().
Returns first Track from TrackBits or INVALID_TRACK.
This function returns the first Track found in the TrackBits value as Track-value. It returns INVALID_TRACK if the parameter is TRACK_BIT_NONE or INVALID_TRACK_BIT.
tracks | The TrackBits value |
Definition at line 177 of file track_func.h.
References FindFirstBit(), INVALID_TRACK, INVALID_TRACK_BIT, and TRACK_BIT_NONE.
Referenced by ChooseShipTrack(), FloodHalftile(), GenericPlaceSignals(), Ship::GetVehicleTrackdir(), Train::GetVehicleTrackdir(), ReverseTrainDirection(), TrainCheckIfLineEnds(), TrainController(), and YapfTrainChooseTrack().
|
inline |
Returns first Trackdir from TrackdirBits or INVALID_TRACKDIR.
This function returns the first Trackdir in the given TrackdirBits value or INVALID_TRACKDIR if the value is TRACKDIR_BIT_NONE. The TrackdirBits must not be INVALID_TRACKDIR_BIT.
trackdirs | The TrackdirBits value |
Definition at line 211 of file track_func.h.
References FindFirstBit(), INVALID_TRACKDIR, TRACKDIR_BIT_MASK, and TRACKDIR_BIT_NONE.
Referenced by CheckNextTrainTile(), ExtendTrainReservation(), FollowReservation(), CYapfFollowShipT< Types >::GetRandomTrackdir(), IsSafeWaitingPosition(), and TrainController().
Checks whether a TrackBits has a given Track.
tracks | The track bits. |
track | The track to check. |
Definition at line 329 of file track_func.h.
References HasBit(), and IsValidTrack().
|
inline |
Checks whether a TrackdirBits has a given Trackdir.
trackdirs | The trackdir bits. |
trackdir | The trackdir to check. |
Definition at line 340 of file track_func.h.
References HasBit(), and IsValidTrackdir().
Referenced by CYapfCostRailT< Types >::PfCalcCost(), CYapfDestinationTileOrStationRailT< Types >::PfDetectDestination(), CYapfFollowRoadT< Types >::SetOriginFromVehiclePos(), and YapfRoadVehicleFindNearestDepot().
|
inline |
Checks if a given Track is diagonal.
track | The given track to check |
Definition at line 619 of file track_func.h.
References IsValidTrack(), TRACK_X, and TRACK_Y.
Referenced by ChooseShipTrack(), and IsDiagonalTrackdir().
|
inline |
Checks if a given Trackdir is diagonal.
trackdir | The given trackdir |
Definition at line 631 of file track_func.h.
References IsDiagonalTrack(), IsValidTrackdir(), and TrackdirToTrack().
Referenced by CmdRailTrackHelper(), CmdSignalTrackHelper(), CYapfCostRailT< Types >::OneTileCost(), CYapfCostRoadT< Types >::OneTileCost(), CYapfCostShipT< Types >::PfCalcCost(), CYapfCostRailT< Types >::ReservationCost(), and CYapfCostBase::stSlopeCost().
|
inline |
Checks whether the trackdir means that we are reversing.
dir | the trackdir to check |
Definition at line 673 of file track_func.h.
References IsValidTrackdirForRoadVehicle().
Referenced by RoadVehicle::GetCurrentMaxSpeed(), RoadVehicle::GetVehicleTrackdir(), and RoadVehicle::HasToUseGetSlopePixelZ().
|
inline |
Checks whether the given trackdir is a straight road.
dir | the trackdir to check |
Definition at line 684 of file track_func.h.
References IsValidTrackdirForRoadVehicle().
Checks whether a trackdir on a specific slope is going uphill.
Valid for rail and road tracks. Valid for tile-slopes (under foundation) and foundation-slopes (on foundation).
slope | The slope of the tile. |
dir | The trackdir of interest. |
Definition at line 700 of file track_func.h.
References HasBit(), IsValidTrackdirForRoadVehicle(), and RemoveHalftileSlope().
Referenced by CYapfCostBase::stSlopeCost().
|
inline |
Checks if a Track is valid.
track | The value to check |
Definition at line 28 of file track_func.h.
References TRACK_END.
Referenced by GenericPlaceSignals(), HasSignalOnTrack(), HasTrack(), IsDiagonalTrack(), TrackCrossesTracks(), TrackDirectionToTrackdir(), TrackEnterdirToTrackdir(), TrackExitdirToTrackdir(), TrackToOppositeTrack(), TrackToTrackBits(), and TrackToTrackdir().
|
inline |
Checks if a Trackdir is valid for non-road vehicles.
trackdir | The value to check |
Definition at line 52 of file track_func.h.
References INVALID_TRACKDIR, TRACKDIR_BIT_MASK, and TRACKDIR_BIT_NONE.
Referenced by FreeTrainTrackReservation(), GetSignalStateByTrackdir(), HasSignalOnTrackdir(), HasTrackdir(), IsDiagonalTrackdir(), NextTrackdir(), TrackdirReachesTrackdirs(), TrackdirToTrack(), and TrackdirToTrackdirBits().
|
inline |
Checks if a Trackdir is valid for road vehicles.
trackdir | The value to check |
Definition at line 40 of file track_func.h.
References TRACKDIR_END.
Referenced by IsReversingRoadTrackdir(), IsStraightRoadTrackdir(), IsUphillTrackdir(), ReverseTrackdir(), TrackdirCrossesTrackdirs(), and TrackdirToExitdir().
Maps a trackdir to the trackdir that you will end up on if you go straight ahead.
This will be the same trackdir for diagonal trackdirs, but a different (alternating) one for straight trackdirs
trackdir | The given trackdir |
Definition at line 403 of file track_func.h.
References IsValidTrackdir(), and TRACKDIR_END.
Removes first Track from TrackBits and returns it.
This function searches for the first bit in the TrackBits, remove this bit from the parameter and returns the found bit as Track value. It returns INVALID_TRACK if the parameter was TRACK_BIT_NONE or INVALID_TRACK_BIT. This is basically used in while-loops to get up to 6 possible tracks on a tile until the parameter becomes TRACK_BIT_NONE.
tracks | The value with the TrackBits |
Definition at line 131 of file track_func.h.
References ClrBit(), FindFirstBit(), INVALID_TRACK, INVALID_TRACK_BIT, TRACK_BIT_MASK, and TRACK_BIT_NONE.
Referenced by ChangeOwnershipOfCompanyItems(), CheckFlatLandRailStation(), CmdConvertRail(), and SetTrackReservation().
|
inline |
Removes first Trackdir from TrackdirBits and returns it.
This function searches for the first bit in the TrackdirBits parameter, remove this bit from the parameter and returns the fnound bit as Trackdir value. It returns INVALID_TRACKDIR if the trackdirs is TRACKDIR_BIT_NONE or INVALID_TRACKDIR_BIT. This is basically used in a while-loop to get all track-directions step by step until the value reaches TRACKDIR_BIT_NONE.
trackdirs | The value with the TrackdirBits |
Definition at line 156 of file track_func.h.
References ClrBit(), FindFirstBit(), INVALID_TRACKDIR, INVALID_TRACKDIR_BIT, TRACKDIR_BIT_MASK, and TRACKDIR_BIT_NONE.
Referenced by FreeTrainTrackReservation(), CYapfFollowShipT< Types >::GetRandomTrackdir(), and CYapfCostRailT< Types >::PfCalcCost().
Maps a trackdir to the reverse trackdir.
Returns the reverse trackdir of a Trackdir value. The reverse trackdir is the same track with the other direction on it.
trackdir | The Trackdir value |
Definition at line 247 of file track_func.h.
References IsValidTrackdirForRoadVehicle().
Referenced by CYapfFollowShipT< Types >::CheckShipReverse(), CmdRemoveSingleSignal(), ExploreSegment(), ExtendTrainReservation(), FollowTrainReservation(), CFollowTrackT< Ttr_type_, VehicleType, T90deg_turns_allowed_, Tmask_reserved_tracks >::ForcedReverse(), FreeTrainReservation(), FreeTrainTrackReservation(), GetTrainForReservation(), HasOnewaySignalBlockingTrackdir(), CYapfCostRailT< Types >::IsAnyStationTileReserved(), IsSafeWaitingPosition(), CYapfCostRailT< Types >::PfCalcCost(), CYapfReserveTrack< Types >::ReserveSingleTrack(), RestoreTrainReservation(), TrackToTrackdirBits(), TrainController(), CYapfReserveTrack< Types >::UnreserveSingleTrack(), UpdateSignalsAroundSegment(), YapfTrainCheckReverse(), and YapfTrainFindNearestDepot().
Converts TrackBits to Track.
This function converts a TrackBits value to a Track value. As it is not possible to convert two or more tracks to one track the parameter must contain only one track or be the INVALID_TRACK_BIT value.
tracks | The TrackBits value to convert |
Definition at line 193 of file track_func.h.
References FindFirstBit(), INVALID_TRACK, INVALID_TRACK_BIT, KillFirstBit(), TRACK_BIT_MASK, and TRACK_BIT_NONE.
Referenced by ChooseShipTrack(), CmdRemoveSingleSignal(), DeleteLastWagon(), ExploreSegment(), Train::ReserveTrackUnderConsist(), and TrainController().
|
inline |
Converts TrackBits to TrackdirBits while allowing both directions.
bits | The TrackBits |
Definition at line 319 of file track_func.h.
Referenced by FollowReservation(), WaterRegion::ForceUpdate(), and FreeTrainTrackReservation().
Maps a track to all tracks that make 90 deg turns with it.
For the diagonal directions these are the complement of the direction, for the straight directions these are the two vertical or horizontal tracks, depend on the given direction
track | The given track |
Definition at line 420 of file track_func.h.
References IsValidTrack(), and TRACK_END.
|
inline |
Discards all directional information from a TrackdirBits value.
Any Track which is present in either direction will be present in the result.
bits | The TrackdirBits to get the TrackBits from |
Definition at line 308 of file track_func.h.
References TRACK_BIT_MASK.
Referenced by CheckNextTrainTile(), CheckRoadBlockedForOvertaking(), CmdRemoveSingleSignal(), DiagdirReachesTracks(), ExtendTrainReservation(), IsWaitingPositionFree(), MaskWireBits(), TrackStatusToTrackBits(), TrainCheckIfLineEnds(), TrainController(), and TryPathReserve().
|
inline |
Maps a trackdir to all trackdirs that make 90 deg turns with it.
For the diagonal tracks this returns the track direction bits of the other axis in both directions, which cannot be joined by the given track direction. For the straight tracks this returns all possible 90 deg turns either on the current tile (which no train can joined) or on the bordering tiles.
trackdir | The track direction |
Definition at line 606 of file track_func.h.
References IsValidTrackdirForRoadVehicle(), TRACK_END, and TrackdirToTrack().
Referenced by CFollowTrackT< Ttr_type_, VehicleType, T90deg_turns_allowed_, Tmask_reserved_tracks >::Follow().
Maps a track and a full (8-way) direction to the trackdir that represents the track running in the given direction.
Definition at line 498 of file track_func.h.
References DIR_END, IsValidDirection(), IsValidTrack(), and TRACK_END.
Referenced by Ship::GetVehicleTrackdir(), Train::GetVehicleTrackdir(), and TrainController().
|
inline |
Maps a trackdir to the trackdirs that can be reached from it (ie, when entering the next tile.
This will include 90 degree turns!
trackdir | The track direction which will be leaved |
Definition at line 584 of file track_func.h.
References DIAGDIR_END, IsValidTrackdir(), and TrackdirToExitdir().
Referenced by CmdRemoveSingleSignal(), and ExtendTrainReservation().
|
inline |
Maps a trackdir to the (4-way) direction the tile is exited when following that trackdir.
For the diagonal directions these are the same directions. For the straight directions these are the directions from the imagined base-tile to the bordering tile which will be joined if the given straight direction is leaved from the base-tile.
trackdir | The given track direction |
Definition at line 439 of file track_func.h.
References IsValidTrackdirForRoadVehicle(), and TRACKDIR_END.
Referenced by CFollowTrackT< Ttr_type_, VehicleType, T90deg_turns_allowed_, Tmask_reserved_tracks >::CanEnterNewTile(), ClearPathReservation(), CmdRemoveSingleSignal(), CFollowTrackT< Ttr_type_, VehicleType, T90deg_turns_allowed_, Tmask_reserved_tracks >::Follow(), FollowTrainReservation(), FreeTrainReservation(), FreeTrainTrackReservation(), GetTrainForReservation(), CYapfCostRailT< Types >::IsAnyStationTileReserved(), CYapfCostRoadT< Types >::OneTileCost(), CYapfCostRailT< Types >::PfCalcCost(), CYapfDestinationTileOrStationRailT< Types >::PfCalcEstimate(), CYapfDestinationTileRoadT< Types >::PfCalcEstimate(), CYapfDestinationTileWaterT< Types >::PfCalcEstimate(), CYapfReserveTrack< Types >::ReserveSingleTrack(), RestoreTrainReservation(), ReverseTrainDirection(), CYapfCostBase::stSlopeCost(), TrackdirReachesTrackdirs(), TrainController(), TryPathReserve(), CYapfReserveTrack< Types >::UnreserveSingleTrack(), UpdateSignalsAroundSegment(), and YapfTrainCheckReverse().
Returns the Track that a given Trackdir represents.
This function filters the Track which is used in the Trackdir value and returns it as a Track value.
trackdir | The trackdir value |
Definition at line 262 of file track_func.h.
References IsValidTrackdir().
Referenced by CheckNextTrainTile(), ChooseShipTrack(), ClearPathReservation(), CmdRailTrackHelper(), CmdSignalTrackHelper(), ExtendTrainReservation(), FindTrainOnTrackEnum(), FollowReservation(), FreeTrainTrackReservation(), GetSignalStateByTrackdir(), HasOnewaySignalBlockingTrackdir(), HasPbsSignalOnTrackdir(), IsDiagonalTrackdir(), IsSafeWaitingPosition(), IsWaitingPositionFree(), CYapfCostRailT< Types >::PfCalcCost(), CYapfDestinationTileOrStationRailT< Types >::PfDetectDestination(), CYapfCostRailT< Types >::ReservationCost(), CYapfReserveTrack< Types >::ReserveSingleTrack(), TrackdirCrossesTrackdirs(), TrainController(), TryPathReserve(), CYapfReserveTrack< Types >::UnreserveSingleTrack(), UpdateSignalsAroundSegment(), YapfShipChooseTrack(), and YapfTrainChooseTrack().
|
inline |
Maps a Trackdir to the corresponding TrackdirBits value.
trackdir | the track direction to convert |
Definition at line 111 of file track_func.h.
References IsValidTrackdir().
Referenced by CYapfFollowShipT< Types >::CheckShipReverse(), CYapfFollowRoadT< Types >::FindNearestDepot(), CFollowTrackT< Ttr_type_, VehicleType, T90deg_turns_allowed_, Tmask_reserved_tracks >::Follow(), CFollowTrackT< Ttr_type_, VehicleType, T90deg_turns_allowed_, Tmask_reserved_tracks >::ForcedReverse(), CYapfFollowRoadT< Types >::SetOriginFromVehiclePos(), TrackToTrackdirBits(), and YapfShipChooseTrack().
|
inline |
Maps a track and an (4-way) dir to the trackdir that represents the track with the entry in the given direction.
For the diagonal tracks the return value is clear, its either the matching track direction or INVALID_TRACKDIR. For the straight tracks this returns the track direction which results if you follow the DiagDirection and then turn by 45 deg left or right on the next tile. The new direction on the new track will be the returning Trackdir value. If the parameters makes no sense like the track TRACK_UPPER and the direction DIAGDIR_NE (target track cannot be reached) this function returns INVALID_TRACKDIR.
track | The target track |
diagdir | The direction to "come from" |
Definition at line 486 of file track_func.h.
References DIAGDIR_END, IsValidDiagDirection(), IsValidTrack(), and TRACK_END.
|
inline |
Maps a track and an (4-way) dir to the trackdir that represents the track with the exit in the given direction.
For the diagonal tracks the resulting track direction are clear for a given DiagDirection. It either matches the direction or it returns INVALID_TRACKDIR, as a TRACK_X cannot be applied with DIAG_SE. For the straight tracks the resulting track direction will be the direction which the DiagDirection is pointing. But this will be INVALID_TRACKDIR if the DiagDirection is pointing 'away' the track.
track | The track to apply an direction on |
diagdir | The DiagDirection to apply on |
Definition at line 461 of file track_func.h.
References DIAGDIR_END, IsValidDiagDirection(), IsValidTrack(), and TRACK_END.
Check if a given track is contained within or overlaps some other tracks.
tracks | Tracks to be tested against |
track | The track to test |
Definition at line 662 of file track_func.h.
References HasBit(), TracksOverlap(), and TrackToTrackBits().
Referenced by IsWaitingPositionFree(), and CYapfCostRailT< Types >::ReservationCost().
|
inline |
Checks if the given tracks overlap, ie form a crossing.
Basically this means when there is more than one track on the tile, except when there are two parallel tracks.
bits | The tracks present. |
Definition at line 645 of file track_func.h.
References KillFirstBit(), TRACK_BIT_HORZ, TRACK_BIT_NONE, and TRACK_BIT_VERT.
Referenced by CmdBuildSingleRail(), CmdBuildSingleSignal(), CmdConvertRail(), CmdRemoveSingleRail(), FreeTrainTrackReservation(), GetRailFoundation(), MaskWireBits(), SetTrackReservation(), TrackOverlapsTracks(), and TryReserveTrack().
|
inline |
Returns the red-signal-information of a TrackStatus.
Note: The result may contain red signals for non-present tracks.
ts | The TrackStatus returned by GetTileTrackStatus() |
Definition at line 376 of file track_func.h.
References TRACKDIR_BIT_MASK.
Referenced by CheckRoadBlockedForOvertaking(), RoadFindPathToDest(), TrainCheckIfLineEnds(), and TrainController().
|
inline |
Returns the present-track-information of a TrackStatus.
ts | The TrackStatus returned by GetTileTrackStatus() |
Definition at line 363 of file track_func.h.
References TrackdirBitsToTrackBits(), and TrackStatusToTrackdirBits().
Referenced by AfterLoadGame(), DisasterTick_Submarine(), GenericPlaceSignals(), MaskWireBits(), RoadVehicle::TileMayHaveSlopedTrack(), TryReserveRailTrack(), UnreserveRailTrack(), and UpdateSignalsInBuffer().
|
inline |
Returns the present-trackdir-information of a TrackStatus.
ts | The TrackStatus returned by GetTileTrackStatus() |
Definition at line 352 of file track_func.h.
References TRACKDIR_BIT_MASK.
Referenced by CheckRoadBlockedForOvertaking(), CYapfFollowShipT< Types >::CheckShipReverse(), CFollowTrackT< Ttr_type_, VehicleType, T90deg_turns_allowed_, Tmask_reserved_tracks >::Follow(), GetTrackdirBitsForRoad(), CFollowTrackT< Ttr_type_, VehicleType, T90deg_turns_allowed_, Tmask_reserved_tracks >::QueryNewTileTrackStatus(), RoadFindPathToDest(), TrackStatusToTrackBits(), TrainCheckIfLineEnds(), TrainController(), and TryPathReserve().
Find the opposite track to a given track.
TRACK_LOWER -> TRACK_UPPER and vice versa, likewise for left/right. TRACK_X is mapped to TRACK_Y and reversed.
t | the track to convert |
Definition at line 231 of file track_func.h.
References IsValidTrack().
Referenced by ChooseShipTrack(), and GetRailReservationTrackBits().
Maps a Track to the corresponding TrackBits value.
track | the track to convert |
Definition at line 77 of file track_func.h.
References IsValidTrack().
Referenced by AdvanceWagonsAfterSwap(), AxisToTrackBits(), CmdBuildSingleRail(), CmdBuildSingleSignal(), CmdRemoveSingleRail(), CmdRemoveSingleSignal(), DiagDirToDiagTrackBits(), EnsureNoTrainOnTrack(), FixupTrainLengths(), FollowReservation(), FreeTrainTrackReservation(), GetDepotReservationTrackBits(), GetRailReservationTrackBits(), GetRailTrackBitsUniversal(), GetTrainForReservation(), RemoveFromRailBaseStation(), TrackOverlapsTracks(), TrainController(), TryReserveTrack(), and UpdateSignalsAroundSegment().
Returns a Trackdir for the given Track.
Since every Track corresponds to two Trackdirs, we choose the one which points between NE and S. Note that the actual implementation is quite futile, but this might change in the future.
track | The given Track |
Definition at line 279 of file track_func.h.
References IsValidTrack().
Referenced by CmdRailTrackHelper(), CmdRemoveSingleSignal(), CmdSignalTrackHelper(), GetTrainForReservation(), and TrackToTrackdirBits().
|
inline |
Returns a TrackdirBit mask from a given Track.
The TrackdirBit mask contains the two TrackdirBits that correspond with the given Track (one for each direction).
track | The track to get the TrackdirBits from |
Definition at line 294 of file track_func.h.
References ReverseTrackdir(), TrackdirToTrackdirBits(), and TrackToTrackdir().
|
inline |
Determine the side in which the vehicle will leave the tile.
direction | vehicle direction |
track | vehicle track bits |
Definition at line 714 of file track_func.h.
References ChangeDiagDir(), DIAGDIR_END, DIAGDIRDIFF_90LEFT, DirToDiagDir(), HasBit(), TRACK_BIT_LEFT, TRACK_BIT_LOWER, TRACK_BIT_RIGHT, and TRACK_BIT_UPPER.
Referenced by CYapfFollowShipT< Types >::CheckShipReverse(), ReverseTrainDirection(), TrainApproachingCrossingTile(), and TrainCheckIfLineEnds().