Mercurial > hg > openttd
view src/tunnel_map.cpp @ 6261:a2ab35efe1ab draft
(svn r9070) -Fix [FS#404]: if bribe failed and you didn't pick up cargo yet, you wouldn't ever be able to do so for a given station
author | truelight <truelight@openttd.org> |
---|---|
date | Thu, 08 Mar 2007 20:50:27 +0000 |
parents | 4b26bd55bd24 |
children | fb10eafe2a26 |
line wrap: on
line source
/* $Id$ */ #include "stdafx.h" #include "openttd.h" #include "tile.h" #include "tunnel_map.h" TileIndex GetOtherTunnelEnd(TileIndex tile) { DiagDirection dir = GetTunnelDirection(tile); TileIndexDiff delta = TileOffsByDiagDir(dir); uint z = GetTileZ(tile); dir = ReverseDiagDir(dir); do { tile += delta; } while ( !IsTunnelTile(tile) || GetTunnelDirection(tile) != dir || GetTileZ(tile) != z ); return tile; } static bool IsTunnelInWayDir(TileIndex tile, uint z, DiagDirection dir) { TileIndexDiff delta = TileOffsByDiagDir(dir); uint height; do { tile -= delta; height = GetTileZ(tile); } while (z < height); return z == height && IsTunnelTile(tile) && GetTunnelDirection(tile) == dir; } bool IsTunnelInWay(TileIndex tile, uint z) { return IsTunnelInWayDir(tile, z, DIAGDIR_NE) || IsTunnelInWayDir(tile, z, DIAGDIR_SE) || IsTunnelInWayDir(tile, z, DIAGDIR_SW) || IsTunnelInWayDir(tile, z, DIAGDIR_NW); }