[clang] 9657385 - [AST] Dont invalide VarDecl even the default initializaiton is failed.
Haojian Wu via cfe-commits
cfe-commits at lists.llvm.org
Tue Apr 14 04:00:10 PDT 2020
Author: Haojian Wu
Date: 2020-04-14T12:58:48+02:00
New Revision: 9657385960350150b77ed652175b4c3801abd7fa
URL: https://github.com/llvm/llvm-project/commit/9657385960350150b77ed652175b4c3801abd7fa
DIFF: https://github.com/llvm/llvm-project/commit/9657385960350150b77ed652175b4c3801abd7fa.diff
LOG: [AST] Dont invalide VarDecl even the default initializaiton is failed.
Summary:
This patch would cause clang emit more diagnostics, but it is much better than https://reviews.llvm.org/D76831
```cpp
struct A {
A(int);
~A() = delete;
};
void k() {
A a;
}
```
before the patch:
/tmp/t3.cpp:24:5: error: no matching constructor for initialization of 'A'
A a;
^
/tmp/t3.cpp:20:3: note: candidate constructor not viable: requires 1 argument, but 0 were provided
A(int);
^
/tmp/t3.cpp:19:8: note: candidate constructor (the implicit copy constructor) not viable: requires 1 argument, but 0 were provided
struct A {
After the patch:
/tmp/t3.cpp:24:5: error: no matching constructor for initialization of 'A'
A a;
^
/tmp/t3.cpp:20:3: note: candidate constructor not viable: requires 1 argument, but 0 were provided
A(int);
^
/tmp/t3.cpp:19:8: note: candidate constructor (the implicit copy constructor) not viable: requires 1 argument, but 0 were provided
struct A {
^
/tmp/t3.cpp:24:5: error: attempt to use a deleted function
A a;
^
/tmp/t3.cpp:21:3: note: '~A' has been explicitly marked deleted here
~A() = delete;
Reviewers: sammccall
Reviewed By: sammccall
Subscribers: cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D77395
Added:
clang/test/AST/ast-dump-invalid-initialized.cpp
clang/test/CodeCompletion/invalid-initialized-class.cpp
Modified:
clang/lib/Sema/SemaDecl.cpp
clang/test/CXX/class.access/p4.cpp
clang/test/CXX/drs/dr3xx.cpp
clang/test/CXX/special/class.ctor/p5-0x.cpp
clang/test/SemaCXX/cxx0x-deleted-default-ctor.cpp
clang/test/SemaCXX/virtual-base-used.cpp
clang/test/SemaObjCXX/arc-0x.mm
Removed:
################################################################################
diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp
index 494a1cd1a685..9a93cb5d8ef2 100644
--- a/clang/lib/Sema/SemaDecl.cpp
+++ b/clang/lib/Sema/SemaDecl.cpp
@@ -12553,9 +12553,10 @@ void Sema::ActOnUninitializedDecl(Decl *RealDecl) {
InitializationSequence InitSeq(*this, Entity, Kind, None);
ExprResult Init = InitSeq.Perform(*this, Entity, Kind, None);
- if (Init.isInvalid())
- Var->setInvalidDecl();
- else if (Init.get()) {
+
+ // If default-init fails, leave var uninitialized but valid, for recovery.
+
+ if (Init.get()) {
Var->setInit(MaybeCreateExprWithCleanups(Init.get()));
// This is important for template substitution.
Var->setInitStyle(VarDecl::CallInit);
diff --git a/clang/test/AST/ast-dump-invalid-initialized.cpp b/clang/test/AST/ast-dump-invalid-initialized.cpp
new file mode 100644
index 000000000000..800a79cc831b
--- /dev/null
+++ b/clang/test/AST/ast-dump-invalid-initialized.cpp
@@ -0,0 +1,19 @@
+// RUN: not %clang_cc1 -triple x86_64-unknown-unknown -Wno-unused-value -fcxx-exceptions -std=gnu++17 -ast-dump %s | FileCheck -strict-whitespace %s
+
+struct A { A(int, int) {} };
+class ForwardDecl;
+
+void test() {
+ // CHECK: `-VarDecl {{.*}} a1 'A'
+ A a1;
+ // CHECK: `-VarDecl {{.*}} a2 'const A'
+ const A a2;
+ // CHECK: `-VarDecl {{.*}} a3 'A'
+ A a3 = garbage();
+
+
+ // CHECK: `-VarDecl {{.*}} invalid b1 'const A &'
+ const A& b1;
+ // CHECK: `-VarDecl {{.*}} invalid b2 'ForwardDecl'
+ ForwardDecl b2;
+}
\ No newline at end of file
diff --git a/clang/test/CXX/class.access/p4.cpp b/clang/test/CXX/class.access/p4.cpp
index adc8bbe29583..b110683f0be8 100644
--- a/clang/test/CXX/class.access/p4.cpp
+++ b/clang/test/CXX/class.access/p4.cpp
@@ -220,14 +220,14 @@ namespace test3 {
};
class Derived3 :
- Base<0>, // expected-note {{deleted because base class 'Base<0>' has an inaccessible destructor}}
+ Base<0>, // expected-note 2{{deleted because base class 'Base<0>' has an inaccessible destructor}}
virtual Base<1>,
Base2,
virtual Base3
{};
- Derived3 d3; // expected-error {{implicitly-deleted default constructor}}
+ Derived3 d3; // expected-error {{implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
#elif __cplusplus >= 201103L && defined(_MSC_VER)
- template <unsigned N> class Base { ~Base(); }; // expected-note 6{{declared private here}}
+ template <unsigned N> class Base { ~Base(); }; // expected-note 9{{declared private here}}
// expected-error at +1 {{inherited virtual base class 'Base<2>' has private destructor}}
class Base2 : virtual Base<2> { ~Base2(); }; // expected-note 1{{declared private here}}
// expected-error at +1 {{inherited virtual base class 'Base<3>' has private destructor}}
@@ -249,13 +249,15 @@ namespace test3 {
~Derived2() {}
};
- class Derived3 :
+ class Derived3 : // expected-error 3{{has private destructor}}
Base<0>, // expected-note {{deleted because base class 'Base<0>' has an inaccessible destructor}}
+ // expected-note at -1 {{destructor of 'Derived3' is implicitly deleted}}
virtual Base<1>,
Base2,
virtual Base3
{};
- Derived3 d3; // expected-error {{implicitly-deleted default constructor}}
+ Derived3 d3; // expected-error {{implicitly-deleted default constructor}} expected-error {{use a deleted function}}
+ // expected-note at -1 {{implicit destructor for}}
#else
#error "missing case of MSVC cross C++ versions"
#endif
diff --git a/clang/test/CXX/drs/dr3xx.cpp b/clang/test/CXX/drs/dr3xx.cpp
index a1501fa563b1..efeed66306c0 100644
--- a/clang/test/CXX/drs/dr3xx.cpp
+++ b/clang/test/CXX/drs/dr3xx.cpp
@@ -429,8 +429,8 @@ namespace dr330 { // dr330: 7
namespace dr331 { // dr331: yes
struct A {
- A(volatile A&); // expected-note {{candidate}}
- } const a, b(a); // expected-error {{no matching constructor}}
+ A(volatile A&); // expected-note 2{{candidate}}
+ } const a, b(a); // expected-error 2{{no matching constructor}}
}
namespace dr332 { // dr332: dup 577
diff --git a/clang/test/CXX/special/class.ctor/p5-0x.cpp b/clang/test/CXX/special/class.ctor/p5-0x.cpp
index 5fa61008e8b7..3026f095ef8a 100644
--- a/clang/test/CXX/special/class.ctor/p5-0x.cpp
+++ b/clang/test/CXX/special/class.ctor/p5-0x.cpp
@@ -4,7 +4,7 @@ struct DefaultedDefCtor1 {};
struct DefaultedDefCtor2 { DefaultedDefCtor2() = default; };
struct DeletedDefCtor { DeletedDefCtor() = delete; DeletedDefCtor(int); }; // expected-note {{explicitly marked deleted here}}
class PrivateDefCtor { PrivateDefCtor() = default; public: PrivateDefCtor(int); };
-struct DeletedDtor { ~DeletedDtor() = delete; }; // expected-note 4{{explicitly marked deleted here}}
+struct DeletedDtor { ~DeletedDtor() = delete; }; // expected-note 8{{explicitly marked deleted here}}
class PrivateDtor { ~PrivateDtor() = default; };
class Friend {
Friend() = default; ~Friend() = default;
@@ -122,22 +122,22 @@ NotDeleted6c nd6c;
// - any direct or virtual base class or non-static data member has a type with
// a destructor that is deleted or inaccessible from the defaulted default
// constructor.
-struct Deleted7a : DeletedDtor {}; // expected-note {{because base class 'DeletedDtor' has a deleted destructor}}
-Deleted7a d7a; // expected-error {{implicitly-deleted default constructor}}
-struct Deleted7b : virtual DeletedDtor {}; // expected-note {{because base class 'DeletedDtor' has a deleted destructor}}
-Deleted7b d7b; // expected-error {{implicitly-deleted default constructor}}
-struct Deleted7c { DeletedDtor a; }; // expected-note {{because field 'a' has a deleted destructor}}
-Deleted7c d7c; // expected-error {{implicitly-deleted default constructor}}
-struct Deleted7d { DeletedDtor a = {}; }; // expected-note {{because field 'a' has a deleted destructor}}
-Deleted7d d7d; // expected-error {{implicitly-deleted default constructor}}
-struct Deleted7e : PrivateDtor {}; // expected-note {{base class 'PrivateDtor' has an inaccessible destructor}}
-Deleted7e d7e; // expected-error {{implicitly-deleted default constructor}}
-struct Deleted7f : virtual PrivateDtor {}; // expected-note {{base class 'PrivateDtor' has an inaccessible destructor}}
-Deleted7f d7f; // expected-error {{implicitly-deleted default constructor}}
-struct Deleted7g { PrivateDtor a; }; // expected-note {{field 'a' has an inaccessible destructor}}
-Deleted7g d7g; // expected-error {{implicitly-deleted default constructor}}
-struct Deleted7h { PrivateDtor a = {}; }; // expected-note {{field 'a' has an inaccessible destructor}}
-Deleted7h d7h; // expected-error {{implicitly-deleted default constructor}}
+struct Deleted7a : DeletedDtor {}; // expected-note 2{{because base class 'DeletedDtor' has a deleted destructor}}
+Deleted7a d7a; // expected-error {{implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
+struct Deleted7b : virtual DeletedDtor {}; // expected-note 2{{because base class 'DeletedDtor' has a deleted destructor}}
+Deleted7b d7b; // expected-error {{implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
+struct Deleted7c { DeletedDtor a; }; // expected-note 2{{because field 'a' has a deleted destructor}}
+Deleted7c d7c; // expected-error {{implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
+struct Deleted7d { DeletedDtor a = {}; }; // expected-note 2{{because field 'a' has a deleted destructor}}
+Deleted7d d7d; // expected-error {{implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
+struct Deleted7e : PrivateDtor {}; // expected-note 2{{base class 'PrivateDtor' has an inaccessible destructor}}
+Deleted7e d7e; // expected-error {{implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
+struct Deleted7f : virtual PrivateDtor {}; // expected-note 2{{base class 'PrivateDtor' has an inaccessible destructor}}
+Deleted7f d7f; // expected-error {{implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
+struct Deleted7g { PrivateDtor a; }; // expected-note 2{{field 'a' has an inaccessible destructor}}
+Deleted7g d7g; // expected-error {{implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
+struct Deleted7h { PrivateDtor a = {}; }; // expected-note 2{{field 'a' has an inaccessible destructor}}
+Deleted7h d7h; // expected-error {{implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
struct NotDeleted7i : Friend {};
NotDeleted7i d7i;
struct NotDeleted7j : virtual Friend {};
diff --git a/clang/test/CodeCompletion/invalid-initialized-class.cpp b/clang/test/CodeCompletion/invalid-initialized-class.cpp
new file mode 100644
index 000000000000..9fb584ef5ef0
--- /dev/null
+++ b/clang/test/CodeCompletion/invalid-initialized-class.cpp
@@ -0,0 +1,15 @@
+struct Foo { Foo(int); int abc; };
+
+void test1() {
+ Foo foo;
+ foo.;
+ // RUN: not %clang_cc1 -fsyntax-only -code-completion-at=%s:5:7 %s -o - | FileCheck -check-prefix=CHECK-CC1 %s
+ // CHECK-CC1: COMPLETION: abc
+}
+
+void test2() {
+ Foo foo = garbage();
+ foo.;
+ // RUN: not %clang_cc1 -fsyntax-only -code-completion-at=%s:12:7 %s -o - | FileCheck -check-prefix=CHECK-CC2 %s
+ // CHECK-CC2: COMPLETION: abc
+}
diff --git a/clang/test/SemaCXX/cxx0x-deleted-default-ctor.cpp b/clang/test/SemaCXX/cxx0x-deleted-default-ctor.cpp
index feb483546c3e..7a43fb5437d8 100644
--- a/clang/test/SemaCXX/cxx0x-deleted-default-ctor.cpp
+++ b/clang/test/SemaCXX/cxx0x-deleted-default-ctor.cpp
@@ -8,9 +8,9 @@ struct non_trivial {
};
union bad_union {
- non_trivial nt; // expected-note {{non-trivial default constructor}}
+ non_trivial nt; // expected-note {{non-trivial default constructor}} expected-note {{destructor of 'bad_union' is implicitly deleted}}
};
-bad_union u; // expected-error {{call to implicitly-deleted default constructor}}
+bad_union u; // expected-error {{call to implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
union bad_union2 { // expected-note {{all data members are const-qualified}}
const int i;
};
@@ -18,10 +18,10 @@ bad_union2 u2; // expected-error {{call to implicitly-deleted default constructo
struct bad_anon {
union {
- non_trivial nt; // expected-note {{non-trivial default constructor}}
+ non_trivial nt; // expected-note {{non-trivial default constructor}} expected-note {{destructor of 'bad_anon' is implicitly deleted}}
};
};
-bad_anon a; // expected-error {{call to implicitly-deleted default constructor}}
+bad_anon a; // expected-error {{call to implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
struct bad_anon2 {
union { // expected-note {{all data members of an anonymous union member are const-qualified}}
const int i;
@@ -62,7 +62,7 @@ struct no_default {
no_default() = delete; // expected-note 5{{deleted here}}
};
struct no_dtor {
- ~no_dtor() = delete; // expected-note 2{{deleted here}}
+ ~no_dtor() = delete; // expected-note 4{{deleted here}}
};
struct bad_field_default {
@@ -74,12 +74,12 @@ struct bad_base_default : no_default { // expected-note {{base class 'no_default
bad_base_default bbd; // expected-error {{call to implicitly-deleted default constructor}}
struct bad_field_dtor {
- no_dtor nd; // expected-note {{field 'nd' has a deleted destructor}}
+ no_dtor nd; // expected-note {{field 'nd' has a deleted destructor}} expected-note {{destructor of 'bad_field_dtor' is implicitly deleted }}
};
-bad_field_dtor bfx; // expected-error {{call to implicitly-deleted default constructor}}
-struct bad_base_dtor : no_dtor { // expected-note {{base class 'no_dtor' has a deleted destructor}}
+bad_field_dtor bfx; // expected-error {{call to implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
+struct bad_base_dtor : no_dtor { // expected-note {{base class 'no_dtor' has a deleted destructor}} expected-note {{destructor of 'bad_base_dtor' is implicitly deleted}}
};
-bad_base_dtor bbx; // expected-error {{call to implicitly-deleted default constructor}}
+bad_base_dtor bbx; // expected-error {{call to implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
struct ambiguous_default {
ambiguous_default();
diff --git a/clang/test/SemaCXX/virtual-base-used.cpp b/clang/test/SemaCXX/virtual-base-used.cpp
index d84ad9c9e585..ad0aa62a359c 100644
--- a/clang/test/SemaCXX/virtual-base-used.cpp
+++ b/clang/test/SemaCXX/virtual-base-used.cpp
@@ -40,6 +40,7 @@ struct B : public virtual A {
// expected-note at -7 {{destructor of 'B' is implicitly deleted because field 'x' has an inaccessible destructor}}
#ifdef MSABI
// expected-note at -9 {{default constructor of 'B' is implicitly deleted because field 'x' has an inaccessible destructor}}
+ // expected-note at -10 {{destructor of 'B' is implicitly deleted}}
#endif
#endif
};
@@ -59,6 +60,10 @@ struct D : public virtual B {
~D();
#if __cplusplus >= 201103L
//expected-error at -2 {{non-deleted function '~D' cannot override a deleted function}}
+#ifdef MSABI
+//expected-error at -4 {{use a deleted function}}
+#else
+#endif
#endif
};
@@ -68,6 +73,7 @@ D d;
// expected-note at -2 2{{implicit default constructor for 'D' first required here}}
#else
// expected-error at -4 {{call to implicitly-deleted default constructor of 'D'}}
+// expected-note at -5 {{implicit destructor for 'D' first required here}}
#endif
#else
void D::foo() {
@@ -92,6 +98,7 @@ struct E : public virtual A {
// expected-note at -7 {{destructor of 'E' is implicitly deleted because field 'x' has an inaccessible destructor}}
#ifdef MSABI
// expected-note at -9 {{default constructor of 'E' is implicitly deleted because field 'x' has an inaccessible destructor}}
+ // expected-note at -10 {{destructor of 'E' is implicitly deleted}}
#endif
#endif
};
@@ -106,6 +113,7 @@ struct F : public E {
// expected-note at -7 {{overridden virtual function is here}}
#ifdef MSABI
// expected-note at -9 {{default constructor of 'F' is implicitly deleted because base class 'E' has a deleted default constructor}}
+// expected-note at -10 {{destructor of 'F' is implicitly deleted}}
#endif
#endif
};
@@ -125,6 +133,9 @@ struct G : public virtual F {
~G();
#if __cplusplus >= 201103L
//expected-error at -2 {{non-deleted function '~G' cannot override a deleted function}}
+#ifdef MSABI
+ //expected-error at -4 {{use a deleted function}}
+#endif
#endif
};
@@ -134,6 +145,7 @@ G g;
// expected-note at -2 2{{implicit default constructor for 'G' first required here}}
#else
// expected-error at -4 {{call to implicitly-deleted default constructor of 'G'}}
+// expected-note at -5 {{mplicit destructor for 'G' first required here}}
#endif
#else
void G::foo() {
@@ -159,6 +171,7 @@ struct H : public virtual A {
// expected-note at -7 {{destructor of 'H' is implicitly deleted because field 'x' has an inaccessible destructor}}
#ifdef MSABI
// expected-note at -9 {{default constructor of 'H' is implicitly deleted because field 'x' has an inaccessible destructor}}
+ // expected-note at -10 {{destructor of 'H' is implicitly deleted}}
#endif
#endif
};
@@ -188,6 +201,11 @@ struct J : public I {
virtual void foo();
~J();
+#ifdef MSABI
+#if __cplusplus >= 201103L
+//expected-error at -3 {{use a deleted function}}
+#endif
+#endif
};
#ifdef MSABI
@@ -196,6 +214,7 @@ J j;
// expected-note at -2 2{{implicit default constructor for 'J' first required here}}
#else
// expected-error at -4 {{call to implicitly-deleted default constructor of 'J'}}
+// expected-note at -5 {{implicit destructor for 'J' first required here}}
#endif
#else
diff --git a/clang/test/SemaObjCXX/arc-0x.mm b/clang/test/SemaObjCXX/arc-0x.mm
index 052c99ac13c8..7a4fa4432a03 100644
--- a/clang/test/SemaObjCXX/arc-0x.mm
+++ b/clang/test/SemaObjCXX/arc-0x.mm
@@ -116,13 +116,13 @@ void test() {
// Implicitly-declared special functions of a union are deleted by default if
// ARC is enabled and the union has an ObjC pointer field.
union U0 {
- id f0; // expected-note 6 {{'U0' is implicitly deleted because variant field 'f0' is an ObjC pointer}}
+ id f0; // expected-note 7 {{'U0' is implicitly deleted because variant field 'f0' is an ObjC pointer}}
};
union U1 {
- __weak id f0; // expected-note 12 {{'U1' is implicitly deleted because variant field 'f0' is an ObjC pointer}}
+ __weak id f0; // expected-note 13 {{'U1' is implicitly deleted because variant field 'f0' is an ObjC pointer}}
U1() = default; // expected-warning {{explicitly defaulted default constructor is implicitly deleted}} expected-note {{explicitly defaulted function was implicitly deleted here}}
- ~U1() = default; // expected-warning {{explicitly defaulted destructor is implicitly deleted}} expected-note {{explicitly defaulted function was implicitly deleted here}}
+ ~U1() = default; // expected-warning {{explicitly defaulted destructor is implicitly deleted}} expected-note 2{{explicitly defaulted function was implicitly deleted here}}
U1(const U1 &) = default; // expected-warning {{explicitly defaulted copy constructor is implicitly deleted}} expected-note 2 {{explicitly defaulted function was implicitly deleted here}}
U1(U1 &&) = default; // expected-warning {{explicitly defaulted move constructor is implicitly deleted}}
U1 & operator=(const U1 &) = default; // expected-warning {{explicitly defaulted copy assignment operator is implicitly deleted}} expected-note 2 {{explicitly defaulted function was implicitly deleted here}}
@@ -154,15 +154,15 @@ void test() {
// functions of the containing class.
struct S0 {
union {
- id f0; // expected-note 6 {{'' is implicitly deleted because variant field 'f0' is an ObjC pointer}}
+ id f0; // expected-note 7 {{'' is implicitly deleted because variant field 'f0' is an ObjC pointer}}
char f1;
};
};
struct S1 {
union {
- union { // expected-note 2 {{'S1' is implicitly deleted because variant field '' has a non-trivial}} expected-note 4 {{'S1' is implicitly deleted because field '' has a deleted}}
- id f0; // expected-note 2 {{'' is implicitly deleted because variant field 'f0' is an ObjC pointer}}
+ union { // expected-note 2 {{'S1' is implicitly deleted because variant field '' has a non-trivial}} expected-note 5 {{'S1' is implicitly deleted because field '' has a deleted}}
+ id f0; // expected-note 3 {{'' is implicitly deleted because variant field 'f0' is an ObjC pointer}}
char f1;
};
int f2;
@@ -172,7 +172,7 @@ void test() {
struct S2 {
union {
// FIXME: the note should say 'f0' is causing the special functions to be deleted.
- struct { // expected-note 6 {{'S2' is implicitly deleted because variant field '' has a non-trivial}}
+ struct { // expected-note 7 {{'S2' is implicitly deleted because variant field '' has a non-trivial}}
id f0;
int f1;
};
@@ -189,14 +189,18 @@ void test() {
S1 *x5;
S2 *x6;
- static union { // expected-error {{call to implicitly-deleted default constructor of}}
- id g0; // expected-note {{default constructor of '' is implicitly deleted because variant field 'g0' is an ObjC pointer}}
+ static union { // expected-error {{call to implicitly-deleted default constructor of}} expected-error {{attempt to use a deleted function}}
+ id g0; // expected-note {{default constructor of '' is implicitly deleted because variant field 'g0' is an ObjC pointer}} \
+ // expected-note {{destructor of '' is implicitly deleted because}}
};
- static union { // expected-error {{call to implicitly-deleted default constructor of}}
- union { // expected-note {{default constructor of '' is implicitly deleted because field '' has a deleted default constructor}}
- union { // expected-note {{default constructor of '' is implicitly deleted because field '' has a deleted default constructor}}
- __weak id g1; // expected-note {{default constructor of '' is implicitly deleted because variant field 'g1' is an ObjC pointer}}
+ static union { // expected-error {{call to implicitly-deleted default constructor of}} expected-error {{attempt to use a deleted function}}
+ union { // expected-note {{default constructor of '' is implicitly deleted because field '' has a deleted default constructor}} \
+ // expected-note {{destructor of '' is implicitly deleted because}}
+ union { // expected-note {{default constructor of '' is implicitly deleted because field '' has a deleted default constructor}} \
+ // expected-note {{destructor of '' is implicitly deleted because}}
+ __weak id g1; // expected-note {{default constructor of '' is implicitly deleted because variant field 'g1' is an ObjC pointer}} \
+ // expected-note {{destructor of '' is implicitly deleted because}}
int g2;
};
int g3;
@@ -205,13 +209,13 @@ void test() {
};
void testDefaultConstructor() {
- U0 t0; // expected-error {{call to implicitly-deleted default constructor}}
- U1 t1; // expected-error {{call to implicitly-deleted default constructor}}
+ U0 t0; // expected-error {{call to implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
+ U1 t1; // expected-error {{call to implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
U2 t2;
U3 t3;
- S0 t4; // expected-error {{call to implicitly-deleted default constructor}}
- S1 t5; // expected-error {{call to implicitly-deleted default constructor}}
- S2 t6; // expected-error {{call to implicitly-deleted default constructor}}
+ S0 t4; // expected-error {{call to implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
+ S1 t5; // expected-error {{call to implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
+ S2 t6; // expected-error {{call to implicitly-deleted default constructor}} expected-error {{attempt to use a deleted function}}
}
void testDestructor(U0 *u0, U1 *u1, U2 *u2, U3 *u3, S0 *s0, S1 *s1, S2 *s2) {
More information about the cfe-commits
mailing list