summaryrefslogtreecommitdiffstats
path: root/src/boost/libs/hana/test/core/tag_of.cpp
blob: 99afe5c7efc26dc719980a26068349c119866187 (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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
// 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/core/tag_of.hpp>
#include <boost/hana/core/when.hpp>

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


template <typename T, typename ExpectedDatatype>
struct test {
    static_assert(std::is_same<hana::tag_of_t<T>, ExpectedDatatype>::value, "");
    static_assert(std::is_same<hana::tag_of_t<T const>, ExpectedDatatype>::value, "");
    static_assert(std::is_same<hana::tag_of_t<T volatile>, ExpectedDatatype>::value, "");
    static_assert(std::is_same<hana::tag_of_t<T const volatile>, ExpectedDatatype>::value, "");

    static_assert(std::is_same<hana::tag_of_t<T&>, ExpectedDatatype>::value, "");
    static_assert(std::is_same<hana::tag_of_t<T const&>, ExpectedDatatype>::value, "");
    static_assert(std::is_same<hana::tag_of_t<T volatile&>, ExpectedDatatype>::value, "");
    static_assert(std::is_same<hana::tag_of_t<T const volatile&>, ExpectedDatatype>::value, "");

    static_assert(std::is_same<hana::tag_of_t<T&&>, ExpectedDatatype>::value, "");
    static_assert(std::is_same<hana::tag_of_t<T const&&>, ExpectedDatatype>::value, "");
    static_assert(std::is_same<hana::tag_of_t<T volatile&&>, ExpectedDatatype>::value, "");
    static_assert(std::is_same<hana::tag_of_t<T const volatile&&>, ExpectedDatatype>::value, "");
};

struct NestedDatatype;
struct Nested { struct hana_tag; };
template struct test<Nested, Nested::hana_tag>;

struct NoNestedDatatype { };
template struct test<NoNestedDatatype, NoNestedDatatype>;

struct NoNestedHana { };
template struct test<NoNestedHana, NoNestedHana>;


struct FullySpecializedDatatype;
struct FullySpecialized;
namespace boost { namespace hana {
    template <>
    struct tag_of<FullySpecialized> {
        using type = FullySpecializedDatatype;
    };
}}
template struct test<FullySpecialized, FullySpecializedDatatype>;


struct PartiallySpecializedDatatype;
template <typename> struct PartiallySpecialized;
namespace boost { namespace hana {
    template <typename T>
    struct tag_of<PartiallySpecialized<T>> {
        using type = PartiallySpecializedDatatype;
    };
}}
template struct test<PartiallySpecialized<struct anything>, PartiallySpecializedDatatype>;


struct PredicatedDatatype;
struct Predicated { static constexpr bool predicate = true; };
namespace boost { namespace hana {
    template <typename T>
    struct tag_of<T, hana::when<T::predicate>> {
        using type = PredicatedDatatype;
    };
}}
template struct test<Predicated, PredicatedDatatype>;


int main() { }