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/TslRobinIntegration.hpp | 54 +++++++++---------------------- 1 file changed, 15 insertions(+), 39 deletions(-) (limited to 'core/src/Utils/IO/TslRobinIntegration.hpp') diff --git a/core/src/Utils/IO/TslRobinIntegration.hpp b/core/src/Utils/IO/TslRobinIntegration.hpp index c800e52..50775fe 100644 --- a/core/src/Utils/IO/TslRobinIntegration.hpp +++ b/core/src/Utils/IO/TslRobinIntegration.hpp @@ -1,6 +1,7 @@ #pragma once #include "Utils/IO/DataStream.hpp" +#include "Utils/IO/Helper.hpp" #include #include @@ -11,51 +12,34 @@ template struct TslRobinMap { template - static void ReadFromDataStream(InputDataStream& s, tsl::robin_map& map) + static void ReadFromDataStream(InputDataStream& stream, tsl::robin_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) { TKey key; - if constexpr (std::is_same_v) { - s.ReadGeneric(key); - } else { - s.ReadObjectAdapted(key); - } + ReadHelper(stream, key); TValue value; - if constexpr (std::is_same_v) { - s.ReadGeneric(value); - } else { - s.ReadObjectAdapted(value); - } + ReadHelper(stream, value); map.insert(std::move(key), std::move(value)); } } template - static void WriteToDataStream(OutputDataStream& s, const tsl::robin_map& map) + static void WriteToDataStream(OutputDataStream& stream, const tsl::robin_map& map) { - s.Write((uint64_t)map.size()); + stream.Write((uint64_t)map.size()); for (auto it = map.begin(); it != map.end(); ++it) { - if constexpr (std::is_same_v) { - s.WriteGeneric(it.key()); - } else { - s.WriteObjectAdapted(it.key()); - } - - if constexpr (std::is_same_v) { - s.WriteGeneric(it.value()); - } else { - s.WriteObjectAdapted(it.value()); - } + WriteHelper(stream, it.key()); + WriteHelper(stream, it.value()); } } }; @@ -64,38 +48,30 @@ template struct TslRobinSet { template - static void ReadFromDataStream(InputDataStream& s, tsl::robin_set& set) + static void ReadFromDataStream(InputDataStream& stream, tsl::robin_set& set) { static_assert(std::is_default_constructible_v); static_assert(std::is_move_constructible_v); uint64_t size; - s.Read(size); + stream.Read(size); set.reserve(size); for (uint64_t i = 0; i < size; ++i) { TElement element; - if constexpr (std::is_same_v) { - s.ReadGeneric(element); - } else { - s.ReadObjectAdapted(element); - } + ReadHelper(stream, element); set.insert(std::move(element)); } } template - static void WriteToDataStream(OutputDataStream& s, const tsl::array_set& set) + static void WriteToDataStream(OutputDataStream& stream, const tsl::robin_set& set) { - s.Write((uint64_t)set.size()); + stream.Write((uint64_t)set.size()); for (auto& element : set) { - if constexpr (std::is_same_v) { - s.WriteGeneric(element); - } else { - s.WriteObjectAdapted(element); - } + WriteHelper(stream, element); } } }; -- cgit v1.2.3-70-g09d2