From 709274402ff0a83dfaacae880dfa6db478d29ab1 Mon Sep 17 00:00:00 2001 From: Adrian Kummerlaender Date: Mon, 9 Feb 2015 15:46:26 +0100 Subject: Updated `Sort` to make use of `Partition` for splitting at pivot * added further test cases for `Sort` as well as `Nth` aliae --- src/list/operation/higher/sort.h | 13 +++++---- test.cc | 57 +++++++++++++++++++++++++++++++++++++++- 2 files changed, 64 insertions(+), 6 deletions(-) diff --git a/src/list/operation/higher/sort.h b/src/list/operation/higher/sort.h index 0ff5c40..a707a15 100644 --- a/src/list/operation/higher/sort.h +++ b/src/list/operation/higher/sort.h @@ -1,8 +1,9 @@ #ifndef TYPEASVALUE_SRC_LIST_OPERATION_HIGHER_SORT_H_ #define TYPEASVALUE_SRC_LIST_OPERATION_HIGHER_SORT_H_ -#include "filter.h" #include "list/operation/concatenate.h" +#include "list/operation/higher/partition.h" +#include "function/apply.h" namespace tav { @@ -20,11 +21,13 @@ class Sort { typename Drop>, Sequence>::type >::type; - template - using comparator_wrapper = Comparator; + using partitions = typename Partition< + Apply::template single_type, + sequence_sans_pivot + >::type; - using lhs = typename Filter::type; - using rhs = typename Remove::type; + using lhs = typename Car::type; + using rhs = typename Cdr::type; public: typedef typename Concatenate< diff --git a/test.cc b/test.cc index 0dafcb8..3b35cd3 100644 --- a/test.cc +++ b/test.cc @@ -302,6 +302,26 @@ static_assert( "(list void 1 void 2 void) != '(1 . 2)" ); +static_assert( + std::is_same< + tav::Int<1>, + tav::Head< + tav::List, tav::Int<2>, tav::Int<3>>::type + > + >::value, + "(head (list 1 2 3) != 1" +); + +static_assert( + std::is_same< + tav::Pair, tav::Pair, void>>, + tav::Tail< + tav::List, tav::Int<2>, tav::Int<3>>::type + > + >::value, + "(tail (list 1 2 3) != '(2 . 3)" +); + // list of type static_assert( @@ -377,6 +397,30 @@ static_assert( "(nth 1 (list 1 2)) != 2" ); +static_assert( + std::is_same< + tav::Int<1>, + tav::First, tav::Int<2>, tav::Int<3>>::type> + >::value, + "(first (list 1 2 3)) != 1" +); + +static_assert( + std::is_same< + tav::Int<2>, + tav::Second, tav::Int<2>, tav::Int<3>>::type> + >::value, + "(second (list 1 2 3)) != 2" +); + +static_assert( + std::is_same< + tav::Int<3>, + tav::Third, tav::Int<2>, tav::Int<3>>::type> + >::value, + "(third (list 1 2 3)) != 3" +); + // list take static_assert( @@ -558,7 +602,7 @@ static_assert( tav::Pair< tav::List, tav::Int<3>>::type, tav::List>::type - >, + >::type, tav::Partition< tav::Odd, tav::List, tav::Int<2>, tav::Int<3>>::type @@ -921,6 +965,17 @@ static_assert( "(sort < (list 1 3 2)) != (list 3 2 1)" ); +static_assert( + std::is_same< + tav::Iota, tav::Int<1>, tav::Int<1>>::type, + tav::Sort< + tav::GreaterThan, + tav::Iota, tav::Int<42>, tav::Int<-1>>::type + >::type + >::value, + "(sort > (iota 42 42 -1)) != (iota 42 1 1)" +); + // function apply static_assert( -- cgit v1.2.3