From bd7f331da4f56cc32a0244efc6ae3999fb4a7cb5 Mon Sep 17 00:00:00 2001 From: rubidium Date: Sat, 20 Nov 2010 13:57:49 +0000 Subject: [PATCH] (svn r21268) -Fix (r21266): crash (or rather a triggered assertion) in some cases --- src/station_cmd.cpp | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/station_cmd.cpp b/src/station_cmd.cpp index 19c414b734..39d22384bc 100644 --- a/src/station_cmd.cpp +++ b/src/station_cmd.cpp @@ -1413,6 +1413,12 @@ CommandCost RemoveFromRailBaseStation(TileArea ta, SmallVector &affected /* If we reached here, the tile is valid so increase the quantity of tiles we will remove */ quantity++; + if (keep_rail || IsStationTileBlocked(tile)) { + /* Don't refund the 'steel' of the track when we keep the + * rail, or when the tile didn't have any rail at all. */ + total_cost.AddCost(-_price[PR_CLEAR_RAIL]); + } + if (flags & DC_EXEC) { /* read variables before the station tile is removed */ uint specindex = GetCustomStationSpecIndex(tile); @@ -1455,11 +1461,6 @@ CommandCost RemoveFromRailBaseStation(TileArea ta, SmallVector &affected if (IsRailStationTile(v->tile)) SetRailStationPlatformReservation(v->tile, TrackdirToExitdir(ReverseTrackdir(v->GetVehicleTrackdir())), true); } } - if (keep_rail || IsStationTileBlocked(tile)) { - /* Don't refund the 'steel' of the track when we keep the - * rail, or when the tile didn't have any rail at all. */ - total_cost.AddCost(-_price[PR_CLEAR_RAIL]); - } } if (quantity == 0) return_cmd_error(STR_ERROR_THERE_IS_NO_STATION);