From 96a3a89c861648b44857b741b77b11b200d7b259 Mon Sep 17 00:00:00 2001 From: maedhros Date: Mon, 11 Jun 2007 04:52:51 +0000 Subject: (svn r10089) -Fix (r10040): Use GetTileZ instead of GetClearGround in GetTerrainType as GetTileZ is valid for any tile type. Also use GetTerrainType for stations. --- src/newgrf_commons.cpp | 4 ++-- src/newgrf_station.cpp | 6 ++---- 2 files changed, 4 insertions(+), 6 deletions(-) (limited to 'src') diff --git a/src/newgrf_commons.cpp b/src/newgrf_commons.cpp index 6c03de201..72567920e 100644 --- a/src/newgrf_commons.cpp +++ b/src/newgrf_commons.cpp @@ -7,7 +7,7 @@ #include "stdafx.h" #include "openttd.h" #include "variables.h" -#include "clear_map.h" +#include "landscape.h" #include "town.h" #include "industry.h" #include "newgrf.h" @@ -229,7 +229,7 @@ uint32 GetTerrainType(TileIndex tile) { switch (_opt.landscape) { case LT_TROPIC: return GetTropicZone(tile) == TROPICZONE_DESERT ? 1 : 2; - case LT_ARCTIC: return (GetClearGround(tile) == CLEAR_SNOW) ? 4 : 0; + case LT_ARCTIC: return GetTileZ(tile) >= GetSnowLine() ? 4 : 0; default: return 0; } } diff --git a/src/newgrf_station.cpp b/src/newgrf_station.cpp index d00d925af..e53e4d912 100644 --- a/src/newgrf_station.cpp +++ b/src/newgrf_station.cpp @@ -15,6 +15,7 @@ #include "station_map.h" #include "newgrf.h" #include "newgrf_callbacks.h" +#include "newgrf_commons.h" #include "newgrf_station.h" #include "newgrf_spritegroup.h" #include "date.h" @@ -388,10 +389,7 @@ static uint32 StationGetVariable(const ResolverObject *object, byte variable, by /* Calculated station variables */ case 0x40: return GetPlatformInfoHelper(tile, false, false, false); case 0x41: return GetPlatformInfoHelper(tile, true, false, false); - case 0x42: // Terrain and rail type - return ((_opt.landscape == LT_ARCTIC && GetTileZ(tile) > GetSnowLine()) ? 4 : 0) | - (_opt.landscape == LT_TROPIC ? GetTropicZone(tile) : 0) | - (GetRailType(tile) << 8); + case 0x42: return GetTerrainType(tile) | (GetRailType(tile) << 8); case 0x43: return st->owner; // Station owner case 0x44: return 2; // PBS status case 0x45: return GetRailContinuationInfo(tile); -- cgit v1.2.3-70-g09d2