diff options
author | rubidium <rubidium@openttd.org> | 2007-06-03 19:22:23 +0000 |
---|---|---|
committer | rubidium <rubidium@openttd.org> | 2007-06-03 19:22:23 +0000 |
commit | 6a60ba3eaa66b5e226525f2dec4896014657be4e (patch) | |
tree | 2f9281929857522e874d8400400deca2d711df00 | |
parent | a752c73469e2a5e1d3f7b5b30b2db494e4bdbae5 (diff) | |
download | openttd-6a60ba3eaa66b5e226525f2dec4896014657be4e.tar.xz |
(svn r10030) -Fix [FS#823]: one could build on (some) slopes when building on slopes was disabled.
-rw-r--r-- | src/rail_cmd.cpp | 13 |
1 files changed, 5 insertions, 8 deletions
diff --git a/src/rail_cmd.cpp b/src/rail_cmd.cpp index 66036ab36..16d95eaeb 100644 --- a/src/rail_cmd.cpp +++ b/src/rail_cmd.cpp @@ -206,20 +206,17 @@ static uint32 CheckRailSlope(Slope tileh, TrackBits rail_bits, TrackBits existin } /* no special foundation */ - if ((~_valid_tileh_slopes[0][tileh] & rail_bits) == 0) + if ((~_valid_tileh_slopes[0][tileh] & rail_bits) == 0) { return 0; + } else if (!_patches.build_on_slopes || _is_old_ai_player) { + return_cmd_error(STR_1000_LAND_SLOPED_IN_WRONG_DIRECTION); + } if ((~_valid_tileh_slopes[1][tileh] & rail_bits) == 0 || ( // whole tile is leveled up (rail_bits == TRACK_BIT_X || rail_bits == TRACK_BIT_Y) && (tileh == SLOPE_W || tileh == SLOPE_S || tileh == SLOPE_E || tileh == SLOPE_N) )) { // partly up - if (existing != 0) { - return 0; - } else if (!_patches.build_on_slopes || _is_old_ai_player) { - return_cmd_error(STR_1000_LAND_SLOPED_IN_WRONG_DIRECTION); - } else { - return _price.terraform; - } + return (existing != 0) ? 0 : _price.terraform; } } return_cmd_error(STR_1000_LAND_SLOPED_IN_WRONG_DIRECTION); |