diff options
-rw-r--r-- | src/station_cmd.cpp | 4 | ||||
-rw-r--r-- | src/terraform_gui.cpp | 4 |
2 files changed, 4 insertions, 4 deletions
diff --git a/src/station_cmd.cpp b/src/station_cmd.cpp index ef936ddfe..e3317fd43 100644 --- a/src/station_cmd.cpp +++ b/src/station_cmd.cpp @@ -2086,8 +2086,8 @@ bool HasStationInUse(StationID station, CompanyID company) static CommandCost RemoveBuoy(Station *st, DoCommandFlag flags) { - /* XXX: strange stuff */ - if (!Company::IsValidID(_current_company)) return_cmd_error(INVALID_STRING_ID); + /* XXX: strange stuff, allow clearing as invalid company when clearing landscape */ + if (!Company::IsValidID(_current_company) && !(flags & DC_BANKRUPT)) return_cmd_error(INVALID_STRING_ID); TileIndex tile = st->dock_tile; diff --git a/src/terraform_gui.cpp b/src/terraform_gui.cpp index 729b20511..e56945903 100644 --- a/src/terraform_gui.cpp +++ b/src/terraform_gui.cpp @@ -640,8 +640,8 @@ static void ResetLandscapeConfirmationCallback(Window *w, bool confirmed) Station *st; FOR_ALL_STATIONS(st) { /* There can be buoys, remove them */ - if (IsBuoyTile(st->xy)) DoCommand(st->xy, 0, 0, DC_EXEC, CMD_LANDSCAPE_CLEAR); - delete st; + if (st->IsBuoy() && IsBuoyTile(st->xy)) DoCommand(st->xy, 0, 0, DC_EXEC | DC_BANKRUPT, CMD_LANDSCAPE_CLEAR); + if (st->facilities == 0) delete st; } /* The same for waypoints */ |