diff options
author | Patric Stout <truebrain@openttd.org> | 2021-05-30 15:59:40 +0200 |
---|---|---|
committer | Patric Stout <github@truebrain.nl> | 2021-07-02 22:21:58 +0200 |
commit | cdb3dd0493749dd5c62378f318ea61bcb85f988f (patch) | |
tree | c1daa1e67c48fc480b7d4cfa0462db4c1bffdff8 /src/saveload/depot_sl.cpp | |
parent | 7dd5fd6ed497e1da40c13075d6e37b54ab12a082 (diff) | |
download | openttd-cdb3dd0493749dd5c62378f318ea61bcb85f988f.tar.xz |
Add: store headers for most savegame chunks
When a header is added, the chunk changes from CH_ARRAY type to
CH_TABLE type.
Diffstat (limited to 'src/saveload/depot_sl.cpp')
-rw-r--r-- | src/saveload/depot_sl.cpp | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/src/saveload/depot_sl.cpp b/src/saveload/depot_sl.cpp index 6af08e718..c1252562a 100644 --- a/src/saveload/depot_sl.cpp +++ b/src/saveload/depot_sl.cpp @@ -8,10 +8,12 @@ /** @file depot_sl.cpp Code handling saving and loading of depots */ #include "../stdafx.h" -#include "../depot_base.h" -#include "../town.h" #include "saveload.h" +#include "compat/depot_sl_compat.h" + +#include "../depot_base.h" +#include "../town.h" #include "../safeguards.h" @@ -29,6 +31,8 @@ static const SaveLoad _depot_desc[] = { static void Save_DEPT() { + SlTableHeader(_depot_desc); + for (Depot *depot : Depot::Iterate()) { SlSetArrayIndex(depot->index); SlObject(depot, _depot_desc); @@ -37,11 +41,13 @@ static void Save_DEPT() static void Load_DEPT() { + const std::vector<SaveLoad> slt = SlCompatTableHeader(_depot_desc, _depot_sl_compat); + int index; while ((index = SlIterateArray()) != -1) { Depot *depot = new (index) Depot(); - SlObject(depot, _depot_desc); + SlObject(depot, slt); /* Set the town 'pointer' so we can restore it later. */ if (IsSavegameVersionBefore(SLV_141)) depot->town = (Town *)(size_t)_town_index; @@ -57,7 +63,7 @@ static void Ptrs_DEPT() } static const ChunkHandler depot_chunk_handlers[] = { - { 'DEPT', Save_DEPT, Load_DEPT, Ptrs_DEPT, nullptr, CH_ARRAY }, + { 'DEPT', Save_DEPT, Load_DEPT, Ptrs_DEPT, nullptr, CH_TABLE }, }; extern const ChunkHandlerTable _depot_chunk_handlers(depot_chunk_handlers); |