# HG changeset patch # User rubidium # Date 1281483103 0 # Node ID e61270493ab3657688330586bae18c20b573bee0 # Parent 4559798876dcee15482ce8914f9717c4082d0691 (svn r20443) -Codechange: more TileHash to a more generic location diff --git a/src/tile_map.h b/src/tile_map.h --- a/src/tile_map.h +++ b/src/tile_map.h @@ -206,4 +206,35 @@ uint GetTileZ(TileIndex tile); uint GetTileMaxZ(TileIndex tile); -#endif /* TILE_TYPE_H */ + +/** + * Calculate a hash value from a tile position + * + * @param x The X coordinate + * @param y The Y coordinate + * @return The hash of the tile + */ +static inline uint TileHash(uint x, uint y) +{ + uint hash = x >> 4; + hash ^= x >> 6; + hash ^= y >> 4; + hash -= y >> 6; + return hash; +} + +/** + * Get the last two bits of the TileHash + * from a tile position. + * + * @see TileHash() + * @param x The X coordinate + * @param y The Y coordinate + * @return The last two bits from hash of the tile + */ +static inline uint TileHash2Bit(uint x, uint y) +{ + return GB(TileHash(x, y), 0, 2); +} + +#endif /* TILE_MAP_H */ diff --git a/src/town.h b/src/town.h --- a/src/town.h +++ b/src/town.h @@ -233,36 +233,6 @@ extern TownID _new_town_id; /** - * Calculate a hash value from a tile position - * - * @param x The X coordinate - * @param y The Y coordinate - * @return The hash of the tile - */ -static inline uint TileHash(uint x, uint y) -{ - uint hash = x >> 4; - hash ^= x >> 6; - hash ^= y >> 4; - hash -= y >> 6; - return hash; -} - -/** - * Get the last two bits of the TileHash - * from a tile position. - * - * @see TileHash() - * @param x The X coordinate - * @param y The Y coordinate - * @return The last two bits from hash of the tile - */ -static inline uint TileHash2Bit(uint x, uint y) -{ - return GB(TileHash(x, y), 0, 2); -} - -/** * Set the default name for a depot/waypoint * @tparam T The type/class to make a default name for * @param obj The object/instance we want to find the name for