From b76f0185d4064a4c44c6030976213dffe4493873 Mon Sep 17 00:00:00 2001 From: frosch Date: Tue, 13 Apr 2010 17:29:19 +0000 Subject: (svn r19616) -Codechange: Increase transparency of 'Extract' by passing also the number of used bits. --- src/cmd_helper.h | 9 +++++---- src/rail_cmd.cpp | 2 +- src/road_cmd.cpp | 8 ++++---- src/station_cmd.cpp | 2 +- src/water_cmd.cpp | 2 +- 5 files changed, 12 insertions(+), 11 deletions(-) (limited to 'src') diff --git a/src/cmd_helper.h b/src/cmd_helper.h index a034f1217..1530beedb 100644 --- a/src/cmd_helper.h +++ b/src/cmd_helper.h @@ -14,12 +14,13 @@ #include "core/enum_type.hpp" -template static inline T Extract(U v) +template static inline T Extract(U v) { /* Check if there are enough bits in v */ - assert_tcompile(N + EnumPropsT::num_bits <= sizeof(U) * 8); - assert_tcompile(EnumPropsT::end <= (1 << EnumPropsT::num_bits)); - return (T)GB(v, N, EnumPropsT::num_bits); + assert_tcompile(N == EnumPropsT::num_bits); + assert_tcompile(S + N <= sizeof(U) * 8); + assert_tcompile(EnumPropsT::end <= (1 << N)); + return (T)GB(v, S, N); } #endif diff --git a/src/rail_cmd.cpp b/src/rail_cmd.cpp index e0f85675c..f90be4125 100644 --- a/src/rail_cmd.cpp +++ b/src/rail_cmd.cpp @@ -837,7 +837,7 @@ CommandCost CmdBuildTrainDepot(TileIndex tile, DoCommandFlag flags, uint32 p1, u Slope tileh = GetTileSlope(tile, NULL); - DiagDirection dir = Extract(p2); + DiagDirection dir = Extract(p2); /* Prohibit construction if * The tile is non-flat AND diff --git a/src/road_cmd.cpp b/src/road_cmd.cpp index c97ac1b0a..8f3832dc6 100644 --- a/src/road_cmd.cpp +++ b/src/road_cmd.cpp @@ -464,7 +464,7 @@ CommandCost CmdBuildRoad(TileIndex tile, DoCommandFlag flags, uint32 p1, uint32 p2 = (town != NULL) ? town->index : (TownID)INVALID_TOWN; } - RoadBits pieces = Extract(p1); + RoadBits pieces = Extract(p1); /* do not allow building 'zero' road bits, code wouldn't handle it */ if (pieces == ROAD_NONE) return CMD_ERROR; @@ -729,7 +729,7 @@ CommandCost CmdBuildLongRoad(TileIndex start_tile, DoCommandFlag flags, uint32 p RoadType rt = (RoadType)GB(p2, 3, 2); if (!IsValidRoadType(rt) || !ValParamRoadType(rt)) return CMD_ERROR; - Axis axis = Extract(p2); + Axis axis = Extract(p2); /* Only drag in X or Y direction dictated by the direction variable */ if (axis == AXIS_X && TileY(start_tile) != TileY(end_tile)) return CMD_ERROR; // x-axis if (axis == AXIS_Y && TileX(start_tile) != TileX(end_tile)) return CMD_ERROR; // y-axis @@ -821,7 +821,7 @@ CommandCost CmdRemoveLongRoad(TileIndex start_tile, DoCommandFlag flags, uint32 RoadType rt = (RoadType)GB(p2, 3, 2); if (!IsValidRoadType(rt)) return CMD_ERROR; - Axis axis = Extract(p2); + Axis axis = Extract(p2); /* Only drag in X or Y direction dictated by the direction variable */ if (axis == AXIS_X && TileY(start_tile) != TileY(end_tile)) return CMD_ERROR; // x-axis if (axis == AXIS_Y && TileX(start_tile) != TileX(end_tile)) return CMD_ERROR; // y-axis @@ -886,7 +886,7 @@ CommandCost CmdRemoveLongRoad(TileIndex start_tile, DoCommandFlag flags, uint32 */ CommandCost CmdBuildRoadDepot(TileIndex tile, DoCommandFlag flags, uint32 p1, uint32 p2, const char *text) { - DiagDirection dir = Extract(p1); + DiagDirection dir = Extract(p1); RoadType rt = (RoadType)GB(p1, 2, 2); if (!IsValidRoadType(rt) || !ValParamRoadType(rt)) return CMD_ERROR; diff --git a/src/station_cmd.cpp b/src/station_cmd.cpp index a996ff5cd..060b66bf6 100644 --- a/src/station_cmd.cpp +++ b/src/station_cmd.cpp @@ -1096,7 +1096,7 @@ CommandCost CmdBuildRailStation(TileIndex tile_org, DoCommandFlag flags, uint32 { /* Unpack parameters */ RailType rt = (RailType)GB(p1, 0, 4); - Axis axis = Extract(p1); + Axis axis = Extract(p1); byte numtracks = GB(p1, 8, 8); byte plat_len = GB(p1, 16, 8); bool adjacent = HasBit(p1, 24); diff --git a/src/water_cmd.cpp b/src/water_cmd.cpp index 1216fb213..4b80d0cd4 100644 --- a/src/water_cmd.cpp +++ b/src/water_cmd.cpp @@ -104,7 +104,7 @@ static void MarkCanalsAndRiversAroundDirty(TileIndex tile) */ CommandCost CmdBuildShipDepot(TileIndex tile, DoCommandFlag flags, uint32 p1, uint32 p2, const char *text) { - Axis axis = Extract(p1); + Axis axis = Extract(p1); TileIndex tile2 = tile + (axis == AXIS_X ? TileDiffXY(1, 0) : TileDiffXY(0, 1)); -- cgit v1.2.3-54-g00ecf