]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - test/SemaCXX/ast-print.cpp
Vendor import of clang trunk r338150:
[FreeBSD/FreeBSD.git] / test / SemaCXX / ast-print.cpp
1 // RUN: %clang_cc1 -triple %ms_abi_triple -ast-print %s -std=gnu++11 | FileCheck %s
2
3 // CHECK: r;
4 // CHECK-NEXT: (r->method());
5 struct MyClass
6 {
7     void method() {}
8 };
9
10 struct Reference
11 {
12     MyClass* object;
13     MyClass* operator ->() { return object; }
14 };
15
16 void test1() {
17     Reference r;
18     (r->method());
19 }
20
21 // CHECK: if (int a = 1)
22 // CHECK:  while (int a = 1)
23 // CHECK:  switch (int a = 1)
24
25 void test2()
26 {
27     if (int a = 1) { }
28     while (int a = 1) { }
29     switch (int a = 1) { }
30 }
31
32 // CHECK: new (1) int;
33 void *operator new (typeof(sizeof(1)), int, int = 2);
34 void test3() {
35   new (1) int;
36 }
37
38 // CHECK: new X;
39 struct X {
40   void *operator new (typeof(sizeof(1)), int = 2);
41 };
42 void test4() { new X; }
43
44 // CHECK: for (int i = 2097, j = 42; false;)
45 void test5() {
46   for (int i = 2097, j = 42; false;) {}
47 }
48
49 // CHECK: test6fn((int &)y);
50 void test6fn(int& x);
51 void test6() {
52     unsigned int y = 0;
53     test6fn((int&)y);
54 }
55
56 // CHECK: S s(1, 2);
57
58 template <class S> void test7()
59 {
60     S s( 1,2 );
61 }
62
63
64 // CHECK: t.~T();
65
66 template <typename T> void test8(T t) { t.~T(); }
67
68
69 // CHECK:      enum E
70 // CHECK-NEXT:  A,
71 // CHECK-NEXT:  B,
72 // CHECK-NEXT:  C
73 // CHECK-NEXT:  };
74 // CHECK-NEXT: {{^[ ]+}}E a = A;
75
76 struct test9
77 {
78     void f()
79     {
80         enum E { A, B, C };
81         E a = A;
82     }
83 };
84
85 namespace test10 {
86   namespace M {
87     template<typename T>
88     struct X {
89       enum { value };
90     };
91   }
92 }
93
94 typedef int INT;
95
96 // CHECK: test11
97 // CHECK-NEXT: return test10::M::X<INT>::value;
98 int test11() {
99   return test10::M::X<INT>::value;
100 }
101
102
103 struct DefaultArgClass
104 {
105   DefaultArgClass(int a = 1) {}
106   DefaultArgClass(int a, int b, int c = 1) {}
107 };
108
109 struct NoArgClass
110 {
111   NoArgClass() {}
112 };
113
114 struct VirualDestrClass
115 {
116   VirualDestrClass(int arg);
117   virtual ~VirualDestrClass();
118 };
119
120 struct ConstrWithCleanupsClass
121 {
122   ConstrWithCleanupsClass(const VirualDestrClass& cplx = VirualDestrClass(42));
123 };
124
125 // CHECK: test12
126 // CHECK-NEXT: DefaultArgClass useDefaultArg;
127 // CHECK-NEXT: DefaultArgClass overrideDefaultArg(1);
128 // CHECK-NEXT: DefaultArgClass(1, 2);
129 // CHECK-NEXT: DefaultArgClass(1, 2, 3);
130 // CHECK-NEXT: NoArgClass noArg;
131 // CHECK-NEXT: ConstrWithCleanupsClass cwcNoArg;
132 // CHECK-NEXT: ConstrWithCleanupsClass cwcOverrideArg(48);
133 // CHECK-NEXT: ConstrWithCleanupsClass cwcExplicitArg(VirualDestrClass(56));
134 void test12() {
135   DefaultArgClass useDefaultArg;
136   DefaultArgClass overrideDefaultArg(1);
137   DefaultArgClass tempWithDefaultArg = DefaultArgClass(1, 2);
138   DefaultArgClass tempWithExplictArg = DefaultArgClass(1, 2, 3);
139   NoArgClass noArg;
140   ConstrWithCleanupsClass cwcNoArg;
141   ConstrWithCleanupsClass cwcOverrideArg(48);
142   ConstrWithCleanupsClass cwcExplicitArg(VirualDestrClass(56));
143 }
144
145 // CHECK: void test13() {
146 // CHECK:   _Atomic(int) i;
147 // CHECK:   __c11_atomic_init(&i, 0);
148 // CHECK:   __c11_atomic_load(&i, 0);
149 // CHECK: }
150 void test13() {
151   _Atomic(int) i;
152   __c11_atomic_init(&i, 0);
153   __c11_atomic_load(&i, 0);
154 }
155
156
157 // CHECK: void test14() {
158 // CHECK:     struct X {
159 // CHECK:         union {
160 // CHECK:             int x;
161 // CHECK:         } x;
162 // CHECK:     };
163 // CHECK: }
164 void test14() {
165   struct X { union { int x; } x; };
166 }
167
168
169 // CHECK: float test15() {
170 // CHECK:     return __builtin_asinf(1.F);
171 // CHECK: }
172 // CHECK-NOT: extern "C"
173 float test15() {
174   return __builtin_asinf(1.0F);
175 }
176
177 namespace PR18776 {
178 struct A {
179   operator void *();
180   explicit operator bool();
181   A operator&(A);
182 };
183
184 // CHECK: struct A
185 // CHECK-NEXT: {{^[ ]*operator}} void *();
186 // CHECK-NEXT: {{^[ ]*explicit}} operator bool();
187
188 void bar(void *);
189
190 void foo() {
191   A a, b;
192   bar(a & b);
193 // CHECK: bar(a & b);
194   if (a & b)
195 // CHECK: if (a & b)
196     return;
197 }
198 };
199
200 namespace {
201 void test(int i) {
202   switch (i) {
203     case 1:
204       // CHECK: {{\[\[clang::fallthrough\]\]}}
205       [[clang::fallthrough]];
206     case 2:
207       break;
208   }
209 }
210 }
211
212 namespace {
213 // CHECK: struct {{\[\[gnu::visibility\(\"hidden\"\)\]\]}} S;
214 struct [[gnu::visibility("hidden")]] S;
215 }
216
217 // CHECK:      struct CXXFunctionalCastExprPrint {
218 // CHECK-NEXT: } fce = CXXFunctionalCastExprPrint{};
219 struct CXXFunctionalCastExprPrint {} fce = CXXFunctionalCastExprPrint{};
220
221 // CHECK:      struct CXXTemporaryObjectExprPrint {
222 // CHECK-NEXT:   CXXTemporaryObjectExprPrint();
223 // CHECK-NEXT: } toe = CXXTemporaryObjectExprPrint{};
224 struct CXXTemporaryObjectExprPrint { CXXTemporaryObjectExprPrint(); } toe = CXXTemporaryObjectExprPrint{};
225
226 namespace PR24872 {
227 // CHECK: template <typename T> struct Foo : T {
228 // CHECK: using T::operator-;
229 template <typename T> struct Foo : T {
230   using T::operator-;
231 };
232 }
233
234 namespace dont_crash_on_auto_vars {
235 struct T { enum E {X = 12ll }; };
236 struct S {
237   struct  { int I; } ADecl;
238   static const auto Y = T::X;
239 };
240 //CHECK: static const auto Y = T::X;
241 constexpr auto var = T::X;
242 //CHECK: constexpr auto var = T::X;
243 }