diff options
author | yexo <yexo@openttd.org> | 2009-02-19 07:40:08 +0000 |
---|---|---|
committer | yexo <yexo@openttd.org> | 2009-02-19 07:40:08 +0000 |
commit | 69df9f278732429ea2a1c66897c15bb53a5e4c15 (patch) | |
tree | fa0d25f1d5a2c7fdfd64122bd10dc5ee7291d2fe /src/ai/api/ai_rail.cpp | |
parent | 29173de379eaa1f8c7a1a409ad0232a748172906 (diff) | |
download | openttd-69df9f278732429ea2a1c66897c15bb53a5e4c15.tar.xz |
(svn r15519) -Add [NoAI]: support for waypoints by adding AIRail::Build/Remove RailWaypoint, AIWaypoint and AIWaypointList.
Diffstat (limited to 'src/ai/api/ai_rail.cpp')
-rw-r--r-- | src/ai/api/ai_rail.cpp | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/src/ai/api/ai_rail.cpp b/src/ai/api/ai_rail.cpp index f520fdb5c..bce4719ca 100644 --- a/src/ai/api/ai_rail.cpp +++ b/src/ai/api/ai_rail.cpp @@ -170,6 +170,24 @@ return AIObject::DoCommand(tile, p1, p2, CMD_BUILD_RAILROAD_STATION); } +/* static */ bool AIRail::BuildRailWaypoint(TileIndex tile) +{ + EnforcePrecondition(false, ::IsValidTile(tile)); + EnforcePrecondition(false, IsRailTile(tile)); + EnforcePrecondition(false, GetRailTracks(tile) == RAILTRACK_NE_SW || GetRailTracks(tile) == RAILTRACK_NW_SE); + EnforcePrecondition(false, IsRailTypeAvailable(GetCurrentRailType())); + + return AIObject::DoCommand(tile, 0, 0, CMD_BUILD_TRAIN_WAYPOINT); +} + +/* static */ bool AIRail::RemoveRailWaypoint(TileIndex tile) +{ + EnforcePrecondition(false, ::IsValidTile(tile)); + EnforcePrecondition(false, IsRailWaypointTile(tile)); + + return AIObject::DoCommand(tile, 0, 0, CMD_REMOVE_TRAIN_WAYPOINT); +} + /* static */ bool AIRail::RemoveRailStationTileRect(TileIndex tile, TileIndex tile2) { EnforcePrecondition(false, ::IsValidTile(tile)); |