summaryrefslogtreecommitdiffstats
path: root/src/boost/libs/hana/test/tuple/usability_of_types.cpp
blob: 261b47ad00c5963d28900a9af749cbe751be81ef (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
// 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 <boost/hana/at.hpp>
#include <boost/hana/back.hpp>
#include <boost/hana/front.hpp>
#include <boost/hana/integral_constant.hpp>
#include <boost/hana/tuple.hpp>
#include <boost/hana/type.hpp>

#include <type_traits>
namespace hana = boost::hana;


// The fact that a reference to a `type<...>` is returned from `front(types)`
// and friends used to break the `decltype(front(types))::type` pattern,
// because we would be trying to fetch `::type` inside a reference. To work
// around this, a unary `operator+` turning a lvalue `type` into a rvalue
// `type` was added.

struct T; struct U; struct V;

int main() {
    auto check = [](auto types) {
        static_assert(std::is_same<
            typename decltype(+hana::front(types))::type, T
        >{}, "");

        static_assert(std::is_same<
            typename decltype(+hana::at(types, hana::size_c<1>))::type, U
        >{}, "");

        static_assert(std::is_same<
            typename decltype(+hana::back(types))::type, V
        >{}, "");
    };

    check(hana::make_tuple(hana::type_c<T>, hana::type_c<U>, hana::type_c<V>));
    check(hana::tuple_t<T, U, V>);
}