diff options
author | Adrian Kummerlaender | 2015-01-19 17:09:39 +0100 |
---|---|---|
committer | Adrian Kummerlaender | 2015-01-19 17:09:39 +0100 |
commit | 3cac56267edfbfd26e203ad674b9b8e74e44b14e (patch) | |
tree | 3ddc31c53d2976132f566b7fd382e9a924458bf7 | |
parent | 3c431f8a8eab25cdb1237f6a4e3ef6ac3f2b7479 (diff) | |
download | TypeAsValue-3cac56267edfbfd26e203ad674b9b8e74e44b14e.tar TypeAsValue-3cac56267edfbfd26e203ad674b9b8e74e44b14e.tar.gz TypeAsValue-3cac56267edfbfd26e203ad674b9b8e74e44b14e.tar.bz2 TypeAsValue-3cac56267edfbfd26e203ad674b9b8e74e44b14e.tar.lz TypeAsValue-3cac56267edfbfd26e203ad674b9b8e74e44b14e.tar.xz TypeAsValue-3cac56267edfbfd26e203ad674b9b8e74e44b14e.tar.zst TypeAsValue-3cac56267edfbfd26e203ad674b9b8e74e44b14e.zip |
Implemented `Filter` in terms of `Fold`
* as its name implies this _function_ only returns elements which evaluate to _true_ when passed to a given _function_
** this marks the moment where _TypeAsValue_ supports something _ConstList_ does not, i.e. primary goal is achieved
*** namely returning different types depending on the actual _values_ of a _Cons_ structure
* added appropriate test case
-rw-r--r-- | src/list/operation/basic.h | 4 | ||||
-rw-r--r-- | src/list/operation/higher/misc.h | 32 | ||||
-rw-r--r-- | test.cc | 8 |
3 files changed, 38 insertions, 6 deletions
diff --git a/src/list/operation/basic.h b/src/list/operation/basic.h index 364a542..d80b347 100644 --- a/src/list/operation/basic.h +++ b/src/list/operation/basic.h @@ -13,12 +13,12 @@ class Length { typename, typename Previous > - struct Count { + struct count { typedef Add<Size<1>, Previous> type; }; public: - typedef typename Fold<Count, Size<0>, Cons>::type type; + typedef typename Fold<count, Size<0>, Cons>::type type; }; diff --git a/src/list/operation/higher/misc.h b/src/list/operation/higher/misc.h index 280c0d5..95a5f50 100644 --- a/src/list/operation/higher/misc.h +++ b/src/list/operation/higher/misc.h @@ -3,6 +3,7 @@ #include "fold.h" #include "list/operation/concatenate.h" +#include "conditional/if.h" namespace tav { @@ -16,12 +17,35 @@ class Map { typename Current, typename Previous > - struct FunctionWrapper { + struct function_wrapper { typedef Cons<Function<Current>, Previous> type; }; public: - typedef typename Fold<FunctionWrapper, void, List>::type type; + typedef typename Fold<function_wrapper, void, List>::type type; + +}; + +template < + template<typename> class Function, + typename List +> +class Filter { + private: + template < + typename Current, + typename Previous + > + struct function_wrapper { + typedef If< + Function<Current>::type::value, + Cons<Current, Previous>, + Previous + > type; + }; + + public: + typedef typename Fold<function_wrapper, void, List>::type type; }; @@ -32,7 +56,7 @@ class Reverse { typename Current, typename Previous > - struct ReversedConcatenate { + struct reversed_concatenate { typedef typename Concatenate< Previous, Cons<Current, void> @@ -40,7 +64,7 @@ class Reverse { }; public: - typedef typename Fold<ReversedConcatenate, void, List>::type type; + typedef typename Fold<reversed_concatenate, void, List>::type type; }; @@ -14,6 +14,9 @@ class TypeAsValueTest : public ::testing::Test { }; template <typename Element> using quadruple = tav::Multiply<tav::Int<4>, Element>; +template <typename Element> +using odd = tav::Boolean<(Element::value % 2 == 1)>; + TEST_F(TypeAsValueTest, BasicMath) { // (+ 1 2) EXPECT_EQ(3, ( tav::Add<tav::Int<1>, tav::Int<2>>::value )); @@ -99,6 +102,11 @@ TEST_F(TypeAsValueTest, ListMap) { EXPECT_TRUE(( std::is_same<tav::List<tav::Int<4>, tav::Int<8>, tav::Int<12>>::type, tav::Map<quadruple, tav::List<tav::Int<1>, tav::Int<2>, tav::Int<3>>::type>::type>::value )); } +TEST_F(TypeAsValueTest, ListFilter) { + // (filter odd (list 1 2 3)) + EXPECT_TRUE(( std::is_same<tav::List<tav::Int<1>, tav::Int<3>>::type, tav::Filter<odd, tav::List<tav::Int<1>, tav::Int<2>, tav::Int<3>>::type>::type>::value )); +} + TEST_F(TypeAsValueTest, ListReverse) { // (reverse (list 1 2 3)) EXPECT_TRUE(( std::is_same<tav::List<tav::Int<3>, tav::Int<2>, tav::Int<1>>::type, tav::Reverse<tav::List<tav::Int<1>, tav::Int<2>, tav::Int<3>>::type>::type>::value )); |