// Copyright Louis Dionne 2013-2017 // 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 #include #include #include #include #include #include namespace hana = boost::hana; using hana::test::ct_eq; int main() { auto container = ::seq; auto f = hana::test::_injection<0>{}; { auto storage = container(); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f() )); } { auto storage = container(ct_eq<0>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f() )); }{ auto storage = container(ct_eq<0>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f(ct_eq<0>{}) )); } { auto storage = container(ct_eq<0>{}, ct_eq<1>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f() )); }{ auto storage = container(ct_eq<0>{}, ct_eq<1>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f(ct_eq<0>{}) )); }{ auto storage = container(ct_eq<0>{}, ct_eq<1>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f(ct_eq<0>{}, ct_eq<1>{}) )); }{ auto storage = container(ct_eq<0>{}, ct_eq<1>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f(ct_eq<1>{}) )); }{ auto storage = container(ct_eq<0>{}, ct_eq<1>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f(ct_eq<1>{}, ct_eq<0>{}) )); } { auto storage = container(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f() )); }{ auto storage = container(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f(ct_eq<0>{}) )); }{ auto storage = container(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f(ct_eq<1>{}) )); }{ auto storage = container(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f(ct_eq<2>{}) )); }{ auto storage = container(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f(ct_eq<0>{}, ct_eq<2>{}) )); }{ auto storage = container(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f(ct_eq<1>{}, ct_eq<1>{}) )); } { auto storage = container(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}, ct_eq<3>{}); auto sliced = hana::experimental::sliced(storage, hana::tuple_c); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::unpack(sliced, f), f(ct_eq<3>{}, ct_eq<1>{}, ct_eq<0>{}, ct_eq<2>{}, ct_eq<2>{}) )); } }