Fix #12134: Use correct error messages if clearing drive-through road stops fails (#12139)

pull/678/head
merni-ns 3 months ago committed by GitHub
parent aef8a345b2
commit b8b80cb42e
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -4433,29 +4433,37 @@ static void ChangeTileOwner_Station(TileIndex tile, Owner old_owner, Owner new_o
* Check if a drive-through road stop tile can be cleared. * Check if a drive-through road stop tile can be cleared.
* Road stops built on town-owned roads check the conditions * Road stops built on town-owned roads check the conditions
* that would allow clearing of the original road. * that would allow clearing of the original road.
* @param tile road stop tile to check * @param tile The road stop tile to check.
* @param flags command flags * @param flags Command flags.
* @return true if the road can be cleared * @return A succeeded command if the road can be removed, a failed command with the relevant error message otherwise.
*/ */
static bool CanRemoveRoadWithStop(TileIndex tile, DoCommandFlag flags) static CommandCost CanRemoveRoadWithStop(TileIndex tile, DoCommandFlag flags)
{ {
/* Yeah... water can always remove stops, right? */ /* Water flooding can always clear road stops. */
if (_current_company == OWNER_WATER) return true; if (_current_company == OWNER_WATER) return CommandCost();
CommandCost ret;
if (GetRoadTypeTram(tile) != INVALID_ROADTYPE) { if (GetRoadTypeTram(tile) != INVALID_ROADTYPE) {
Owner tram_owner = GetRoadOwner(tile, RTT_TRAM); Owner tram_owner = GetRoadOwner(tile, RTT_TRAM);
if (tram_owner != OWNER_NONE && CheckOwnership(tram_owner).Failed()) return false; if (tram_owner != OWNER_NONE) {
ret = CheckOwnership(tram_owner);
if (ret.Failed()) return ret;
}
} }
if (GetRoadTypeRoad(tile) != INVALID_ROADTYPE) { if (GetRoadTypeRoad(tile) != INVALID_ROADTYPE) {
Owner road_owner = GetRoadOwner(tile, RTT_ROAD); Owner road_owner = GetRoadOwner(tile, RTT_ROAD);
if (road_owner != OWNER_TOWN) { if (road_owner == OWNER_TOWN) {
if (road_owner != OWNER_NONE && CheckOwnership(road_owner).Failed()) return false; ret = CheckAllowRemoveRoad(tile, GetAnyRoadBits(tile, RTT_ROAD), OWNER_TOWN, RTT_ROAD, flags);
} else { if (ret.Failed()) return ret;
if (CheckAllowRemoveRoad(tile, GetAnyRoadBits(tile, RTT_ROAD), OWNER_TOWN, RTT_ROAD, flags).Failed()) return false; } else if (road_owner != OWNER_NONE) {
ret = CheckOwnership(road_owner);
if (ret.Failed()) return ret;
} }
} }
return true; return CommandCost();
} }
/** /**
@ -4486,14 +4494,11 @@ CommandCost ClearTile_Station(TileIndex tile, DoCommandFlag flags)
case STATION_RAIL: return RemoveRailStation(tile, flags); case STATION_RAIL: return RemoveRailStation(tile, flags);
case STATION_WAYPOINT: return RemoveRailWaypoint(tile, flags); case STATION_WAYPOINT: return RemoveRailWaypoint(tile, flags);
case STATION_AIRPORT: return RemoveAirport(tile, flags); case STATION_AIRPORT: return RemoveAirport(tile, flags);
case STATION_TRUCK: case STATION_TRUCK: [[fallthrough]];
if (IsDriveThroughStopTile(tile) && !CanRemoveRoadWithStop(tile, flags)) {
return_cmd_error(STR_ERROR_MUST_DEMOLISH_TRUCK_STATION_FIRST);
}
return RemoveRoadStop(tile, flags);
case STATION_BUS: case STATION_BUS:
if (IsDriveThroughStopTile(tile) && !CanRemoveRoadWithStop(tile, flags)) { if (IsDriveThroughStopTile(tile)) {
return_cmd_error(STR_ERROR_MUST_DEMOLISH_BUS_STATION_FIRST); CommandCost remove_road = CanRemoveRoadWithStop(tile, flags);
if (remove_road.Failed()) return remove_road;
} }
return RemoveRoadStop(tile, flags); return RemoveRoadStop(tile, flags);
case STATION_BUOY: return RemoveBuoy(tile, flags); case STATION_BUOY: return RemoveBuoy(tile, flags);

Loading…
Cancel
Save