summaryrefslogtreecommitdiff
path: root/src/ai/api/ai_map.cpp
diff options
context:
space:
mode:
authortruebrain <truebrain@openttd.org>2009-01-13 23:50:12 +0000
committertruebrain <truebrain@openttd.org>2009-01-13 23:50:12 +0000
commit6fe54a2d1a06b1d55cd649919785af6f4890f9da (patch)
treef92593f0f2201b7be3466211b9ba0dba1a7ab3ca /src/ai/api/ai_map.cpp
parente00cf92f47837d26d5b0fffb0668c5c717b3bacc (diff)
downloadopenttd-6fe54a2d1a06b1d55cd649919785af6f4890f9da.tar.xz
(svn r15078) -Fix [NoAI]: AIMap didn't filter its input (Yexo)
Diffstat (limited to 'src/ai/api/ai_map.cpp')
-rw-r--r--src/ai/api/ai_map.cpp19
1 files changed, 13 insertions, 6 deletions
diff --git a/src/ai/api/ai_map.cpp b/src/ai/api/ai_map.cpp
index 2c8547f95..b3a7f753c 100644
--- a/src/ai/api/ai_map.cpp
+++ b/src/ai/api/ai_map.cpp
@@ -26,37 +26,44 @@
return ::MapSizeY();
}
-/* static */ uint32 AIMap::GetTileX(TileIndex t)
+/* static */ int32 AIMap::GetTileX(TileIndex t)
{
+ if (!::IsValidTile(t)) return -1;
return ::TileX(t);
}
-/* static */ uint32 AIMap::GetTileY(TileIndex t)
+/* static */ int32 AIMap::GetTileY(TileIndex t)
{
+ if (!::IsValidTile(t)) return -1;
return ::TileY(t);
}
/* static */ TileIndex AIMap::GetTileIndex(uint32 x, uint32 y)
{
+ if (x >= ::MapSizeX() || y >= MapSizeY()) return INVALID_TILE;
return ::TileXY(x, y);
}
-/* static */ uint32 AIMap::DistanceManhattan(TileIndex t1, TileIndex t2)
+/* static */ int32 AIMap::DistanceManhattan(TileIndex t1, TileIndex t2)
{
+ if (!::IsValidTile(t1) || !::IsValidTile(t2)) return -1;
return ::DistanceManhattan(t1, t2);
}
-/* static */ uint32 AIMap::DistanceMax(TileIndex t1, TileIndex t2)
+/* static */ int32 AIMap::DistanceMax(TileIndex t1, TileIndex t2)
{
+ if (!::IsValidTile(t1) || !::IsValidTile(t2)) return -1;
return ::DistanceMax(t1, t2);
}
-/* static */ uint32 AIMap::DistanceSquare(TileIndex t1, TileIndex t2)
+/* static */ int32 AIMap::DistanceSquare(TileIndex t1, TileIndex t2)
{
+ if (!::IsValidTile(t1) || !::IsValidTile(t2)) return -1;
return ::DistanceSquare(t1, t2);
}
-/* static */ uint32 AIMap::DistanceFromEdge(TileIndex t)
+/* static */ int32 AIMap::DistanceFromEdge(TileIndex t)
{
+ if (!::IsValidTile(t)) return -1;
return ::DistanceFromEdge(t);
}