2
0
mirror of https://github.com/boostorg/hana.git synced 2026-02-22 15:32:11 +00:00
Files
hana/test/sandbox/repeat.cpp
2014-07-16 16:26:23 -04:00

78 lines
2.0 KiB
C++

/*
@copyright Louis Dionne 2014
Distributed under the Boost Software License, Version 1.0.
(See accompanying file LICENSE.md or copy at http://boost.org/LICENSE_1_0.txt)
*/
#include <boost/hana/bool.hpp>
#include <boost/hana/detail/static_assert.hpp>
#include <boost/hana/functional.hpp>
#include <boost/hana/integral.hpp>
#include <boost/hana/iterable/foldable_instance.hpp>
#include <boost/hana/iterable/mcd.hpp>
#include <boost/hana/lazy.hpp>
#include <boost/hana/list/instance.hpp>
#include <boost/hana/list/mcd.hpp>
using namespace boost::hana;
struct LazyList;
template <typename X, typename Xs>
struct lazy_cons_type {
X x;
Xs xs;
using hana_datatype = LazyList;
};
auto lazy_cons = [](auto x, auto xs) {
return lazy_cons_type<decltype(x), decltype(xs)>{x, xs};
};
struct lazy_nil_type { using hana_datatype = LazyList; };
constexpr lazy_nil_type lazy_nil{};
auto repeat = fix([](auto repeat, auto x) {
return lazy_cons(x, lazy(repeat)(x));
});
namespace boost { namespace hana {
template <>
struct Iterable::instance<LazyList> : Iterable::mcd {
template <typename Xs>
static constexpr auto head_impl(Xs lcons)
{ return lcons.x; }
template <typename Xs>
static constexpr auto tail_impl(Xs lcons)
{ return eval(lcons.xs); }
template <typename Xs>
static constexpr auto is_empty_impl(Xs lcons)
{ return false_; }
static constexpr auto is_empty_impl(lazy_nil_type)
{ return true_; }
};
template <>
struct List::instance<LazyList> : List::mcd<LazyList> {
static constexpr auto nil_impl()
{ return lazy_nil; }
template <typename X, typename Xs>
static constexpr auto cons_impl(X x, Xs xs)
{ return lazy_cons(x, lazy(xs)); }
};
}}
int main() {
BOOST_HANA_STATIC_ASSERT(!is_empty(repeat(1)));
BOOST_HANA_STATIC_ASSERT(head(repeat(1)) == 1);
BOOST_HANA_STATIC_ASSERT(at(int_<10>, repeat(1)) == 1);
BOOST_HANA_STATIC_ASSERT(take(int_<2>, repeat('x')) == list('x', 'x'));
}