1 // RUN: %clang_cc1 -no-opaque-pointers -std=c++11 -triple x86_64-apple-darwin10 %s -emit-llvm -o %t
2 // RUN: FileCheck %s < %t
3 // RUN: FileCheck -check-prefix=CHECK-PR10720 %s < %t
5 extern "C" int printf(...);
8 M() { printf("M()\n"); }
9 M(int i
) { iM
= i
; printf("M(%d)\n", i
); }
11 void MPR() {printf("iM = %d\n", iM
); };
15 P() { printf("P()\n"); }
16 P(int i
) { iP
= i
; printf("P(%d)\n", i
); }
18 void PPR() {printf("iP = %d\n", iP
); };
22 Q() { printf("Q()\n"); }
23 Q(int i
) { iQ
= i
; printf("Q(%d)\n", i
); }
25 void QPR() {printf("iQ = %d\n", iQ
); };
29 N() : f1(1.314), P(2000), ld(00.1234+f1
), M(1000), Q(3000),
30 d1(3.4567), i1(1234), m1(100) { printf("N()\n"); }
37 printf("f1 = %f d1 = %f i1 = %d ld = %f \n", f1
,d1
,i1
, ld
);
41 printf("iQ = %d\n", iQ
);
42 printf("iP = %d\n", iP
);
43 printf("iM = %d\n", iM
);
44 // FIXME. We don't yet support this syntax.
45 // printf("iQ = %d\n", (*this).iQ);
46 printf("iQ = %d\n", this->iQ
);
47 printf("iP = %d\n", this->iP
);
48 printf("iM = %d\n", this->iM
);
65 template <class T
> struct A
{
70 operator int() {return 0;}
73 // CHECK-LABEL: define{{.*}} void @_Z1fv()
75 // CHECK: call void @_ZN1AIsEC1Ei
78 // CHECK-NEXT: store i32 17
81 // CHECK-NEXT: call void @_ZN1AIsED1Ev
82 // CHECK-NOT: call void @_ZN1AIsED1Ev
86 // Make sure we initialize the vtable pointer if it's required by a
88 namespace InitVTable
{
96 // CHECK-LABEL: define{{.*}} void @_ZN10InitVTable1BC2Ev(%"struct.InitVTable::B"* {{[^,]*}} %this) unnamed_addr
97 // CHECK: [[T0:%.*]] = bitcast [[B:%.*]]* [[THIS:%.*]] to i32 (...)***
98 // CHECK-NEXT: store i32 (...)** bitcast (i8** getelementptr inbounds ({ [3 x i8*] }, { [3 x i8*] }* @_ZTVN10InitVTable1BE, i32 0, inrange i32 0, i32 2) to i32 (...)**), i32 (...)*** [[T0]]
99 // CHECK: [[VTBL:%.*]] = load i32 ([[B]]*)**, i32 ([[B]]*)*** {{%.*}}
100 // CHECK-NEXT: [[FNP:%.*]] = getelementptr inbounds i32 ([[B]]*)*, i32 ([[B]]*)** [[VTBL]], i64 0
101 // CHECK-NEXT: [[FN:%.*]] = load i32 ([[B]]*)*, i32 ([[B]]*)** [[FNP]]
102 // CHECK-NEXT: [[ARG:%.*]] = call noundef i32 [[FN]]([[B]]* {{[^,]*}} [[THIS]])
103 // CHECK-NEXT: call void @_ZN10InitVTable1AC2Ei({{.*}}* {{[^,]*}} {{%.*}}, i32 noundef [[ARG]])
104 // CHECK-NEXT: [[T0:%.*]] = bitcast [[B]]* [[THIS]] to i32 (...)***
105 // CHECK-NEXT: store i32 (...)** bitcast (i8** getelementptr inbounds ({ [3 x i8*] }, { [3 x i8*] }* @_ZTVN10InitVTable1BE, i32 0, inrange i32 0, i32 2) to i32 (...)**), i32 (...)*** [[T0]]
106 // CHECK-NEXT: ret void
109 // CHECK-LABEL: define{{.*}} void @_ZN10InitVTable1BC2Ei(%"struct.InitVTable::B"* {{[^,]*}} %this, i32 noundef %x) unnamed_addr
110 // CHECK: [[ARG:%.*]] = add nsw i32 {{%.*}}, 5
111 // CHECK-NEXT: call void @_ZN10InitVTable1AC2Ei({{.*}}* {{[^,]*}} {{%.*}}, i32 noundef [[ARG]])
112 // CHECK-NEXT: [[T0:%.*]] = bitcast [[B]]* {{%.*}} to i32 (...)***
113 // CHECK-NEXT: store i32 (...)** bitcast (i8** getelementptr inbounds ({ [3 x i8*] }, { [3 x i8*] }* @_ZTVN10InitVTable1BE, i32 0, inrange i32 0, i32 2) to i32 (...)**), i32 (...)*** [[T0]]
114 // CHECK-NEXT: ret void
115 B::B(int x
) : A(x
+ 5) {}
118 namespace rdar9694300
{
123 // CHECK-LABEL: define{{.*}} void @_ZN11rdar96943001fEv
127 // CHECK-NEXT: [[I:%.*]] = alloca i32
128 // CHECK-NEXT: store i32 17, i32* [[I]]
130 // CHECK-NEXT: ret void
134 // Check that we emit a zero initialization step for list-value-initialization
135 // which calls a trivial default constructor.
146 // CHECK: define {{.*}}@_ZN7PR132731fEv(
149 // CHECK: llvm.memset{{.*}}i8 0
162 template<typename T
> struct X
;
164 // Make sure that the instantiated constructor initializes start and
166 // CHECK-LABEL: define linkonce_odr void @_ZN1XIiEC2ERKS0_(%struct.X* {{[^,]*}} %this, %struct.X* noundef nonnull align {{[0-9]+}} dereferenceable({{[0-9]+}}) %other) unnamed_addr
167 // CHECK: {{store.*null}}
168 // CHECK: {{store.*null}}
171 X
<T
>::X(const X
&other
) : start(0), end(0) { }
173 X
<int> get_X(X
<int> x
) { return x
; }
179 X
& operator=(const X
&);
187 // CHECK-PR10720: define linkonce_odr {{.*}} @_ZN7PR107205pair2aSERKS0_
188 // CHECK-PR10720: load
189 // CHECK-PR10720: icmp ne
190 // CHECK-PR10720-NEXT: br i1
191 // CHECK-PR10720: call {{.*}} @_ZN7PR107201XaSERKS0_
192 // CHECK-PR10720: ret
193 pair2
&operator=(const pair2
&) = default;
195 // CHECK-PR10720: define linkonce_odr {{.*}} @_ZN7PR107205pair2aSEOS0_
196 // CHECK-PR10720: load
197 // CHECK-PR10720: icmp ne
198 // CHECK-PR10720-NEXT: br i1
199 // CHECK-PR10720: call {{.*}} @_ZN7PR107201XaSEOS0_
200 // CHECK-PR10720: ret
201 pair2
&operator=(pair2
&&) = default;
203 // CHECK-PR10720-LABEL: define linkonce_odr void @_ZN7PR107204pairC2ERKS0_
204 // CHECK-PR10720-NOT: ret
205 // CHECK-PR10720: call void @llvm.memcpy
206 // CHECK-PR10720-NEXT: ret void
208 // CHECK-PR10720-LABEL: define linkonce_odr void @_ZN7PR107205pair2C2ERKS0_
209 // CHECK-PR10720-NOT: ret
210 // CHECK-PR10720: call void @_ZN7PR107201XC1ERKS0_
211 // CHECK-PR10720: icmp eq
212 // CHECK-PR10720-NEXT: br i1
213 // CHECK-PR10720: ret void
215 // CHECK-PR10720-LABEL: define linkonce_odr void @_ZN7PR107205pair2C2EOS0_
216 // CHECK-PR10720-NOT: ret
217 // CHECK-PR10720: load
218 // CHECK-PR10720: call void @_ZN7PR107201XC1EOS0_
219 // CHECK-PR10720: icmp eq
220 // CHECK-PR10720-NEXT: br i1
221 // CHECK-PR10720: ret void
222 pair2(pair2
&&) = default;
224 pair2(const pair2
&) = default;
227 struct pair
: X
{ // Make the copy constructor non-trivial, so we actually generate it.
229 pair(const pair
&) = default;
232 void foo(const pair
&x
, const pair2
&x2
) {
235 pair2
y2m(static_cast<pair2
&&>(y2
));
238 y2m
= static_cast<pair2
&&>(y2
);