File: optional_test_ref_to_val.cpp

package info (click to toggle)
boost1.83 1.83.0-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 545,632 kB
  • sloc: cpp: 3,857,086; xml: 125,552; ansic: 34,414; python: 25,887; asm: 5,276; sh: 4,799; ada: 1,681; makefile: 1,629; perl: 1,212; pascal: 1,139; sql: 810; yacc: 478; ruby: 102; lisp: 24; csh: 6
file content (116 lines) | stat: -rw-r--r-- 2,825 bytes parent folder | download | duplicates (7)
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
106
107
108
109
110
111
112
113
114
115
116
// Copyright (C) 2016 Andrzej Krzemienski.
//
// Use, modification, and distribution is subject to 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)
//
// See http://www.boost.org/lib/optional for documentation.
//
// You are welcome to contact the author at:
//  akrzemi1@gmail.com


#include "boost/optional/optional.hpp"

#ifdef BOOST_BORLANDC
#pragma hdrstop
#endif

#include "boost/core/lightweight_test.hpp"

using boost::optional;
using boost::none;

struct Value
{
  int val;
  explicit Value(int v) : val(v) {}
};

int val(int const& i)
{
  return i;
}

int val(Value const& v)
{
  return v.val;
}

template <typename Tref>
optional<Tref&> make_opt_ref(Tref& v)
{
  return optional<Tref&>(v);
}

template <typename Tval, typename Tref>
void test_construct_from_optional_ref()
{
    Tref v1 (1), v2 (2);
    
    optional<Tref&> opt_ref0;
    optional<Tref&> opt_ref1 (v1);
    
    optional<Tval> opt_val0 (opt_ref0);
    optional<Tval> opt_val1 (opt_ref1);
    optional<Tval> opt_val2 (make_opt_ref(v2));
    
    BOOST_TEST (!opt_val0);
    BOOST_TEST (opt_val1);
    BOOST_TEST (opt_val2);
    
    BOOST_TEST_EQ (1, val(*opt_val1));
    BOOST_TEST_EQ (2, val(*opt_val2));
    
    BOOST_TEST (boost::addressof(*opt_val1) != boost::addressof(v1));
    BOOST_TEST (boost::addressof(*opt_val2) != boost::addressof(v2));
}

template <typename Tval, typename Tref>
void test_assign_from_optional_ref()
{
    Tref v1 (1), v2 (2);
    
    optional<Tref&> opt_ref0;
    optional<Tref&> opt_ref1 (v1);
    
    optional<Tval> opt_val0;
    optional<Tval> opt_val1;
    optional<Tval> opt_val2;
    
    opt_val0 = opt_ref0;
    opt_val1 = opt_ref1;
    opt_val2 = make_opt_ref(v2);
    
    BOOST_TEST (!opt_val0);
    BOOST_TEST (opt_val1);
    BOOST_TEST (opt_val2);
    
    BOOST_TEST_EQ (1, val(*opt_val1));
    BOOST_TEST_EQ (2, val(*opt_val2));
    
    BOOST_TEST (boost::addressof(*opt_val1) != boost::addressof(v1));
    BOOST_TEST (boost::addressof(*opt_val2) != boost::addressof(v2));
}


int main()
{
    test_construct_from_optional_ref<int, int>();
    test_construct_from_optional_ref<int, int const>();
    test_construct_from_optional_ref<int const, int const>();
    test_construct_from_optional_ref<int const, int>();
    
    test_construct_from_optional_ref<Value, Value>();
    test_construct_from_optional_ref<Value, Value const>();
    test_construct_from_optional_ref<Value const, Value const>();
    test_construct_from_optional_ref<Value const, Value>();
    
    test_assign_from_optional_ref<int, int>();
    test_assign_from_optional_ref<int, int const>();

    test_assign_from_optional_ref<Value, Value>();
    test_assign_from_optional_ref<Value, Value const>();

    return boost::report_errors();
}