diff options
author | smatz <smatz@openttd.org> | 2008-09-13 17:26:44 +0000 |
---|---|---|
committer | smatz <smatz@openttd.org> | 2008-09-13 17:26:44 +0000 |
commit | 5b14c6706450382699038d5e51ecc52a30881dc0 (patch) | |
tree | 7a288207bcd3568a036e2127ca18497653ee1523 | |
parent | 33e46bb75a81bb1675b301c36d3ea8544540f4a6 (diff) | |
download | openttd-5b14c6706450382699038d5e51ecc52a30881dc0.tar.xz |
(svn r14315) -Fix: allow adding roadtypes only to drive-through road stops
-rw-r--r-- | src/road_cmd.cpp | 20 |
1 files changed, 9 insertions, 11 deletions
diff --git a/src/road_cmd.cpp b/src/road_cmd.cpp index cc0a092ac..6d1d878c6 100644 --- a/src/road_cmd.cpp +++ b/src/road_cmd.cpp @@ -576,17 +576,14 @@ CommandCost CmdBuildRoad(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) return CommandCost(EXPENSES_CONSTRUCTION, _price.build_road * (rt == ROADTYPE_ROAD ? 2 : 4)); } - case MP_STATION: - if (!IsRoadStop(tile)) goto do_clear; - if (IsDriveThroughStopTile(tile)) { - RoadBits curbits = AxisToRoadBits(DiagDirToAxis(GetRoadStopDir(tile))); - if (pieces & ~curbits) goto do_clear; - pieces = curbits; // we need to pay for both roadbits - } else { - if (pieces & ~DiagDirToRoadBits(GetRoadStopDir(tile))) goto do_clear; - } + case MP_STATION: { + if (!IsDriveThroughStopTile(tile)) goto do_clear; if (HasTileRoadType(tile, rt)) return_cmd_error(STR_1007_ALREADY_BUILT); - break; + + RoadBits curbits = AxisToRoadBits(DiagDirToAxis(GetRoadStopDir(tile))); + if (pieces & ~curbits) goto do_clear; + pieces = curbits; // we need to pay for both roadbits + } break; case MP_TUNNELBRIDGE: if (GetTunnelBridgeTransportType(tile) != TRANSPORT_ROAD) return CMD_ERROR; @@ -674,8 +671,9 @@ do_clear:; } break; case MP_STATION: + assert(IsDriveThroughStopTile(tile)); SetRoadTypes(tile, GetRoadTypes(tile) | RoadTypeToRoadTypes(rt)); - if (IsDriveThroughStopTile(tile) && rt == ROADTYPE_ROAD) SetStopBuiltOnTownRoad(tile, false); + if (rt == ROADTYPE_ROAD) SetStopBuiltOnTownRoad(tile, false); break; default: |