From e3d7bbe61650e672a9625466e75e9097b094f7ad Mon Sep 17 00:00:00 2001 From: ADAM David Alan Martin Date: Mon, 25 Oct 2021 02:08:12 -0400 Subject: [PATCH] Comparison test builds again. Now to extend the functionalization. --- Capabilities.h | 10 +++++----- Meta/find.h | 13 +++++++++---- Meta/functional.h | 2 +- comparisons.test/0.cc | 4 ++-- 4 files changed, 17 insertions(+), 12 deletions(-) diff --git a/Capabilities.h b/Capabilities.h index a1990b9..09e3501 100644 --- a/Capabilities.h +++ b/Capabilities.h @@ -65,17 +65,17 @@ namespace Alepha::Hydrogen constexpr auto has_cap( const Stud::type_identity< Capabilities< Caps... > > & ) { - return Meta::find_if< Meta::bind1st< std::is_base_of, cap >, Meta::list< Caps... > >{}; + return Meta::find_if< Meta::bind1st< std::is_base_of, cap >, Meta::Container::vector< Caps... > >{}; } template< typename cap > - constexpr std::false_type has_cap( const Meta::list<> & ) { return {}; } + constexpr std::false_type has_cap( const Meta::Container::vector<> & ) { return {}; } template< typename cap, typename First, typename ... TParams > constexpr auto - has_cap( const Meta::list< First, TParams... > & ) + has_cap( const Meta::Container::vector< First, TParams... > & ) { - using depth_type= decltype( has_cap< cap >( Meta::list< TParams... >{} ) ); + using depth_type= decltype( has_cap< cap >( Meta::Container::vector< TParams... >{} ) ); if constexpr( is_capability_list_v< First > ) { using bool_type= decltype( has_cap< cap >( Stud::type_identity< First >() ) ); @@ -92,7 +92,7 @@ namespace Alepha::Hydrogen constexpr auto has_cap( const Class< TParams... > & ) { - return has_cap< cap >( Meta::list< TParams... >{} ); + return has_cap< cap >( Meta::Container::vector< TParams... >{} ); } namespace exports diff --git a/Meta/find.h b/Meta/find.h index e9e9fa3..53f5f32 100644 --- a/Meta/find.h +++ b/Meta/find.h @@ -6,7 +6,7 @@ static_assert( __cplusplus > 201700, "C++17 Required" ); #include -#include +#include #include namespace Alepha::Hydrogen::Meta @@ -21,11 +21,16 @@ namespace Alepha::Hydrogen::Meta struct find_if; template< typename Predicate, typename First, typename ... Elements > - struct find_if< Predicate, list< First, Elements... > > - : std::conditional_t< Meta::call< Predicate, First >::value, std::true_type, find_if< Predicate, list< Elements... > > >::type {}; + struct find_if< Predicate, Container::vector< First, Elements... > > + : std::conditional_t + < + Meta::call< Predicate, First >::value, + std::true_type, + find_if< Predicate, Container::vector< Elements... > > + >::type {}; template< typename Predicate > - struct find_if< Predicate, list<> > : std::false_type {}; + struct find_if< Predicate, Container::vector<> > : std::false_type {}; template< typename Predicate, typename List > constexpr bool find_if_v= find_if< Predicate, List >::value; diff --git a/Meta/functional.h b/Meta/functional.h index f84aaf3..82f3987 100644 --- a/Meta/functional.h +++ b/Meta/functional.h @@ -27,7 +27,7 @@ namespace Alepha::Hydrogen::Meta { using type= bind2nd; template< typename Arg > - struct call : Function< Arg, second >::type {}; + struct call : Function< Arg, Second >::type {}; }; template< typename Function, typename ... Args > diff --git a/comparisons.test/0.cc b/comparisons.test/0.cc index 3a863e9..0c22a08 100644 --- a/comparisons.test/0.cc +++ b/comparisons.test/0.cc @@ -8,8 +8,8 @@ static_assert( __cplusplus > 201700, "C++17 Required" ); namespace { - using Alepha::Testing::argcnt_t; - using Alepha::Testing::argvec_t; + using Alepha::exports::types::argcnt_t; + using Alepha::exports::types::argvec_t; } int