blob: 845173934219cf1f3a8fbe331aa2e56e164ef170 (
about) (
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
|
// RUN: %clang_cc1 -fsyntax-only -verify %s
struct A { };
A::A() { } // expected-error {{definition of implicitly declared default constructor}}
struct B { };
B::B(const B&) { } // expected-error {{definition of implicitly declared copy constructor}}
struct C { };
C& C::operator=(const C&) { return *this; } // expected-error {{definition of implicitly declared copy assignment operator}}
struct D { };
D::~D() { } // expected-error {{definition of implicitly declared destructor}}
// Make sure that the special member functions are introduced for
// name-lookup purposes and overload with user-declared
// constructors and assignment operators.
namespace PR6570 {
class A { };
class B {
public:
B() {}
B(const A& a) {
operator = (CONST);
operator = (a);
}
B& operator = (const A& a) {
return *this;
}
void f(const A &a) {
B b(a);
};
static const B CONST;
};
}
namespace PR7594 {
// If the lazy declaration of special member functions is triggered
// in an out-of-line initializer, make sure the functions aren't in
// the initializer scope. This used to crash Clang:
struct C {
C();
static C *c;
};
C *C::c = new C();
}
|