From 3abddfe705752ac8477421211f6e664f1a0994fc Mon Sep 17 00:00:00 2001 From: peter1138 Date: Sat, 21 Mar 2009 23:58:20 +0000 Subject: (svn r15799) -Codechange: Save rail type label list to savegame and perform mapping on load if necessary. --- src/saveload/afterload.cpp | 2 + src/saveload/labelmaps_sl.cpp | 125 +++++++++++++++++++++++++++++++++++++++ src/saveload/saveload.cpp | 2 + src/saveload/saveload_internal.h | 1 + 4 files changed, 130 insertions(+) create mode 100644 src/saveload/labelmaps_sl.cpp (limited to 'src/saveload') diff --git a/src/saveload/afterload.cpp b/src/saveload/afterload.cpp index 44fd9f01c..5f7cc1848 100644 --- a/src/saveload/afterload.cpp +++ b/src/saveload/afterload.cpp @@ -1797,6 +1797,8 @@ bool AfterLoadGame() } } + AfterLoadLabelMaps(); + GamelogPrintDebug(1); bool ret = InitializeWindowsAndCaches(); diff --git a/src/saveload/labelmaps_sl.cpp b/src/saveload/labelmaps_sl.cpp new file mode 100644 index 000000000..e39e4d9b6 --- /dev/null +++ b/src/saveload/labelmaps_sl.cpp @@ -0,0 +1,125 @@ +/* $Id$ */ + +/** @file labelmaps_sl.cpp Code handling saving and loading of rail type label mappings */ + +#include "../stdafx.h" +#include "../strings_type.h" +#include "../rail.h" +#include "../map_func.h" +#include "../tile_map.h" +#include "../rail_map.h" +#include "../road_map.h" +#include "../station_map.h" +#include "../tunnelbridge_map.h" +#include "../core/alloc_func.hpp" +#include "../core/smallvec_type.hpp" +#include "../settings_type.h" + +#include "saveload.h" + +static SmallVector _railtype_list; + +/** + * Test if any saved rail type labels are different to the currently loaded + * rail types, which therefore requires conversion. + * @return true if (and only if) conversion due to rail type changes is needed. + */ +static bool NeedRailTypeConversion() +{ + for (uint i = 0; i < _railtype_list.Length(); i++) { + if ((RailType)i < RAILTYPE_END) { + const RailtypeInfo *rti = GetRailTypeInfo((RailType)i); + if (rti->label != _railtype_list[i]) return true; + } else { + if (_railtype_list[i] != 0) return true; + } + } + + /* No rail type conversion is necessary */ + return false; +} + +void AfterLoadLabelMaps() +{ + if (NeedRailTypeConversion()) { + SmallVector railtype_conversion_map; + + for (uint i = 0; i < _railtype_list.Length(); i++) { + RailType r = GetRailTypeByLabel(_railtype_list[i]); + if (r == INVALID_RAILTYPE) r = RAILTYPE_BEGIN; + + *railtype_conversion_map.Append() = r; + } + + for (TileIndex t = 0; t < MapSize(); t++) { + switch (GetTileType(t)) { + case MP_RAILWAY: + SetRailType(t, railtype_conversion_map[GetRailType(t)]); + break; + + case MP_ROAD: + if (IsLevelCrossing(t)) { + SetRailType(t, railtype_conversion_map[GetRailType(t)]); + } + break; + + case MP_STATION: + if (IsRailwayStation(t)) { + SetRailType(t, railtype_conversion_map[GetRailType(t)]); + } + break; + + case MP_TUNNELBRIDGE: + if (GetTunnelBridgeTransportType(t) == TRANSPORT_RAIL) { + SetRailType(t, railtype_conversion_map[GetRailType(t)]); + } + break; + + default: + break; + } + } + } + + _railtype_list.Clear(); +} + +/** Container for a label for SaveLoad system */ +struct LabelObject { + uint32 label; +}; + +static const SaveLoad _label_object_desc[] = { + SLE_VAR(LabelObject, label, SLE_UINT32), + SLE_END(), +}; + +static void Save_RAIL() +{ + LabelObject lo; + + for (RailType r = RAILTYPE_BEGIN; r != RAILTYPE_END; r++) { + lo.label = GetRailTypeInfo(r)->label; + + SlSetArrayIndex(r); + SlObject(&lo, _label_object_desc); + } +} + +static void Load_RAIL() +{ + _railtype_list.Clear(); + + LabelObject lo; + int index; + + while ((index = SlIterateArray()) != -1) { + SlObject(&lo, _label_object_desc); + *_railtype_list.Append() = (RailTypeLabel)lo.label; + } +} + +extern const ChunkHandler _labelmaps_chunk_handlers[] = { + { 'RAIL', Save_RAIL, Load_RAIL, CH_ARRAY | CH_LAST}, +}; + diff --git a/src/saveload/saveload.cpp b/src/saveload/saveload.cpp index 04b6499e7..c9480f884 100644 --- a/src/saveload/saveload.cpp +++ b/src/saveload/saveload.cpp @@ -1332,6 +1332,7 @@ extern const ChunkHandler _newgrf_chunk_handlers[]; extern const ChunkHandler _group_chunk_handlers[]; extern const ChunkHandler _cargopacket_chunk_handlers[]; extern const ChunkHandler _autoreplace_chunk_handlers[]; +extern const ChunkHandler _labelmaps_chunk_handlers[]; static const ChunkHandler * const _chunk_handlers[] = { _gamelog_chunk_handlers, @@ -1358,6 +1359,7 @@ static const ChunkHandler * const _chunk_handlers[] = { _group_chunk_handlers, _cargopacket_chunk_handlers, _autoreplace_chunk_handlers, + _labelmaps_chunk_handlers, NULL, }; diff --git a/src/saveload/saveload_internal.h b/src/saveload/saveload_internal.h index 19a5b5cbf..0486a796f 100644 --- a/src/saveload/saveload_internal.h +++ b/src/saveload/saveload_internal.h @@ -21,6 +21,7 @@ void FixOldWaypoints(); void AfterLoadWaypoints(); void AfterLoadVehicles(bool part_of_load); void AfterLoadStations(); +void AfterLoadLabelMaps(); void UpdateHousesAndTowns(); void UpdateOldAircraft(); -- cgit v1.2.3-70-g09d2