annotate gcc/testsuite/g++.dg/ext/has_trivial_copy.C @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 // { dg-do run }
kono
parents:
diff changeset
2 #include <cassert>
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 struct A
kono
parents:
diff changeset
5 {
kono
parents:
diff changeset
6 double a;
kono
parents:
diff changeset
7 double b;
kono
parents:
diff changeset
8 };
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 union U
kono
parents:
diff changeset
11 {
kono
parents:
diff changeset
12 double a;
kono
parents:
diff changeset
13 double b;
kono
parents:
diff changeset
14 };
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 struct B
kono
parents:
diff changeset
17 {
kono
parents:
diff changeset
18 B(const B&) { }
kono
parents:
diff changeset
19 };
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 struct C
kono
parents:
diff changeset
22 {
kono
parents:
diff changeset
23 virtual int f() { return 1; }
kono
parents:
diff changeset
24 };
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 struct D
kono
parents:
diff changeset
27 : public B { };
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29 struct E
kono
parents:
diff changeset
30 : public A { };
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 struct F
kono
parents:
diff changeset
33 {
kono
parents:
diff changeset
34 A a;
kono
parents:
diff changeset
35 };
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 struct G
kono
parents:
diff changeset
38 {
kono
parents:
diff changeset
39 B b;
kono
parents:
diff changeset
40 };
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 template<typename T>
kono
parents:
diff changeset
43 bool
kono
parents:
diff changeset
44 f()
kono
parents:
diff changeset
45 { return __has_trivial_copy(T); }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 template<typename T>
kono
parents:
diff changeset
48 class My
kono
parents:
diff changeset
49 {
kono
parents:
diff changeset
50 public:
kono
parents:
diff changeset
51 bool
kono
parents:
diff changeset
52 f()
kono
parents:
diff changeset
53 { return !!__has_trivial_copy(T); }
kono
parents:
diff changeset
54 };
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56 template<typename T>
kono
parents:
diff changeset
57 class My2
kono
parents:
diff changeset
58 {
kono
parents:
diff changeset
59 public:
kono
parents:
diff changeset
60 static const bool trait = __has_trivial_copy(T);
kono
parents:
diff changeset
61 };
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 template<typename T>
kono
parents:
diff changeset
64 const bool My2<T>::trait;
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66 template<typename T, bool b = __has_trivial_copy(T)>
kono
parents:
diff changeset
67 struct My3_help
kono
parents:
diff changeset
68 { static const bool trait = b; };
kono
parents:
diff changeset
69
kono
parents:
diff changeset
70 template<typename T, bool b>
kono
parents:
diff changeset
71 const bool My3_help<T, b>::trait;
kono
parents:
diff changeset
72
kono
parents:
diff changeset
73 template<typename T>
kono
parents:
diff changeset
74 class My3
kono
parents:
diff changeset
75 {
kono
parents:
diff changeset
76 public:
kono
parents:
diff changeset
77 bool
kono
parents:
diff changeset
78 f()
kono
parents:
diff changeset
79 { return My3_help<T>::trait; }
kono
parents:
diff changeset
80 };
kono
parents:
diff changeset
81
kono
parents:
diff changeset
82 #define PTEST(T) (__has_trivial_copy(T) && f<T>() \
kono
parents:
diff changeset
83 && My<T>().f() && My2<T>::trait && My3<T>().f())
kono
parents:
diff changeset
84
kono
parents:
diff changeset
85 #define NTEST(T) (!__has_trivial_copy(T) && !f<T>() \
kono
parents:
diff changeset
86 && !My<T>().f() && !My2<T>::trait && !My3<T>().f())
kono
parents:
diff changeset
87
kono
parents:
diff changeset
88 int main()
kono
parents:
diff changeset
89 {
kono
parents:
diff changeset
90 assert (PTEST (int));
kono
parents:
diff changeset
91 assert (NTEST (int (int)));
kono
parents:
diff changeset
92 assert (NTEST (void));
kono
parents:
diff changeset
93 assert (PTEST (A));
kono
parents:
diff changeset
94 assert (PTEST (U));
kono
parents:
diff changeset
95 assert (NTEST (B));
kono
parents:
diff changeset
96 assert (NTEST (C));
kono
parents:
diff changeset
97 assert (NTEST (D));
kono
parents:
diff changeset
98 assert (PTEST (E));
kono
parents:
diff changeset
99 assert (PTEST (E[]));
kono
parents:
diff changeset
100 assert (PTEST (F));
kono
parents:
diff changeset
101 assert (NTEST (G));
kono
parents:
diff changeset
102 assert (PTEST (B&));
kono
parents:
diff changeset
103
kono
parents:
diff changeset
104 return 0;
kono
parents:
diff changeset
105 }