From 04653742243e4bb6452108cfd0fef2f4afd8f23b Mon Sep 17 00:00:00 2001 From: rtk0c Date: Mon, 6 Sep 2021 00:15:35 -0700 Subject: Fix all compile errors, remove OperateIOProxy requirement from DataStream api --- core/src/Utils/IO/TslArrayIntegration.hpp | 26 +++++++++----------------- 1 file changed, 9 insertions(+), 17 deletions(-) (limited to 'core/src/Utils/IO/TslArrayIntegration.hpp') diff --git a/core/src/Utils/IO/TslArrayIntegration.hpp b/core/src/Utils/IO/TslArrayIntegration.hpp index eebea02..af1197c 100644 --- a/core/src/Utils/IO/TslArrayIntegration.hpp +++ b/core/src/Utils/IO/TslArrayIntegration.hpp @@ -1,6 +1,7 @@ #pragma once #include "Utils/IO/DataStream.hpp" +#include "Utils/IO/Helper.hpp" #include "Utils/IO/StringIntegration.hpp" #include @@ -15,43 +16,34 @@ template struct TslArrayMap { template - static void ReadFromDataStream(InputDataStream& s, tsl::robin_map& map) + static void ReadFromDataStream(InputDataStream& stream, tsl::array_map& map) { static_assert(std::is_default_constructible_v); static_assert(std::is_move_constructible_v); uint64_t size; - s.Read(size); + stream.Read(size); map.reserve(size); for (uint64_t i = 0; i < size; ++i) { std::string key; - s.ReadObjectAdapted(key); + stream.ReadObjectAdapted(key); TValue value; - if constexpr (std::is_same_v) { - s.ReadGeneric(value); - } else { - s.ReadObjectAdapted(value); - } + ReadHelper(stream, value); map.insert(key, std::move(value)); } } template - static void WriteToDataStream(OutputDataStream& s, const tsl::robin_map& map) + static void WriteToDataStream(OutputDataStream& stream, const tsl::array_map& map) { - s.Write((uint64_t)map.size()); + stream.Write((uint64_t)map.size()); for (auto it = map.begin(); it != map.end(); ++it) { - s.WriteObjectAdapted(it.key_sv()); - - if constexpr (std::is_same_v) { - s.WriteGeneric(it.value()); - } else { - s.WriteObjectAdapted(it.value()); - } + stream.WriteObjectAdapted(it.key_sv()); + WriteHelper(stream, it.value()); } } }; -- cgit v1.2.3-70-g09d2