summaryrefslogtreecommitdiff
path: root/src/saveload/group_sl.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/saveload/group_sl.cpp')
-rw-r--r--src/saveload/group_sl.cpp46
1 files changed, 25 insertions, 21 deletions
diff --git a/src/saveload/group_sl.cpp b/src/saveload/group_sl.cpp
index 6c510b6e6..d286f1f20 100644
--- a/src/saveload/group_sl.cpp
+++ b/src/saveload/group_sl.cpp
@@ -28,38 +28,42 @@ static const SaveLoad _group_desc[] = {
SLE_CONDVAR(Group, parent, SLE_UINT16, SLV_189, SL_MAX_VERSION),
};
-static void Save_GRPS()
-{
- SlTableHeader(_group_desc);
+struct GRPSChunkHandler : ChunkHandler {
+ GRPSChunkHandler() : ChunkHandler('GRPS', CH_TABLE) {}
- for (Group *g : Group::Iterate()) {
- SlSetArrayIndex(g->index);
- SlObject(g, _group_desc);
+ void Save() const override
+ {
+ SlTableHeader(_group_desc);
+
+ for (Group *g : Group::Iterate()) {
+ SlSetArrayIndex(g->index);
+ SlObject(g, _group_desc);
+ }
}
-}
-static void Load_GRPS()
-{
- const std::vector<SaveLoad> slt = SlCompatTableHeader(_group_desc, _group_sl_compat);
+ void Load() const override
+ {
+ const std::vector<SaveLoad> slt = SlCompatTableHeader(_group_desc, _group_sl_compat);
- int index;
+ int index;
- while ((index = SlIterateArray()) != -1) {
- Group *g = new (index) Group();
- SlObject(g, slt);
+ while ((index = SlIterateArray()) != -1) {
+ Group *g = new (index) Group();
+ SlObject(g, slt);
- if (IsSavegameVersionBefore(SLV_189)) g->parent = INVALID_GROUP;
+ if (IsSavegameVersionBefore(SLV_189)) g->parent = INVALID_GROUP;
- if (IsSavegameVersionBefore(SLV_GROUP_LIVERIES)) {
- const Company *c = Company::Get(g->owner);
- g->livery.colour1 = c->livery[LS_DEFAULT].colour1;
- g->livery.colour2 = c->livery[LS_DEFAULT].colour2;
+ if (IsSavegameVersionBefore(SLV_GROUP_LIVERIES)) {
+ const Company *c = Company::Get(g->owner);
+ g->livery.colour1 = c->livery[LS_DEFAULT].colour1;
+ g->livery.colour2 = c->livery[LS_DEFAULT].colour2;
+ }
}
}
-}
+};
-static const ChunkHandler GRPS{ 'GRPS', Save_GRPS, Load_GRPS, nullptr, nullptr, CH_TABLE };
+static const GRPSChunkHandler GRPS;
static const ChunkHandlerRef group_chunk_handlers[] = {
GRPS,
};