From 0cbc85dd74103ec5c7b2ac5802721ccf051d8454 Mon Sep 17 00:00:00 2001 From: Adrian Kummerlaender Date: Fri, 23 Jan 2015 19:22:01 +0100 Subject: Implemented `Iota` list constructor * recursively generates a list of `Count` elements starting at `Initial` and consecutively adding `Step` ** as most functionality of this library this function was modeled after its _Scheme_ equivalent `iota` ** it may be used as the foundation of a set of higher order list generators including e.g. `list-tabulate` * added appropriate test cases --- test.cc | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) (limited to 'test.cc') diff --git a/test.cc b/test.cc index b945899..173aa19 100644 --- a/test.cc +++ b/test.cc @@ -5,6 +5,7 @@ #include "list/cons.h" #include "list/list.h" +#include "list/iota.h" #include "list/operation/reverse.h" #include "list/operation/contains.h" #include "list/operation/higher/fold.h" @@ -507,3 +508,41 @@ static_assert( >::value, "(length (concatenate (list (list 1 2) (list 3) (list 4 5 6)))) != 6" ); + +// list iota + +static_assert( + std::is_same< + tav::List, tav::Int<2>, tav::Int<3>>::type, + tav::Iota< + tav::Size<3>, + tav::Int<1>, + tav::Int<1> + >::type + >::value, + "(iota 3 1 1) != (list 1 2 3)" +); + +static_assert( + std::is_same< + tav::List, tav::Int<2>, tav::Int<4>, tav::Int<6>, tav::Int<8>>::type, + tav::Iota< + tav::Size<5>, + tav::Int<0>, + tav::Int<2> + >::type + >::value, + "(iota 5 0 2) != (list 0 2 4 6 8)" +); + +static_assert( + std::is_same< + tav::List, tav::Int<4>, tav::Int<3>, tav::Int<2>, tav::Int<1>>::type, + tav::Iota< + tav::Size<5>, + tav::Int<5>, + tav::Int<-1> + >::type + >::value, + "(iota 5 5 -1) != (list 5 4 3 2 1)" +); -- cgit v1.2.3