diff options
author | frosch <frosch@openttd.org> | 2008-07-27 09:16:23 +0000 |
---|---|---|
committer | frosch <frosch@openttd.org> | 2008-07-27 09:16:23 +0000 |
commit | 008a725e4ae56f291e12079dbb972b682d422b4b (patch) | |
tree | 2eb60b2090a9de5ad313427a37fb1f7c93b5333e | |
parent | 1c53d19df5c1db5070613227c40fc3ab134f3574 (diff) | |
download | openttd-008a725e4ae56f291e12079dbb972b682d422b4b.tar.xz |
(svn r13846) -Fix (r13838): Do not draw water borders inside of industries.
-rw-r--r-- | src/water_cmd.cpp | 22 |
1 files changed, 20 insertions, 2 deletions
diff --git a/src/water_cmd.cpp b/src/water_cmd.cpp index db6872178..f409c250e 100644 --- a/src/water_cmd.cpp +++ b/src/water_cmd.cpp @@ -536,11 +536,29 @@ static bool IsWateredTile(TileIndex tile, Direction from) return false; case MP_STATION: - if (IsOilRig(tile)) return GetWaterClass(tile) != WATER_CLASS_INVALID; + if (IsOilRig(tile)) { + /* Do not draw waterborders inside of industries. + * Note: There is no easy way to detect the industry of an oilrig tile. */ + TileIndex src_tile = tile + TileOffsByDir(from); + if ((IsTileType(src_tile, MP_STATION) && IsOilRig(src_tile)) || + (IsTileType(src_tile, MP_INDUSTRY))) return true; + + return GetWaterClass(tile) != WATER_CLASS_INVALID; + } return (IsDock(tile) && GetTileSlope(tile, NULL) == SLOPE_FLAT) || IsBuoy(tile); - case MP_INDUSTRY: return IsIndustryTileOnWater(tile); + case MP_INDUSTRY: { + /* Do not draw waterborders inside of industries. + * Note: There is no easy way to detect the industry of an oilrig tile. */ + TileIndex src_tile = tile + TileOffsByDir(from); + if ((IsTileType(src_tile, MP_STATION) && IsOilRig(src_tile)) || + (IsTileType(src_tile, MP_INDUSTRY) && GetIndustryIndex(src_tile) == GetIndustryIndex(tile))) return true; + + return IsIndustryTileOnWater(tile); + } + case MP_TUNNELBRIDGE: return GetTunnelBridgeTransportType(tile) == TRANSPORT_WATER && ReverseDiagDir(GetTunnelBridgeDirection(tile)) == DirToDiagDir(from); + default: return false; } } |