1 // RUN: %clang_cc1 -triple i686-mingw32 -ast-dump %s | FileCheck %s
2 // RUN: %clang_cc1 -triple i686-mingw32 -std=c++1z -ast-dump %s | FileCheck %s -check-prefix=CHECK-1Z
3 
4 template<class T>
5 class P {
6  public:
P(T * t)7   P(T* t) {}
8 };
9 
10 namespace foo {
A(int=0)11 class A { public: A(int = 0) {} };
12 enum B {};
13 typedef int C;
14 }
15 
16 // CHECK: VarDecl {{0x[0-9a-fA-F]+}} <line:[[@LINE+1]]:1, col:36> col:15 ImplicitConstrArray 'foo::A [2]'
17 static foo::A ImplicitConstrArray[2];
18 
main()19 int main() {
20   // CHECK: CXXNewExpr {{0x[0-9a-fA-F]+}} <col:19, col:28> 'foo::A *'
21   P<foo::A> p14 = new foo::A;
22   // CHECK: CXXNewExpr {{0x[0-9a-fA-F]+}} <col:19, col:28> 'foo::B *'
23   P<foo::B> p24 = new foo::B;
24   // CHECK: CXXNewExpr {{0x[0-9a-fA-F]+}} <col:19, col:28> 'foo::C *'
25   P<foo::C> pr4 = new foo::C;
26 }
27 
getName()28 foo::A getName() {
29   // CHECK: CXXConstructExpr {{0x[0-9a-fA-F]+}} <col:10, col:17> 'foo::A'
30   return foo::A();
31 }
32 
destruct(foo::A * a1,foo::A * a2,P<int> * p1)33 void destruct(foo::A *a1, foo::A *a2, P<int> *p1) {
34   // CHECK: MemberExpr {{0x[0-9a-fA-F]+}} <col:3, col:8> '<bound member function type>' ->~A
35   a1->~A();
36   // CHECK: MemberExpr {{0x[0-9a-fA-F]+}} <col:3, col:16> '<bound member function type>' ->~A
37   a2->foo::A::~A();
38   // CHECK: MemberExpr {{0x[0-9a-fA-F]+}} <col:3, col:13> '<bound member function type>' ->~P
39   p1->~P<int>();
40 }
41 
42 struct D {
43   D(int);
44   ~D();
45 };
46 
construct()47 void construct() {
48   using namespace foo;
49   A a = A(12);
50   // CHECK: CXXConstructExpr {{0x[0-9a-fA-F]+}} <col:9, col:13> 'foo::A' 'void (int){{( __attribute__\(\(thiscall\)\))?}}'
51   D d = D(12);
52   // CHECK: CXXConstructExpr {{0x[0-9a-fA-F]+}} <col:9, col:13> 'D' 'void (int){{( __attribute__\(\(thiscall\)\))?}}'
53 }
54 
55 namespace PR38987 {
56 struct A { A(); };
f()57 template <class T> void f() { T{}; }
58 template void f<A>();
59 // CHECK: CXXTemporaryObjectExpr {{.*}} <col:31, col:33> 'PR38987::A':'PR38987::A'
60 }
61 
62 void abort() __attribute__((noreturn));
63 
64 namespace std {
65 typedef decltype(sizeof(int)) size_t;
66 
67 template <typename E> struct initializer_list {
68   const E *p;
69   size_t n;
initializer_liststd::initializer_list70   initializer_list(const E *p, size_t n) : p(p), n(n) {}
71 };
72 
73 template <typename F, typename S> struct pair {
74   F f;
75   S s;
pairstd::pair76   pair(const F &f, const S &s) : f(f), s(s) {}
77 };
78 
79 struct string {
80   const char *str;
stringstd::string81   string() { abort(); }
stringstd::string82   string(const char *S) : str(S) {}
~stringstd::string83   ~string() { abort(); }
84 };
85 
86 template<typename K, typename V>
87 struct map {
88   using T = pair<K, V>;
mapstd::map89   map(initializer_list<T> i, const string &s = string()) {}
~mapstd::map90   ~map() { abort(); }
91 };
92 
93 }; // namespace std
94 
95 // CHECK: NamespaceDecl {{.*}} attributed_decl
96 namespace attributed_decl {
f()97   void f() {
98     // CHECK: DeclStmt {{.*}} <line:[[@LINE+1]]:5, col:28>
99     [[maybe_unused]] int i1;
100     // CHECK: DeclStmt {{.*}} <line:[[@LINE+1]]:5, col:35>
101     __attribute__((unused)) int i2;
102     // CHECK: DeclStmt {{.*}} <line:[[@LINE+1]]:5, col:35>
103     int __attribute__((unused)) i3;
104     // CHECK: DeclStmt {{.*}} <<built-in>:{{.*}}, {{.*}}:[[@LINE+1]]:40>
105     __declspec(dllexport) extern int i4;
106     // CHECK: DeclStmt {{.*}} <line:[[@LINE+1]]:5, col:40>
107     extern int __declspec(dllexport) i5;
108   }
109 }
110 
111 // CHECK: NamespaceDecl {{.*}} attributed_stmt
112 namespace attributed_stmt {
113   // In DO_PRAGMA and _Pragma cases, `LoopHintAttr` comes from <scratch space>
114   // file.
115 
116   #define DO_PRAGMA(x) _Pragma (#x)
117 
f()118   void f() {
119     // CHECK: AttributedStmt {{.*}} <line:[[@LINE-3]]:24, line:[[@LINE+2]]:33>
120     DO_PRAGMA (unroll(2))
121     for (int i = 0; i < 10; ++i);
122 
123     // CHECK: AttributedStmt {{.*}} <line:[[@LINE+2]]:5, line:[[@LINE+3]]:33>
124     // CHECK: LoopHintAttr {{.*}} <line:[[@LINE+1]]:13, col:22>
125     #pragma unroll(2)
126     for (int i = 0; i < 10; ++i);
127 
128     // CHECK: AttributedStmt {{.*}} <line:[[@LINE+2]]:5, line:[[@LINE+5]]:33>
129     // CHECK: LoopHintAttr {{.*}} <line:[[@LINE+1]]:19, col:41>
130     #pragma clang loop vectorize(enable)
131     // CHECK: LoopHintAttr {{.*}} <line:[[@LINE+1]]:19, col:42>
132     #pragma clang loop interleave(enable)
133     for (int i = 0; i < 10; ++i);
134 
135     // CHECK: AttributedStmt {{.*}} <line:[[@LINE+1]]:5, line:[[@LINE+2]]:33>
136     _Pragma("unroll(2)")
137     for (int i = 0; i < 10; ++i);
138   }
139 }
140 
141 #if __cplusplus >= 201703L
142 // CHECK-1Z: FunctionDecl {{.*}} construct_with_init_list
construct_with_init_list()143 std::map<int, int> construct_with_init_list() {
144   // CHECK-1Z-NEXT: CompoundStmt
145   // CHECK-1Z-NEXT: ReturnStmt {{.*}} <line:[[@LINE+5]]:3, col:35
146   // CHECK-1Z-NEXT: ExprWithCleanups {{.*}} <col:10, col:35
147   // CHECK-1Z-NEXT: CXXBindTemporaryExpr {{.*}} <col:10, col:35
148   // CHECK-1Z-NEXT: CXXTemporaryObjectExpr {{.*}} <col:10, col:35
149   // CHECK-1Z-NEXT: CXXStdInitializerListExpr {{.*}} <col:28, col:35
150   return std::map<int, int>{{0, 0}};
151 }
152 
153 // CHECK-1Z: NamespaceDecl {{.*}} in_class_init
154 namespace in_class_init {
155   struct A {};
156 
157   // CHECK-1Z: CXXRecordDecl {{.*}} struct B definition
158   struct B {
159     // CHECK-1Z: FieldDecl {{.*}} a 'in_class_init::A'
160     // CHECK-1Z-NEXT: InitListExpr {{.*}} <col:11, col:12
161     A a = {};
162   };
163 }
164 
165 // CHECK-1Z: NamespaceDecl {{.*}} delegating_constructor_init
166 namespace delegating_constructor_init {
167   struct A {};
168 
169   struct B : A {
170     A a;
Bdelegating_constructor_init::B171     B(A a) : a(a) {}
172   };
173 
174   // CHECK-1Z: CXXRecordDecl {{.*}} struct C definition
175   struct C : B {
176     // CHECK-1Z: CXXConstructorDecl {{.*}} C
177     // CHECK-1Z-NEXT: CXXCtorInitializer 'delegating_constructor_init::B'
178     // CHECK-1Z-NEXT: CXXConstructExpr {{.*}} <col:11, col:15
179     // CHECK-1Z-NEXT: InitListExpr {{.*}} <col:13, col:14
Cdelegating_constructor_init::C180     C() : B({}) {};
181   };
182 }
183 
184 // CHECK-1Z: NamespaceDecl {{.*}} new_init
185 namespace new_init {
A()186   void A() {
187     // CHECK-1Z: CXXNewExpr {{.*}} <line:[[@LINE+2]]:5, col:14
188     // CHECK-1Z-NEXT: InitListExpr {{.*}} <col:12, col:14
189     new int{0};
190   }
191 }
192 #endif
193