diff options
Implemented higher order `Find` list search operation
* added appropriate test case
* other queries in `query.h` may be redefined in terms of `Find`
Diffstat (limited to 'src/list/operation/higher/query.h')
-rw-r--r-- | src/list/operation/higher/query.h | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/src/list/operation/higher/query.h b/src/list/operation/higher/query.h index 198ffa5..d2b8e76 100644 --- a/src/list/operation/higher/query.h +++ b/src/list/operation/higher/query.h @@ -9,41 +9,41 @@ namespace tav { template < - template<typename> class Function, + template<typename> class Predicate, typename List > using Any = Fold< Or, Boolean<false>, - typename Map<Function, List>::type + typename Map<Predicate, List>::type >; template < - template<typename> class Function, + template<typename> class Predicate, typename List > using All = Fold< And, Boolean<true>, - typename Map<Function, List>::type + typename Map<Predicate, List>::type >; template < - template<typename> class Function, + template<typename> class Predicate, typename List > using None = Not< - typename Any<Function, List>::type + typename Any<Predicate, List>::type >; template < - template<typename> class Function, + template<typename> class Predicate, typename List > using Count = Fold< Add, tav::Size<0>, - typename Map<Function, List>::type + typename Map<Predicate, List>::type >; } |