diff options
author | KUDr <kudr@openttd.org> | 2007-01-10 18:12:09 +0000 |
---|---|---|
committer | KUDr <kudr@openttd.org> | 2007-01-10 18:12:09 +0000 |
commit | e373ea7096c741a8189f7a480863fd21dd6f6be1 (patch) | |
tree | d9abc3d9810159441bed9f82a52bd1ee52d770dd /src/road_map.cpp | |
parent | 001d858b528d78743deaf7dcea46ea8f0736bad9 (diff) | |
download | openttd-e373ea7096c741a8189f7a480863fd21dd6f6be1.tar.xz |
(svn r8033) [cpp] - Prepare for merge from branches/cpp (all .c files renamed to .cpp)
Diffstat (limited to 'src/road_map.cpp')
-rw-r--r-- | src/road_map.cpp | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/src/road_map.cpp b/src/road_map.cpp new file mode 100644 index 000000000..cccd2e76a --- /dev/null +++ b/src/road_map.cpp @@ -0,0 +1,54 @@ +/* $Id$ */ + +#include "stdafx.h" +#include "openttd.h" +#include "bridge_map.h" +#include "functions.h" +#include "road_map.h" +#include "station.h" +#include "tunnel_map.h" +#include "station_map.h" +#include "depot.h" + + +RoadBits GetAnyRoadBits(TileIndex tile) +{ + switch (GetTileType(tile)) { + case MP_STREET: + switch (GetRoadTileType(tile)) { + default: + case ROAD_TILE_NORMAL: return GetRoadBits(tile); + case ROAD_TILE_CROSSING: return GetCrossingRoadBits(tile); + case ROAD_TILE_DEPOT: return DiagDirToRoadBits(GetRoadDepotDirection(tile)); + } + + case MP_STATION: + if (!IsRoadStopTile(tile)) return 0; + return DiagDirToRoadBits(GetRoadStopDir(tile)); + + case MP_TUNNELBRIDGE: + if (IsTunnel(tile)) { + if (GetTunnelTransportType(tile) != TRANSPORT_ROAD) return 0; + return DiagDirToRoadBits(ReverseDiagDir(GetTunnelDirection(tile))); + } else { + if (GetBridgeTransportType(tile) != TRANSPORT_ROAD) return 0; + return DiagDirToRoadBits(ReverseDiagDir(GetBridgeRampDirection(tile))); + } + + default: return 0; + } +} + + +TrackBits GetAnyRoadTrackBits(TileIndex tile) +{ + uint32 r; + + // Don't allow local authorities to build roads through road depots or road stops. + if ((IsTileType(tile, MP_STREET) && IsTileDepotType(tile, TRANSPORT_ROAD)) || IsTileType(tile, MP_STATION)) { + return 0; + } + + r = GetTileTrackStatus(tile, TRANSPORT_ROAD); + return (byte)(r | (r >> 8)); +} |