2
0
mirror of https://github.com/boostorg/hana.git synced 2026-02-18 14:12:11 +00:00
Files
hana/test/sandbox/repeat.cpp
2014-06-21 15:10:06 -04:00

61 lines
1.5 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/detail/sandbox/lazy.hpp>
#include <boost/hana/detail/static_assert.hpp>
#include <boost/hana/functional.hpp>
#include <boost/hana/integral.hpp>
#include <boost/hana/iterable.hpp>
using namespace boost::hana;
struct LazyList;
template <typename X, typename Xs>
struct lcons_type {
X x;
Xs xs;
using hana_datatype = LazyList;
};
auto lcons = [](auto x, auto xs) {
return lcons_type<decltype(x), decltype(xs)>{x, xs};
};
auto repeat = fix([](auto repeat, auto x) {
return lcons(x, sandbox::lazy<>(repeat)(x));
});
namespace boost { namespace hana {
template <>
struct Iterable<LazyList> : defaults<Iterable>::with<LazyList> {
template <typename Xs>
static constexpr auto head_impl(Xs lcons)
{ return lcons.x; }
template <typename Xs>
static constexpr auto tail_impl(Xs lcons)
{ return lcons.xs.eval(); }
template <typename Xs>
static constexpr auto is_empty_impl(Xs lcons)
{ return false_; }
};
template <>
constexpr bool foldable_from_iterable<LazyList> = true;
template <>
constexpr bool comparable_from_iterable<LazyList> = true;
}}
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);
}