File: variant_eq_ne_cx.cpp

package info (click to toggle)
boost1.90 1.90.0-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 593,156 kB
  • sloc: cpp: 4,190,642; xml: 196,648; python: 34,618; ansic: 23,145; asm: 5,468; sh: 3,776; makefile: 1,161; perl: 1,020; sql: 728; ruby: 676; yacc: 478; java: 77; lisp: 24; csh: 6
file content (105 lines) | stat: -rw-r--r-- 2,439 bytes parent folder | download | duplicates (10)
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105

// Copyright 2017, 2019 Peter Dimov
//
// Distributed under the Boost Software License, Version 1.0.
//
// See accompanying file LICENSE_1_0.txt or copy at
// http://www.boost.org/LICENSE_1_0.txt

#include <boost/variant2/variant.hpp>
using namespace boost::variant2;

#if !defined(BOOST_MP11_HAS_CXX14_CONSTEXPR)

#include <boost/config/pragma_message.hpp>

BOOST_PRAGMA_MESSAGE("Skipping constexpr op==, op!= test because BOOST_MP11_HAS_CXX14_CONSTEXPR is not defined")

int main() {}

#else

struct X
{
};

inline constexpr bool operator==( X const&, X const& ) { return false; }
inline constexpr bool operator!=( X const&, X const& ) { return false; }

#define STATIC_ASSERT(...) static_assert(__VA_ARGS__, #__VA_ARGS__)

int main()
{
    {
        constexpr variant<int> v1, v2, v3( 1 ), v4( 1 );

        STATIC_ASSERT( v1 == v2 );
        STATIC_ASSERT( !(v1 != v2) );

        STATIC_ASSERT( v1 != v3 );
        STATIC_ASSERT( !(v1 == v3) );

        STATIC_ASSERT( v3 == v4 );
        STATIC_ASSERT( !(v3 != v4) );
    }

    {
        constexpr variant<int, float> v1, v2, v3( 1 ), v4( 1 ), v5( 3.14f ), v6( 3.14f );

        STATIC_ASSERT( v1 == v2 );
        STATIC_ASSERT( !(v1 != v2) );

        STATIC_ASSERT( v1 != v3 );
        STATIC_ASSERT( !(v1 == v3) );

        STATIC_ASSERT( v3 == v4 );
        STATIC_ASSERT( !(v3 != v4) );

        STATIC_ASSERT( v1 != v5 );
        STATIC_ASSERT( !(v1 == v5) );

        STATIC_ASSERT( v3 != v5 );
        STATIC_ASSERT( !(v3 == v5) );

        STATIC_ASSERT( v5 == v6 );
        STATIC_ASSERT( !(v5 != v6) );
    }

    {
        constexpr variant<int, int, float> v1, v2, v3( in_place_index_t<1>{} ), v4( in_place_index_t<1>{} ), v5( 3.14f ), v6( 3.14f );

        STATIC_ASSERT( v1 == v2 );
        STATIC_ASSERT( !(v1 != v2) );

        STATIC_ASSERT( v1 != v3 );
        STATIC_ASSERT( !(v1 == v3) );

        STATIC_ASSERT( v3 == v4 );
        STATIC_ASSERT( !(v3 != v4) );

        STATIC_ASSERT( v1 != v5 );
        STATIC_ASSERT( !(v1 == v5) );

        STATIC_ASSERT( v3 != v5 );
        STATIC_ASSERT( !(v3 == v5) );

        STATIC_ASSERT( v5 == v6 );
        STATIC_ASSERT( !(v5 != v6) );
    }

    {
        constexpr variant<X> v1, v2;

        STATIC_ASSERT( !(v1 == v2) );
        STATIC_ASSERT( !(v1 != v2) );
    }

    {
        constexpr variant<monostate> v1, v2;

        STATIC_ASSERT( v1 == v2 );
        STATIC_ASSERT( !(v1 != v2) );
    }
}

#endif