// 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 #include #include #include namespace hana = boost::hana; template auto key() { return hana::test::ct_eq{}; } template auto val() { return hana::test::ct_eq<-i>{}; } template auto p() { return ::minimal_product(key(), val()); } struct undefined { }; int main() { auto sequence = ::seq; // Use pointers to work around a Clang ICE hana::test::_injection<0> f{}; auto* fp = &f; hana::test::ct_eq<999> state{}; auto* statep = &state; auto check = [=](auto ...pairs) { auto possible_results = hana::transform(hana::permutations(sequence(pairs...)), [=](auto xs) { return hana::fold_right(xs, *statep, *fp); } ); BOOST_HANA_CONSTANT_CHECK(hana::contains( possible_results, hana::fold_right(hana::make_map(pairs...), state, f) )); }; check(); check(p<1, 1>()); check(p<1, 1>(), p<2, 2>()); check(p<1, 1>(), p<2, 2>(), p<3, 3>()); check(p<1, 1>(), p<2, 2>(), p<3, 3>(), p<4, 4>()); }