diff options
-rw-r--r-- | macros.h | 5 | ||||
-rw-r--r-- | tile.h | 10 |
2 files changed, 9 insertions, 6 deletions
@@ -151,4 +151,9 @@ static inline void swap_tile(TileIndex *a, TileIndex *b) { TileIndex t = *a; *a } #endif +// Fetch count bits starting at bit start from value +#define GB(value, start, count) (((value) >> (start)) & ((1 << (count)) - 1)) +// Set count bits in value starting at bit start to data +#define SB(value, start, count, data) ((value) = ((value) & ~(((1 << (count)) - 1) << (start))) | ((data) << (start))) + #endif /* MACROS_H */ @@ -46,15 +46,14 @@ static inline bool CorrectZ(uint tileh) static inline uint TileHeight(TileIndex tile) { assert(tile < MapSize()); - return _map_type_and_height[tile] & 0xf; + return GB(_map_type_and_height[tile], 0, 4); } static inline void SetTileHeight(TileIndex tile, uint height) { assert(tile < MapSize()); assert(height < 16); - _map_type_and_height[tile] &= ~0x0F; - _map_type_and_height[tile] |= height; + SB(_map_type_and_height[tile], 0, 4, height); } static inline uint TilePixelHeight(TileIndex tile) @@ -65,14 +64,13 @@ static inline uint TilePixelHeight(TileIndex tile) static inline TileType GetTileType(TileIndex tile) { assert(tile < MapSize()); - return _map_type_and_height[tile] >> 4; + return GB(_map_type_and_height[tile], 4, 4); } static inline void SetTileType(TileIndex tile, TileType type) { assert(tile < MapSize()); - _map_type_and_height[tile] &= ~0xF0; - _map_type_and_height[tile] |= type << 4; + SB(_map_type_and_height[tile], 4, 4, type); } static inline bool IsTileType(TileIndex tile, TileType type) |