// 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 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()); } int main() { constexpr auto list = ::seq; BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::keys(hana::make_map()), list() )); BOOST_HANA_CONSTANT_CHECK(hana::equal( hana::keys(hana::make_map(p<1, 1>())), list(key<1>()) )); BOOST_HANA_CONSTANT_CHECK(hana::contains( hana::permutations(list(key<1>(), key<2>())), hana::keys(hana::make_map(p<1, 1>(), p<2, 2>())) )); BOOST_HANA_CONSTANT_CHECK(hana::contains( hana::permutations(list(key<1>(), key<2>(), key<3>())), hana::keys(hana::make_map(p<1, 1>(), p<2, 2>(), p<3, 3>())) )); }