// 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) #ifndef BOOST_HANA_TEST_AUTO_ALL_OF_HPP #define BOOST_HANA_TEST_AUTO_ALL_OF_HPP #include #include #include #include #include #include "test_case.hpp" #include TestCase test_all_of{[]{ namespace hana = boost::hana; using hana::test::ct_eq; BOOST_HANA_CONSTANT_CHECK(hana::all_of( MAKE_TUPLE(), [](auto) { return hana::false_c; } )); BOOST_HANA_CONSTANT_CHECK(hana::all_of( MAKE_TUPLE(ct_eq<0>{}), [](auto) { return hana::true_c; } )); BOOST_HANA_CONSTANT_CHECK(hana::not_(hana::all_of( MAKE_TUPLE(ct_eq<0>{}), [](auto) { return hana::false_c; } ))); BOOST_HANA_CONSTANT_CHECK(hana::all_of( MAKE_TUPLE(ct_eq<0>{}), hana::equal.to(ct_eq<0>{}) )); BOOST_HANA_CONSTANT_CHECK(hana::not_(hana::all_of( MAKE_TUPLE(ct_eq<0>{}), hana::equal.to(ct_eq<999>{}) ))); BOOST_HANA_CONSTANT_CHECK(hana::all_of( MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}), [](auto) { return hana::true_c; } )); BOOST_HANA_CONSTANT_CHECK(hana::not_(hana::all_of( MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}), [](auto) { return hana::false_c; } ))); BOOST_HANA_CONSTANT_CHECK(hana::all_of( MAKE_TUPLE(ct_eq<0>{}, ct_eq<0>{}), hana::equal.to(ct_eq<0>{}) )); BOOST_HANA_CONSTANT_CHECK(hana::not_(hana::all_of( MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}), hana::equal.to(ct_eq<0>{}) ))); BOOST_HANA_CONSTANT_CHECK(hana::all_of( MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}), [](auto) { return hana::true_c; } )); BOOST_HANA_CONSTANT_CHECK(hana::not_(hana::all_of( MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}), [](auto) { return hana::false_c; } ))); BOOST_HANA_CONSTANT_CHECK(hana::all_of( MAKE_TUPLE(ct_eq<0>{}, ct_eq<0>{}, ct_eq<0>{}), hana::equal.to(ct_eq<0>{}) )); BOOST_HANA_CONSTANT_CHECK(hana::not_(hana::all_of( MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<0>{}), hana::equal.to(ct_eq<0>{}) ))); BOOST_HANA_CONSTANT_CHECK(hana::all_of( MAKE_TUPLE(ct_eq<0>{}, ct_eq<0>{}, ct_eq<0>{}, ct_eq<0>{}), hana::equal.to(ct_eq<0>{}) )); BOOST_HANA_CONSTANT_CHECK(hana::not_(hana::all_of( MAKE_TUPLE(ct_eq<999>{}, ct_eq<0>{}, ct_eq<0>{}, ct_eq<0>{}), hana::equal.to(ct_eq<0>{}) ))); BOOST_HANA_CONSTANT_CHECK(hana::not_(hana::all_of( MAKE_TUPLE(ct_eq<0>{}, ct_eq<999>{}, ct_eq<0>{}, ct_eq<0>{}), hana::equal.to(ct_eq<0>{}) ))); BOOST_HANA_CONSTANT_CHECK(hana::not_(hana::all_of( MAKE_TUPLE(ct_eq<0>{}, ct_eq<0>{}, ct_eq<999>{}, ct_eq<0>{}), hana::equal.to(ct_eq<0>{}) ))); BOOST_HANA_CONSTANT_CHECK(hana::not_(hana::all_of( MAKE_TUPLE(ct_eq<0>{}, ct_eq<0>{}, ct_eq<0>{}, ct_eq<999>{}), hana::equal.to(ct_eq<0>{}) ))); // Make sure `all_of` short-circuits with runtime predicates // See http://stackoverflow.com/q/42012512/627587 { { int counter = 0; auto tuple = MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}); hana::all_of(tuple, [&](auto) { ++counter; return false; }); BOOST_HANA_RUNTIME_CHECK(counter == 1); } { int counter = 0; auto tuple = MAKE_TUPLE(ct_eq<0>{}, ct_eq<999>{}, ct_eq<0>{}); hana::all_of(tuple, [&](auto x) -> bool { ++counter; return hana::equal(x, ct_eq<0>{}); }); BOOST_HANA_RUNTIME_CHECK(counter == 2); } } }}; #endif // !BOOST_HANA_TEST_AUTO_ALL_OF_HPP