(svn r5500) Undo r4597, because it breaks the intended change of r5315 to prohibit building rails on a road tile while road works are in progress
authortron
Sat, 15 Jul 2006 09:29:39 +0000
changeset 4140 1765a8dd17dc
parent 4139 611ec4ec9a3b
child 4141 86d4e1404b53
(svn r5500) Undo r4597, because it breaks the intended change of r5315 to prohibit building rails on a road tile while road works are in progress
rail_cmd.c
--- a/rail_cmd.c	Fri Jul 14 18:14:08 2006 +0000
+++ b/rail_cmd.c	Sat Jul 15 09:29:39 2006 +0000
@@ -286,14 +286,16 @@
 
 			if (!EnsureNoVehicle(tile)) return CMD_ERROR;
 
-			if (GetRoadTileType(tile) == ROAD_TILE_NORMAL &&
-					((track == TRACK_X && GetRoadBits(tile) == ROAD_Y) ||
-					(track == TRACK_Y && GetRoadBits(tile) == ROAD_X))) {
-				if (flags & DC_EXEC) {
-					MakeRoadCrossing(tile, GetTileOwner(tile), _current_player, (track == TRACK_X ? AXIS_Y : AXIS_X), p1, GetTownIndex(tile));
+			if (GetRoadTileType(tile) == ROAD_TILE_NORMAL) {
+				if (HasRoadWorks(tile)) return_cmd_error(STR_ROAD_WORKS_IN_PROGRESS);
+
+				if ((track == TRACK_X && GetRoadBits(tile) == ROAD_Y) ||
+						(track == TRACK_Y && GetRoadBits(tile) == ROAD_X)) {
+					if (flags & DC_EXEC) {
+						MakeRoadCrossing(tile, GetTileOwner(tile), _current_player, (track == TRACK_X ? AXIS_Y : AXIS_X), p1, GetTownIndex(tile));
+					}
+					break;
 				}
-
-				break;
 			}
 
 			if (IsLevelCrossing(tile) && GetCrossingRailBits(tile) == trackbit) {