summaryrefslogtreecommitdiff
path: root/src/station_cmd.cpp
diff options
context:
space:
mode:
authorrubidium <rubidium@openttd.org>2007-02-18 11:14:55 +0000
committerrubidium <rubidium@openttd.org>2007-02-18 11:14:55 +0000
commit66ad0c7d0c84e09c17dd1268efa9705542dd829b (patch)
tree7ab14f40fa026a89aa287cff67ab6c5027b5e60c /src/station_cmd.cpp
parent38fedf20ce77e7d921b040e9fad23597289c7bc2 (diff)
downloadopenttd-66ad0c7d0c84e09c17dd1268efa9705542dd829b.tar.xz
(svn r8797) -Fix (8741): the 'drive through station built on town owned road' bit was not set.
Diffstat (limited to 'src/station_cmd.cpp')
-rw-r--r--src/station_cmd.cpp5
1 files changed, 3 insertions, 2 deletions
diff --git a/src/station_cmd.cpp b/src/station_cmd.cpp
index fae6a60c8..34d3393c2 100644
--- a/src/station_cmd.cpp
+++ b/src/station_cmd.cpp
@@ -1215,6 +1215,7 @@ int32 CmdBuildRoadStop(TileIndex tile, uint32 flags, uint32 p1, uint32 p2)
bool type = HASBIT(p2, 0);
bool is_drive_through = HASBIT(p2, 1);
bool build_over_road = is_drive_through && IsTileType(tile, MP_STREET) && GetRoadTileType(tile) == ROAD_TILE_NORMAL;
+ bool town_owned_road = build_over_road && IsTileOwner(tile, OWNER_TOWN);
Owner cur_owner = _current_player;
/* Saveguard the parameters */
@@ -1233,7 +1234,7 @@ int32 CmdBuildRoadStop(TileIndex tile, uint32 flags, uint32 p1, uint32 p2)
if (build_over_road) flags ^= DC_AUTO;
- if (build_over_road && IsTileOwner(tile, OWNER_TOWN)) _current_player = OWNER_TOWN;
+ if (town_owned_road) _current_player = OWNER_TOWN;
ret = CheckFlatLandBelow(tile, 1, 1, flags, is_drive_through ? 5 << p1 : 1 << p1, NULL);
_current_player = cur_owner;
if (CmdFailed(ret)) return ret;
@@ -1301,7 +1302,7 @@ int32 CmdBuildRoadStop(TileIndex tile, uint32 flags, uint32 p1, uint32 p2)
st->rect.BeforeAddTile(tile, StationRect::ADD_TRY);
MakeRoadStop(tile, st->owner, st->index, type ? RoadStop::TRUCK : RoadStop::BUS, is_drive_through, (DiagDirection)p1);
- if (is_drive_through & HASBIT(p2, 3)) SetStopBuiltOnTownRoad(tile);
+ if (town_owned_road) SetStopBuiltOnTownRoad(tile);
UpdateStationVirtCoordDirty(st);
UpdateStationAcceptance(st, false);