| // RUN: %clang_cc1 -fsyntax-only -verify %s |
| // RUN: %clang_cc1 -fsyntax-only -verify -std=c++98 %s |
| // RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s |
| |
| class Base { // expected-warning{{class 'Base' does not declare any constructor to initialize its non-modifiable members}} |
| #if __cplusplus <= 199711L |
| // expected-error@-2 {{cannot define the implicit copy assignment operator for 'Base', because non-static reference member 'ref' cannot use copy assignment operator}} |
| #endif |
| |
| int &ref; // expected-note{{reference member 'ref' will never be initialized}} |
| #if __cplusplus <= 199711L |
| // expected-note@-2 {{declared here}} |
| #else |
| // expected-note@-4 2 {{copy assignment operator of 'Base' is implicitly deleted because field 'ref' is of reference type 'int &'}} |
| #endif |
| }; |
| |
| class X : Base { |
| #if __cplusplus <= 199711L |
| // expected-note@-2 {{assignment operator for 'Base' first required here}} |
| // expected-error@-3 {{cannot define the implicit copy assignment operator for 'X', because non-static const member 'cint' cannot use copy assignment operator}} |
| #else |
| // expected-note@-5 2 {{copy assignment operator of 'X' is implicitly deleted because base class 'Base' has a deleted copy assignment operator}} |
| #endif |
| |
| public: |
| X(); |
| const int cint; |
| #if __cplusplus <= 199711L |
| // expected-note@-2 {{declared here}} |
| #endif |
| }; |
| |
| struct Y : X { |
| Y(); |
| Y& operator=(const Y&); |
| Y& operator=(volatile Y&); |
| Y& operator=(const volatile Y&); |
| Y& operator=(Y&); |
| }; |
| |
| class Z : Y {}; |
| |
| Z z1; |
| Z z2; |
| |
| // Test1 |
| void f(X x, const X cx) { |
| x = cx; |
| #if __cplusplus <= 199711L |
| // expected-note@-2 2{{assignment operator for 'X' first required here}} |
| #else |
| // expected-error@-4 {{object of type 'X' cannot be assigned because its copy assignment operator is implicitly deleted}} |
| #endif |
| |
| x = cx; |
| #if __cplusplus >= 201103L |
| // expected-error@-2 {{object of type 'X' cannot be assigned because its copy assignment operator is implicitly deleted}} |
| #endif |
| z1 = z2; |
| } |
| |
| // Test2 |
| class T {}; |
| T t1; |
| T t2; |
| |
| void g() { |
| t1 = t2; |
| } |
| |
| // Test3 |
| class V { |
| public: |
| V(); |
| V &operator = (V &b); |
| }; |
| |
| class W : V {}; |
| W w1, w2; |
| |
| void h() { |
| w1 = w2; |
| } |
| |
| // Test4 |
| |
| class B1 { |
| public: |
| B1(); |
| B1 &operator = (B1 b); |
| }; |
| |
| class D1 : B1 {}; |
| D1 d1, d2; |
| |
| void i() { |
| d1 = d2; |
| } |
| |
| // Test5 |
| |
| class E1 { |
| #if __cplusplus <= 199711L |
| // expected-error@-2 {{cannot define the implicit copy assignment operator for 'E1', because non-static const member 'a' cannot use copy assignment operator}} |
| #endif |
| |
| public: |
| const int a; |
| #if __cplusplus <= 199711L |
| // expected-note@-2 {{declared here}} |
| #else |
| // expected-note@-4 {{copy assignment operator of 'E1' is implicitly deleted because field 'a' is of const-qualified type 'const int'}} |
| #endif |
| E1() : a(0) {} |
| |
| }; |
| |
| E1 e1, e2; |
| |
| void j() { |
| e1 = e2; |
| #if __cplusplus <= 199711L |
| // expected-note@-2 {{assignment operator for 'E1' first required here}} |
| #else |
| // expected-error@-4 {{object of type 'E1' cannot be assigned because its copy assignment operator is implicitly deleted}} |
| #endif |
| } |
| |
| namespace ProtectedCheck { |
| struct X { |
| protected: |
| X &operator=(const X&); |
| #if __cplusplus <= 199711L |
| // expected-note@-2 {{declared protected here}} |
| #endif |
| }; |
| |
| struct Y : public X { }; |
| |
| void f(Y y) { y = y; } |
| |
| struct Z { |
| #if __cplusplus <= 199711L |
| // expected-error@-2 {{'operator=' is a protected member of 'ProtectedCheck::X'}} |
| #endif |
| X x; |
| #if __cplusplus >= 201103L |
| // expected-note@-2 {{copy assignment operator of 'Z' is implicitly deleted because field 'x' has an inaccessible copy assignment operator}} |
| #endif |
| }; |
| |
| void f(Z z) { z = z; } |
| #if __cplusplus <= 199711L |
| // expected-note@-2 {{implicit copy assignment operator}} |
| #else |
| // expected-error@-4 {{object of type 'ProtectedCheck::Z' cannot be assigned because its copy assignment operator is implicitly deleted}} |
| #endif |
| } |
| |
| namespace MultiplePaths { |
| struct X0 { |
| X0 &operator=(const X0&); |
| }; |
| |
| struct X1 : public virtual X0 { }; |
| |
| struct X2 : X0, X1 { }; // expected-warning{{direct base 'MultiplePaths::X0' is inaccessible due to ambiguity:\n struct MultiplePaths::X2 -> struct MultiplePaths::X0\n struct MultiplePaths::X2 -> struct MultiplePaths::X1 -> struct MultiplePaths::X0}} |
| |
| void f(X2 x2) { x2 = x2; } |
| } |