From ee644efa0c6bf9e5e31e5eb59df49f99d4175876 Mon Sep 17 00:00:00 2001 From: Stanislaw Halik Date: Wed, 14 Feb 2024 19:57:38 +0100 Subject: clean up the vector wrapper --- compat/vector-wrapper-fwd.hpp | 5 ++--- compat/vector-wrapper.hpp | 15 +++++++++------ 2 files changed, 11 insertions(+), 9 deletions(-) (limited to 'compat') diff --git a/compat/vector-wrapper-fwd.hpp b/compat/vector-wrapper-fwd.hpp index 4e4ab371..f3da48bc 100644 --- a/compat/vector-wrapper-fwd.hpp +++ b/compat/vector-wrapper-fwd.hpp @@ -2,15 +2,14 @@ namespace floormat { -template struct vector_wrapper; - enum class vector_wrapper_repr : uint8_t // todo! use this { invalid, lvalue_reference_to_vector, const_reference_to_vector, vector, - //rvalue_reference_to_vector, }; +template struct vector_wrapper; + } // namespace floormat diff --git a/compat/vector-wrapper.hpp b/compat/vector-wrapper.hpp index cb6e7549..5bbb8677 100644 --- a/compat/vector-wrapper.hpp +++ b/compat/vector-wrapper.hpp @@ -1,16 +1,19 @@ #pragma once -#include "vector-wrapper-fwd.hpp" // todo! +#include "vector-wrapper-fwd.hpp" #include namespace floormat { -template +template struct vector_wrapper_traits; + +template struct vector_wrapper_traits { using vector_type = std::vector&; }; +template struct vector_wrapper_traits { using vector_type = const std::vector&; }; +template struct vector_wrapper_traits { using vector_type = std::vector; }; + +template struct vector_wrapper final { - using vector_type = std::conditional_t, const std::vector>, std::vector>; - using qualified_type = std::conditional_t, vector_type, vector_type&>; - - qualified_type vec; + typename vector_wrapper_traits::vector_type vec; }; } // namespace floormat -- cgit v1.2.3