hana/test/_include/auto/index_if.hpp
Jason Rice 6d086796a3 [index_if] New index_if function
- Adds index_if
    - Rewrites detail::index_if to use recursive alias stuff
      optimized for tuple and basic_tuple
    - find_if now uses index_if for Iterables
    - at_key now uses index_if for Sequence
    - Removes duplicate code and unnecessary special case implementations
        - detail::advance_until
        - at_key::advance_until
        - tuple_tag implementation of find_if
    - Uses Foldable instead of Sequence for cases where length is known.
      (find_if had a specialization when Iterable and not Sequence)
    - Adds test.*.auto.index_if for Sequences
    - Adds test support/counter for testing infinite iterables
2017-04-07 16:19:52 -07:00

82 lines
2.8 KiB
C++

// Copyright Louis Dionne 2013-2017
// Copyright Jason Rice 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_INDEX_IF_HPP
#define BOOST_HANA_TEST_AUTO_INDEX_IF_HPP
#include <boost/hana/assert.hpp>
#include <boost/hana/equal.hpp>
#include <boost/hana/index_if.hpp>
#include <boost/hana/integral_constant.hpp>
#include <boost/hana/optional.hpp>
#include "test_case.hpp"
#include <laws/base.hpp>
#include <support/tracked.hpp>
namespace _test_index_if_detail { template <int> struct invalid { }; }
TestCase test_index_if{[]{
namespace hana = boost::hana;
using hana::test::ct_eq;
using _test_index_if_detail::invalid;
BOOST_HANA_CONSTANT_CHECK(hana::equal(
hana::index_if(MAKE_TUPLE(), hana::equal.to(ct_eq<0>{})),
hana::nothing
));
BOOST_HANA_CONSTANT_CHECK(hana::equal(
hana::index_if(MAKE_TUPLE(ct_eq<0>{}), hana::equal.to(ct_eq<0>{})),
hana::just(hana::size_c<0>)
));
BOOST_HANA_CONSTANT_CHECK(hana::equal(
hana::index_if(MAKE_TUPLE(ct_eq<0>{}), hana::equal.to(ct_eq<42>{})),
hana::nothing
));
BOOST_HANA_CONSTANT_CHECK(hana::equal(
hana::index_if(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}), hana::equal.to(ct_eq<0>{})),
hana::just(hana::size_c<0>)
));
BOOST_HANA_CONSTANT_CHECK(hana::equal(
hana::index_if(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}), hana::equal.to(ct_eq<1>{})),
hana::just(hana::size_c<1>)
));
BOOST_HANA_CONSTANT_CHECK(hana::equal(
hana::index_if(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}), hana::equal.to(ct_eq<2>{})),
hana::just(hana::size_c<2>)
));
BOOST_HANA_CONSTANT_CHECK(hana::equal(
hana::index_if(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}), hana::equal.to(ct_eq<42>{})),
hana::nothing
));
#ifndef MAKE_TUPLE_NO_CONSTEXPR
auto type_equal = [](auto type) { return [=](auto&& value) {
return hana::equal(hana::typeid_(value), type);
};};
static_assert(decltype(hana::equal(
hana::index_if(MAKE_TUPLE(1, '2', 3.3), type_equal(hana::type_c<int>)),
hana::just(hana::size_c<0>)
)){}, "");
static_assert(decltype(hana::equal(
hana::index_if(MAKE_TUPLE(1, '2', 3.3), type_equal(hana::type_c<char>)),
hana::just(hana::size_c<1>)
)){}, "");
static_assert(decltype(hana::equal(
hana::index_if(MAKE_TUPLE(1, '2', 3.3), type_equal(hana::type_c<double>)),
hana::just(hana::size_c<2>)
)){}, "");
static_assert(decltype(hana::equal(
hana::index_if(MAKE_TUPLE(1, '2', 3.3), type_equal(hana::type_c<invalid<42>>)),
hana::nothing
)){}, "");
#endif
}};
#endif // !BOOST_HANA_TEST_AUTO_INDEX_IF_HPP