annotate clang/test/PCH/cxx0x-default-delete.cpp @ 207:2e18cbf3894f

LLVM12
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Tue, 08 Jun 2021 06:07:14 +0900
parents 1d019706d866
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 // Without PCH
anatofuz
parents:
diff changeset
2 // RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify -include %s %s
anatofuz
parents:
diff changeset
3 // With PCH
anatofuz
parents:
diff changeset
4 // RUN: %clang_cc1 -x c++-header -std=c++11 -emit-pch -o %t %s
anatofuz
parents:
diff changeset
5 // RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify -include-pch %t %s
anatofuz
parents:
diff changeset
6
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
7 // RUN: %clang_cc1 -x c++-header -std=c++11 -emit-pch -fpch-instantiate-templates -o %t %s
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
8 // RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify -include-pch %t %s
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
9
150
anatofuz
parents:
diff changeset
10 #ifndef PASS1
anatofuz
parents:
diff changeset
11 #define PASS1
anatofuz
parents:
diff changeset
12
anatofuz
parents:
diff changeset
13 struct foo {
anatofuz
parents:
diff changeset
14 foo() = default;
anatofuz
parents:
diff changeset
15 void bar() = delete;
anatofuz
parents:
diff changeset
16 };
anatofuz
parents:
diff changeset
17
anatofuz
parents:
diff changeset
18 struct baz {
anatofuz
parents:
diff changeset
19 ~baz() = delete;
anatofuz
parents:
diff changeset
20 };
anatofuz
parents:
diff changeset
21
anatofuz
parents:
diff changeset
22 class quux {
anatofuz
parents:
diff changeset
23 ~quux() = default;
anatofuz
parents:
diff changeset
24 };
anatofuz
parents:
diff changeset
25
anatofuz
parents:
diff changeset
26 struct A {
anatofuz
parents:
diff changeset
27 A(const A&) = default;
anatofuz
parents:
diff changeset
28 template<typename T> A(T&&);
anatofuz
parents:
diff changeset
29 };
anatofuz
parents:
diff changeset
30
anatofuz
parents:
diff changeset
31 #else
anatofuz
parents:
diff changeset
32
anatofuz
parents:
diff changeset
33 foo::foo() { } // expected-error{{definition of explicitly defaulted default constructor}}
anatofuz
parents:
diff changeset
34 foo f;
anatofuz
parents:
diff changeset
35 void fn() {
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
36 f.bar(); // expected-error{{deleted function}} expected-note@15{{deleted here}}
150
anatofuz
parents:
diff changeset
37 }
anatofuz
parents:
diff changeset
38
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
39 baz bz; // expected-error{{deleted function}} expected-note@19{{deleted here}}
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
40 quux qx; // expected-error{{private destructor}} expected-note@23{{private here}}
150
anatofuz
parents:
diff changeset
41
anatofuz
parents:
diff changeset
42 struct B { A a; };
anatofuz
parents:
diff changeset
43 struct C { mutable A a; };
anatofuz
parents:
diff changeset
44 static_assert(__is_trivially_constructible(B, const B&), "");
anatofuz
parents:
diff changeset
45 static_assert(!__is_trivially_constructible(B, B&&), "");
anatofuz
parents:
diff changeset
46 static_assert(!__is_trivially_constructible(C, const C&), "");
anatofuz
parents:
diff changeset
47 static_assert(!__is_trivially_constructible(C, C&&), "");
anatofuz
parents:
diff changeset
48
anatofuz
parents:
diff changeset
49 #endif