From 70e00f817e9596a746800ba4afec2b7c4ca25142 Mon Sep 17 00:00:00 2001 From: rtk0c Date: Sat, 4 Sep 2021 17:58:56 -0700 Subject: Migrate Template and TableTemplate to use DataStream --- core/src/Utils/IO/VectorIntegration.hpp | 38 +++++++++++++++++++++++---------- 1 file changed, 27 insertions(+), 11 deletions(-) (limited to 'core/src/Utils/IO/VectorIntegration.hpp') diff --git a/core/src/Utils/IO/VectorIntegration.hpp b/core/src/Utils/IO/VectorIntegration.hpp index dedbf29..da663a4 100644 --- a/core/src/Utils/IO/VectorIntegration.hpp +++ b/core/src/Utils/IO/VectorIntegration.hpp @@ -2,31 +2,47 @@ #include "Utils/IO/DataStream.hpp" +#include #include namespace DataStreamAdapters { +template struct Vector { template - void ReadFromDataStream(InputDataStream& s, std::vecetor& vec) + static void ReadFromDataStream(InputDataStream& s, std::vector& vec) { - s.Write((uint64_t)vec.size()); - for (auto& element : vec) { - // TODO - } - } + static_assert(std::is_default_constructible_v); + static_assert(std::is_move_constructible_v); - template - void WriteToDataStream(OutputDataStream& s, const std::vecetor& vec) - { uint64_t size; - s >> size; + s.Read(size); vec.clear(); vec.reserve(size); for (uint64_t i = 0; i < size; ++i) { - // TODO + TElement element; + if constexpr (std::is_same_v) { + s.ReadGeneric(element); + } else { + s.ReadObjectAdapted(element); + } + + vec.push_back(std::move(element)); + } + } + + template + static void WriteToDataStream(OutputDataStream& s, const std::vector& vec) + { + s.Write((uint64_t)vec.size()); + for (auto& element : vec) { + if constexpr (std::is_same_v) { + s.WriteGeneric(element); + } else { + s.WriteObjectAdapted(element); + } } } }; -- cgit v1.2.3-70-g09d2