File: assign_pair_cxx03.pass.cpp

package info (click to toggle)
llvm-toolchain-19 1%3A19.1.7-3~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm-proposed-updates
  • size: 1,998,492 kB
  • sloc: cpp: 6,951,680; ansic: 1,486,157; asm: 913,598; python: 232,024; f90: 80,126; objc: 75,281; lisp: 37,276; pascal: 16,990; sh: 10,009; ml: 5,058; perl: 4,724; awk: 3,523; makefile: 3,167; javascript: 2,504; xml: 892; fortran: 664; cs: 573
file content (69 lines) | stat: -rw-r--r-- 1,896 bytes parent folder | download | duplicates (11)
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
//===----------------------------------------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//

// REQUIRES: c++03

// <utility>

// template <class T1, class T2> struct pair

// pair& operator=(pair const& p);

#include <utility>
#include <memory>
#include <cassert>

#include "test_macros.h"

struct NonAssignable {
  NonAssignable() {}
private:
  NonAssignable& operator=(NonAssignable const&);
};

struct Incomplete;
extern Incomplete inc_obj;

struct ConstructibleFromInt {
  ConstructibleFromInt() : value(-1) { }
  explicit ConstructibleFromInt(int v) : value(v) { }
  int value;
};

int main(int, char**)
{
    {
      // Test that we don't constrain the assignment operator in C++03 mode.
      // Since we don't have access control SFINAE having pair evaluate SFINAE
      // may cause a hard error.
      typedef std::pair<int, NonAssignable> P;
      static_assert(std::is_copy_assignable<P>::value, "");
    }
    {
      typedef std::pair<int, Incomplete&> P;
      static_assert(std::is_copy_assignable<P>::value, "");
      P p(42, inc_obj);
      assert(&p.second == &inc_obj);
    }
    {
      // The type is constructible from int, but not assignable from int.
      // This ensures that operator=(pair const&) can be used in conjunction with
      // pair(pair<U, V> const&) to mimic operator=(pair<U, V> const&) in C++03.
      // This is weird but valid in C++03.
      std::pair<ConstructibleFromInt, char> p;
      std::pair<int, char> from(11, 'x');
      p = from;
      assert(p.first.value == 11);
      assert(p.second == 'x');
    }

  return 0;
}

struct Incomplete {};
Incomplete inc_obj;