From ba235622db7a79567166ea363dd3c0c3ef353d98 Mon Sep 17 00:00:00 2001 From: Stanislaw Halik Date: Tue, 15 Nov 2022 23:33:41 +0100 Subject: now that it's done, remove it It can always be brought back later. --- src/entity.hpp | 147 -------------------------------------------------------- test/entity.cpp | 52 -------------------- 2 files changed, 199 deletions(-) diff --git a/src/entity.hpp b/src/entity.hpp index 51698651..44f6295a 100644 --- a/src/entity.hpp +++ b/src/entity.hpp @@ -4,9 +4,7 @@ #include #include #include -#include #include -#include #include namespace floormat {} @@ -192,151 +190,6 @@ constexpr CORRADE_ALWAYS_INLINE bool find_in_tuple(F&& fun, Tuple&& tuple) return false; } -template struct parameter_pack; - -template class F, typename Acc, typename T, typename... Fs> -struct reduce0_; - -template class F, typename Acc, template class X, typename... Fs> -struct reduce0_, Fs...> { - using type = Acc; -}; - -template class F, typename Acc, template class X, typename T, typename... Ts, typename... Fs> -struct reduce0_, Fs...> { - using type = typename reduce0_< F, F, parameter_pack, Fs... >::type; -}; - -template class F, typename Acc, typename X, typename... Fs> -using reduce0 = typename reduce0_::type; - -template class F, typename X, typename... Fs> -struct reduce_; - -template class F, template class X, typename T1, typename... Ts, typename... Fs> -struct reduce_, Fs...> { - using type = typename reduce0_< F, T1, parameter_pack, Fs... >::type; -}; - -template class F, typename T, typename... Fs> -using reduce = typename reduce_::type; - -template typename C, typename... Args2> -struct lift_; - -template class C, template class T, typename... Args, typename... CArgs> -struct lift_, C, CArgs...> { - using type = C; -}; - -template class C, typename... CArgs> -using lift = typename lift_::type; - -template class F, template class C, typename T, typename... Us> -struct map_; - -template class F, template class C, template class X, typename... Ts, typename... Us> -struct map_, Us...> { - using type = C...>; -}; - -template class F, typename X, typename... Us> -using map = typename map_::type; - -template -struct skip_; - -template class Tuple, typename T, typename... Ts> -struct skip_> { - using type = typename skip_>::type; -}; - -template class Tuple, typename... Ts> -struct skip_<0, Tuple> { using type = parameter_pack; }; - -template class Tuple, typename T, typename... Ts> -struct skip_<0, Tuple> { - using type = parameter_pack; -}; - -template -using skip = typename skip_::type; - -template -struct take_; - -template class Tuple, typename... Ts, typename... As> -struct take_<0, parameter_pack, Tuple> { - using type = parameter_pack; -}; - -template class Tuple, typename T1, typename... Ts> -struct take_<0, parameter_pack, Tuple> { - using type = parameter_pack; -}; - -template class Tuple, typename T1, typename... Ts> -struct take_, Tuple> { - using type = typename take_, parameter_pack>::type; -}; - -template -using take = typename take_, T>::type; - -template -struct nth_; - -template class X, typename T, typename... Ts> -struct nth_> { - using type = typename nth_>::type; -}; - -template class X, typename T, typename... Ts> -struct nth_<0, X> { - using type = T; -}; - -template -using nth = typename nth_::type; - -template -struct except_nth_; - -template class X, typename... As, typename T, typename... Ts> -struct except_nth_, X> { - using type = typename except_nth_, parameter_pack>::type; -}; - -template class X, typename T, typename... Ts> -struct except_nth_<0, parameter_pack, X> { - using type = parameter_pack; -}; - -template -using except_nth = typename except_nth_, T>::type; - -template -struct sort_tuple_ { - template - static consteval auto sort_indices(const Tuple& tuple, const std::index_sequence&) { - std::array indices = { Is..., }; - using KeyT = decltype(KeyFn(std::get<0>(tuple))); - std::array keys = { KeyFn(std::get(tuple))..., }; - std::sort(indices.begin(), indices.end(), [&](std::size_t a, std::size_t b) { return Comp(keys[a], keys[b]); }); - return indices; - } - - template - struct helper { - template - static consteval auto do_sort(const Tuple& tuple, const std::index_sequence&) { - return std::make_tuple(std::get(tuple)...); - } - }; -}; - - - } // namespace detail template diff --git a/test/entity.cpp b/test/entity.cpp index e1bbb055..8266ec47 100644 --- a/test/entity.cpp +++ b/test/entity.cpp @@ -64,62 +64,10 @@ static constexpr bool test_visitor() return true; } -namespace test_sorting { - -template -struct item { - static constexpr std::size_t size = I-1; - std::array data; - consteval item(const char(&str)[I]) { - std::copy(str, str+I, data.data()); - } - template - constexpr bool operator==(const item& o) const { return data == o.data; } -}; - -static constexpr void test() -{ - using namespace floormat::entities::detail; - constexpr auto tuple = std::make_tuple(item{"bb"}, item{"aaa"}, item{"cccc"}, item{"d"}); - constexpr auto size = std::tuple_size_v>; - constexpr auto key = [](const auto& x) constexpr { return StringView(x.data.data(), x.data.size()); }; - constexpr auto comp = [](auto a, auto b) constexpr { return a < b; }; - using Sort = sort_tuple_, key, comp>; - constexpr auto indices = Sort::sort_indices(tuple, std::make_index_sequence()); - constexpr auto tuple2 = Sort::helper::do_sort(tuple, std::make_index_sequence()); - static_assert(tuple2 == std::make_tuple(item{"aaa"}, item{"bb"}, item{"cccc"}, item{"d"})); -} - -} // namespace test_sorting - void test_app::test_entity() { static_assert(test_accessors()); static_assert(test_visitor()); - test_sorting::test(); } -namespace type_tests { - -using namespace floormat::entities::detail; - -template using common_type2 = std::common_type_t; -static_assert(std::is_same_v>>); -static_assert(std::is_same_v, - map>>); - -static_assert(std::is_same_v, - map>>); -static_assert(std::is_same_v, lift, std::tuple, int>>); -static_assert(std::is_same_v, - skip<3, std::tuple>>); -static_assert(std::is_same_v, - take<3, std::tuple>>); -static_assert(std::is_same_v>>); - -static_assert(std::is_same_v, - except_nth<2, parameter_pack>>); - -} // namespace type_tests - } // namespace floormat -- cgit v1.2.3