summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/saveload/saveload.cpp179
1 files changed, 78 insertions, 101 deletions
diff --git a/src/saveload/saveload.cpp b/src/saveload/saveload.cpp
index 40f631e31..97f4a82d0 100644
--- a/src/saveload/saveload.cpp
+++ b/src/saveload/saveload.cpp
@@ -1218,6 +1218,66 @@ static void *IntToReference(size_t index, SLRefType rt)
}
/**
+ * Template class to help with list-like types.
+ */
+template <template<typename, typename> typename Tstorage, typename Tvar, typename Tallocator = std::allocator<Tvar>>
+class SlStorageHelper {
+ typedef Tstorage<Tvar, Tallocator> SlStorageT;
+public:
+ /**
+ * Internal templated helper to return the size in bytes of a list-like type.
+ * @param storage The storage to find the size of
+ * @param conv VarType type of variable that is used for calculating the size
+ */
+ static size_t SlCalcLen(const void *storage, VarType conv)
+ {
+ const SlStorageT *list = static_cast<const SlStorageT *>(storage);
+
+ int type_size = SlCalcConvFileLen(SLE_FILE_U32); // Size of the length of the list.
+ int item_size = SlCalcConvFileLen(conv);
+ return list->size() * item_size + type_size;
+ }
+
+ /**
+ * Internal templated helper to save/load a list-like type.
+ * @param storage The storage being manipulated.
+ * @param conv VarType type of variable that is used for calculating the size.
+ */
+ static void SlSaveLoad(void *storage, VarType conv)
+ {
+ SlStorageT *list = static_cast<SlStorageT *>(storage);
+
+ switch (_sl.action) {
+ case SLA_SAVE: {
+ SlWriteUint32((uint32)list->size());
+
+ for (auto &item : *list) {
+ SlSaveLoadConv(&item, conv);
+ }
+ break;
+ }
+ case SLA_LOAD_CHECK:
+ case SLA_LOAD: {
+ size_t length = SlReadUint32();
+
+ /* Load each value and push to the end of the storage. */
+ for (size_t i = 0; i < length; i++) {
+ Tvar &data = list->emplace_back();
+ SlSaveLoadConv(&data, conv);
+ }
+ break;
+ }
+ case SLA_PTRS:
+ break;
+ case SLA_NULL:
+ list->clear();
+ break;
+ default: NOT_REACHED();
+ }
+ }
+};
+
+/**
* Return the size in bytes of a list
* @param list The std::list to find the size of
*/
@@ -1231,7 +1291,6 @@ static inline size_t SlCalcListLen(const void *list)
return l->size() * type_size + type_size;
}
-
/**
* Save/Load a list.
* @param list The list being manipulated
@@ -1289,71 +1348,6 @@ static void SlList(void *list, SLRefType conv)
}
}
-
-/**
- * Template class to help with std::deque.
- */
-template <typename T>
-class SlDequeHelper {
- typedef std::deque<T> SlDequeT;
-public:
- /**
- * Internal templated helper to return the size in bytes of a std::deque.
- * @param deque The std::deque to find the size of
- * @param conv VarType type of variable that is used for calculating the size
- */
- static size_t SlCalcDequeLen(const void *deque, VarType conv)
- {
- const SlDequeT *l = (const SlDequeT *)deque;
-
- int type_size = 4;
- /* Each entry is saved as type_size bytes, plus type_size bytes are used for the length
- * of the list */
- return l->size() * SlCalcConvFileLen(conv) + type_size;
- }
-
- /**
- * Internal templated helper to save/load a std::deque.
- * @param deque The std::deque being manipulated
- * @param conv VarType type of variable that is used for calculating the size
- */
- static void SlDeque(void *deque, VarType conv)
- {
- SlDequeT *l = (SlDequeT *)deque;
-
- switch (_sl.action) {
- case SLA_SAVE: {
- SlWriteUint32((uint32)l->size());
-
- typename SlDequeT::iterator iter;
- for (iter = l->begin(); iter != l->end(); ++iter) {
- SlSaveLoadConv(&(*iter), conv);
- }
- break;
- }
- case SLA_LOAD_CHECK:
- case SLA_LOAD: {
- size_t length = SlReadUint32();
-
- /* Load each value and push to the end of the deque */
- for (size_t i = 0; i < length; i++) {
- T data;
- SlSaveLoadConv(&data, conv);
- l->push_back(data);
- }
- break;
- }
- case SLA_PTRS:
- break;
- case SLA_NULL:
- l->clear();
- break;
- default: NOT_REACHED();
- }
- }
-};
-
-
/**
* Return the size in bytes of a std::deque.
* @param deque The std::deque to find the size of
@@ -1362,25 +1356,19 @@ public:
static inline size_t SlCalcDequeLen(const void *deque, VarType conv)
{
switch (GetVarMemType(conv)) {
- case SLE_VAR_BL:
- return SlDequeHelper<bool>::SlCalcDequeLen(deque, conv);
- case SLE_VAR_I8:
- case SLE_VAR_U8:
- return SlDequeHelper<uint8>::SlCalcDequeLen(deque, conv);
- case SLE_VAR_I16:
- case SLE_VAR_U16:
- return SlDequeHelper<uint16>::SlCalcDequeLen(deque, conv);
- case SLE_VAR_I32:
- case SLE_VAR_U32:
- return SlDequeHelper<uint32>::SlCalcDequeLen(deque, conv);
- case SLE_VAR_I64:
- case SLE_VAR_U64:
- return SlDequeHelper<uint64>::SlCalcDequeLen(deque, conv);
+ case SLE_VAR_BL: return SlStorageHelper<std::deque, bool>::SlCalcLen(deque, conv);
+ case SLE_VAR_I8: return SlStorageHelper<std::deque, int8>::SlCalcLen(deque, conv);
+ case SLE_VAR_U8: return SlStorageHelper<std::deque, uint8>::SlCalcLen(deque, conv);
+ case SLE_VAR_I16: return SlStorageHelper<std::deque, int16>::SlCalcLen(deque, conv);
+ case SLE_VAR_U16: return SlStorageHelper<std::deque, uint16>::SlCalcLen(deque, conv);
+ case SLE_VAR_I32: return SlStorageHelper<std::deque, int32>::SlCalcLen(deque, conv);
+ case SLE_VAR_U32: return SlStorageHelper<std::deque, uint32>::SlCalcLen(deque, conv);
+ case SLE_VAR_I64: return SlStorageHelper<std::deque, int64>::SlCalcLen(deque, conv);
+ case SLE_VAR_U64: return SlStorageHelper<std::deque, uint64>::SlCalcLen(deque, conv);
default: NOT_REACHED();
}
}
-
/**
* Save/load a std::deque.
* @param deque The std::deque being manipulated
@@ -1389,30 +1377,19 @@ static inline size_t SlCalcDequeLen(const void *deque, VarType conv)
static void SlDeque(void *deque, VarType conv)
{
switch (GetVarMemType(conv)) {
- case SLE_VAR_BL:
- SlDequeHelper<bool>::SlDeque(deque, conv);
- break;
- case SLE_VAR_I8:
- case SLE_VAR_U8:
- SlDequeHelper<uint8>::SlDeque(deque, conv);
- break;
- case SLE_VAR_I16:
- case SLE_VAR_U16:
- SlDequeHelper<uint16>::SlDeque(deque, conv);
- break;
- case SLE_VAR_I32:
- case SLE_VAR_U32:
- SlDequeHelper<uint32>::SlDeque(deque, conv);
- break;
- case SLE_VAR_I64:
- case SLE_VAR_U64:
- SlDequeHelper<uint64>::SlDeque(deque, conv);
- break;
+ case SLE_VAR_BL: SlStorageHelper<std::deque, bool>::SlSaveLoad(deque, conv); break;
+ case SLE_VAR_I8: SlStorageHelper<std::deque, int8>::SlSaveLoad(deque, conv); break;
+ case SLE_VAR_U8: SlStorageHelper<std::deque, uint8>::SlSaveLoad(deque, conv); break;
+ case SLE_VAR_I16: SlStorageHelper<std::deque, int16>::SlSaveLoad(deque, conv); break;
+ case SLE_VAR_U16: SlStorageHelper<std::deque, uint16>::SlSaveLoad(deque, conv); break;
+ case SLE_VAR_I32: SlStorageHelper<std::deque, int32>::SlSaveLoad(deque, conv); break;
+ case SLE_VAR_U32: SlStorageHelper<std::deque, uint32>::SlSaveLoad(deque, conv); break;
+ case SLE_VAR_I64: SlStorageHelper<std::deque, int64>::SlSaveLoad(deque, conv); break;
+ case SLE_VAR_U64: SlStorageHelper<std::deque, uint64>::SlSaveLoad(deque, conv); break;
default: NOT_REACHED();
}
}
-
/** Are we going to save this object or not? */
static inline bool SlIsObjectValidInSavegame(const SaveLoad &sld)
{