# HG changeset patch # User tron # Date 1172043451 0 # Node ID 1f2c064d8490f9c86757ca1f0b8736aaf98ab73c # Parent 1921ab72b54db740aade131f6444393d5a0b80c8 (svn r8828) -Fix -Regression (r7585): On load calculate the station rectangle for all savegames, not just savegames with at least version 27 diff --git a/src/openttd.cpp b/src/openttd.cpp --- a/src/openttd.cpp +++ b/src/openttd.cpp @@ -1288,20 +1288,23 @@ DoZoomInOutWindow(ZOOM_NONE, w); // update button status MarkWholeScreenDirty(); - /* From this version on there can be multiple road stops of the same type per - * station. Convert the existing stops to the new internal data structure. - */ for (TileIndex t = 0; t < map_size; t++) { switch (GetTileType(t)) { - case MP_STATION: + case MP_STATION: { + Station *st = GetStationByTile(t); + + st->rect.BeforeAddTile(t, StationRect::ADD_FORCE); + switch (GetStationType(t)) { case STATION_TRUCK: case STATION_BUS: if (CheckSavegameVersion(6)) { + /* From this version on there can be multiple road stops of the + * same type per station. Convert the existing stops to the new + * internal data structure. */ RoadStop *rs = new RoadStop(t); if (rs == NULL) error("Too many road stops in savegame"); - Station *st = GetStationByTile(t); RoadStop **head = IsTruckStop(t) ? &st->truck_stops : &st->bus_stops; *head = rs; @@ -1330,6 +1333,7 @@ default: break; } break; + } default: break; } diff --git a/src/station_cmd.cpp b/src/station_cmd.cpp --- a/src/station_cmd.cpp +++ b/src/station_cmd.cpp @@ -2647,11 +2647,6 @@ st->speclist[i].spec = GetCustomStationSpecByGrf(st->speclist[i].grfid, st->speclist[i].localidx); } } - - for (TileIndex tile = 0; tile < MapSize(); tile++) { - if (GetTileType(tile) != MP_STATION) continue; - GetStationByTile(tile)->rect.BeforeAddTile(tile, StationRect::ADD_FORCE); - } }