1*67e74705SXin Li // RUN: %clang_cc1 -verify -Wno-return-type -Wno-main -std=c++11 -emit-llvm -triple %itanium_abi_triple -o - %s | FileCheck %s
2*67e74705SXin Li // expected-no-diagnostics
3*67e74705SXin Li
4*67e74705SXin Li namespace test1 {
5*67e74705SXin Li int x;
6*67e74705SXin Li template <int& D> class T { };
7*67e74705SXin Li // CHECK: void @_ZN5test12f0ENS_1TIL_ZNS_1xEEEE(
f0(T<x> a0)8*67e74705SXin Li void f0(T<x> a0) {}
9*67e74705SXin Li }
10*67e74705SXin Li
11*67e74705SXin Li namespace test1 {
12*67e74705SXin Li // CHECK: void @_ZN5test12f0Ef
f0(float)13*67e74705SXin Li void f0(float) {}
14*67e74705SXin Li template<void (&)(float)> struct t1 {};
15*67e74705SXin Li // CHECK: void @_ZN5test12f1ENS_2t1IL_ZNS_2f0EfEEE(
f1(t1<f0> a0)16*67e74705SXin Li void f1(t1<f0> a0) {}
17*67e74705SXin Li }
18*67e74705SXin Li
19*67e74705SXin Li namespace test2 {
20*67e74705SXin Li // CHECK: void @_ZN5test22f0Ef
f0(float)21*67e74705SXin Li void f0(float) {}
22*67e74705SXin Li template<void (*)(float)> struct t1 {};
23*67e74705SXin Li // CHECK: void @_ZN5test22f1ENS_2t1IXadL_ZNS_2f0EfEEEE(
f1(t1<f0> a0)24*67e74705SXin Li void f1(t1<f0> a0) {}
25*67e74705SXin Li }
26*67e74705SXin Li
27*67e74705SXin Li namespace test3 {
28*67e74705SXin Li // CHECK: void @test3_f0
test3_f0(float)29*67e74705SXin Li extern "C" void test3_f0(float) {}
30*67e74705SXin Li template<void (&)(float)> struct t1 {};
31*67e74705SXin Li // CHECK: void @_ZN5test32f1ENS_2t1IL_Z8test3_f0EEE(
f1(t1<test3_f0> a0)32*67e74705SXin Li void f1(t1<test3_f0> a0) {}
33*67e74705SXin Li }
34*67e74705SXin Li
35*67e74705SXin Li namespace test4 {
36*67e74705SXin Li // CHECK: void @test4_f0
test4_f0(float)37*67e74705SXin Li extern "C" void test4_f0(float) {}
38*67e74705SXin Li template<void (*)(float)> struct t1 {};
39*67e74705SXin Li // CHECK: void @_ZN5test42f1ENS_2t1IXadL_Z8test4_f0EEEE(
f1(t1<test4_f0> a0)40*67e74705SXin Li void f1(t1<test4_f0> a0) {}
41*67e74705SXin Li }
42*67e74705SXin Li
43*67e74705SXin Li // CHECK: void @test5_f0
test5_f0(float)44*67e74705SXin Li extern "C" void test5_f0(float) {}
main(int)45*67e74705SXin Li int main(int) {}
46*67e74705SXin Li
47*67e74705SXin Li namespace test5 {
48*67e74705SXin Li template<void (&)(float)> struct t1 {};
49*67e74705SXin Li // CHECK: void @_ZN5test52f1ENS_2t1IL_Z8test5_f0EEE(
f1(t1<test5_f0> a0)50*67e74705SXin Li void f1(t1<test5_f0> a0) {}
51*67e74705SXin Li
52*67e74705SXin Li template<int (&)(int)> struct t2 {};
53*67e74705SXin Li // CHECK: void @_ZN5test52f2ENS_2t2IL_Z4mainEEE
f2(t2<main> a0)54*67e74705SXin Li void f2(t2<main> a0) {}
55*67e74705SXin Li }
56*67e74705SXin Li
57*67e74705SXin Li namespace test6 {
58*67e74705SXin Li struct A { void im0(float); };
59*67e74705SXin Li // CHECK: void @_ZN5test61A3im0Ef
im0(float)60*67e74705SXin Li void A::im0(float) {}
61*67e74705SXin Li template <void(A::*)(float)> class T { };
62*67e74705SXin Li // CHECK: void @_ZN5test62f0ENS_1TIXadL_ZNS_1A3im0EfEEEE(
f0(T<& A::im0> a0)63*67e74705SXin Li void f0(T<&A::im0> a0) {}
64*67e74705SXin Li }
65*67e74705SXin Li
66*67e74705SXin Li namespace test7 {
67*67e74705SXin Li template<typename T>
68*67e74705SXin Li struct meta {
69*67e74705SXin Li static const unsigned value = sizeof(T);
70*67e74705SXin Li };
71*67e74705SXin Li
72*67e74705SXin Li template<unsigned> struct int_c {
73*67e74705SXin Li typedef float type;
74*67e74705SXin Li };
75*67e74705SXin Li
76*67e74705SXin Li template<typename T>
77*67e74705SXin Li struct X {
78*67e74705SXin Li template<typename U>
Xtest7::X79*67e74705SXin Li X(U*, typename int_c<(meta<T>::value + meta<U>::value)>::type *) { }
80*67e74705SXin Li };
81*67e74705SXin Li
82*67e74705SXin Li // CHECK: define weak_odr {{.*}} @_ZN5test71XIiEC1IdEEPT_PNS_5int_cIXplL_ZNS_4metaIiE5valueEEsr4metaIS3_EE5valueEE4typeE(
83*67e74705SXin Li template X<int>::X(double*, float*);
84*67e74705SXin Li }
85*67e74705SXin Li
86*67e74705SXin Li namespace test8 {
87*67e74705SXin Li template<typename T>
88*67e74705SXin Li struct meta {
89*67e74705SXin Li struct type {
90*67e74705SXin Li static const unsigned value = sizeof(T);
91*67e74705SXin Li };
92*67e74705SXin Li };
93*67e74705SXin Li
94*67e74705SXin Li template<unsigned> struct int_c {
95*67e74705SXin Li typedef float type;
96*67e74705SXin Li };
97*67e74705SXin Li
98*67e74705SXin Li template<typename T>
f(int_c<meta<T>::type::value>)99*67e74705SXin Li void f(int_c<meta<T>::type::value>) { }
100*67e74705SXin Li
101*67e74705SXin Li // CHECK-LABEL: define weak_odr {{.*}}void @_ZN5test81fIiEEvNS_5int_cIXsr4metaIT_E4typeE5valueEEE(
102*67e74705SXin Li template void f<int>(int_c<sizeof(int)>);
103*67e74705SXin Li }
104*67e74705SXin Li
105*67e74705SXin Li namespace test9 {
106*67e74705SXin Li template<typename T>
107*67e74705SXin Li struct supermeta {
108*67e74705SXin Li template<typename U>
109*67e74705SXin Li struct apply {
110*67e74705SXin Li typedef T U::*type;
111*67e74705SXin Li };
112*67e74705SXin Li };
113*67e74705SXin Li
114*67e74705SXin Li struct X { };
115*67e74705SXin Li
116*67e74705SXin Li template<typename T, typename U>
117*67e74705SXin Li typename supermeta<T>::template apply<U>::type f();
118*67e74705SXin Li
test_f()119*67e74705SXin Li void test_f() {
120*67e74705SXin Li // CHECK: @_ZN5test91fIiNS_1XEEENS_9supermetaIT_E5applyIT0_E4typeEv()
121*67e74705SXin Li // Note: GCC incorrectly mangles this as
122*67e74705SXin Li // _ZN5test91fIiNS_1XEEENS_9supermetaIT_E5apply4typeEv, while EDG
123*67e74705SXin Li // gets it right.
124*67e74705SXin Li f<int, X>();
125*67e74705SXin Li }
126*67e74705SXin Li }
127*67e74705SXin Li
128*67e74705SXin Li namespace test10 {
129*67e74705SXin Li template<typename T>
130*67e74705SXin Li struct X {
131*67e74705SXin Li template<typename U>
132*67e74705SXin Li struct definition {
133*67e74705SXin Li };
134*67e74705SXin Li };
135*67e74705SXin Li
136*67e74705SXin Li // CHECK: _ZN6test101fIidEENS_1XIT_E10definitionIT0_EES2_S5_
137*67e74705SXin Li template<typename T, typename U>
f(T,U)138*67e74705SXin Li typename X<T>::template definition<U> f(T, U) { }
139*67e74705SXin Li
g(int i,double d)140*67e74705SXin Li void g(int i, double d) {
141*67e74705SXin Li f(i, d);
142*67e74705SXin Li }
143*67e74705SXin Li }
144*67e74705SXin Li
145*67e74705SXin Li // Report from cxx-abi-dev, 2012.01.04.
146*67e74705SXin Li namespace test11 {
147*67e74705SXin Li int cmp(char a, char b);
148*67e74705SXin Li template <typename T, int (*cmp)(T, T)> struct A {};
f(A<T,cmp> &)149*67e74705SXin Li template <typename T> void f(A<T,cmp> &) {}
150*67e74705SXin Li template void f<char>(A<char,cmp> &);
151*67e74705SXin Li // CHECK: @_ZN6test111fIcEEvRNS_1AIT_L_ZNS_3cmpEccEEE(
152*67e74705SXin Li }
153*67e74705SXin Li
154*67e74705SXin Li namespace test12 {
155*67e74705SXin Li // Make sure we can mangle non-type template args with internal linkage.
f()156*67e74705SXin Li static int f() {}
157*67e74705SXin Li const int n = 10;
test()158*67e74705SXin Li template<typename T, T v> void test() {}
use()159*67e74705SXin Li void use() {
160*67e74705SXin Li // CHECK-LABEL: define internal {{.*}}void @_ZN6test124testIFivEXadL_ZNS_L1fEvEEEEvv(
161*67e74705SXin Li test<int(), &f>();
162*67e74705SXin Li // CHECK-LABEL: define internal {{.*}}void @_ZN6test124testIRFivEL_ZNS_L1fEvEEEvv(
163*67e74705SXin Li test<int(&)(), f>();
164*67e74705SXin Li // CHECK-LABEL: define internal {{.*}}void @_ZN6test124testIPKiXadL_ZNS_L1nEEEEEvv(
165*67e74705SXin Li test<const int*, &n>();
166*67e74705SXin Li // CHECK-LABEL: define internal {{.*}}void @_ZN6test124testIRKiL_ZNS_L1nEEEEvv(
167*67e74705SXin Li test<const int&, n>();
168*67e74705SXin Li }
169*67e74705SXin Li }
170*67e74705SXin Li
171*67e74705SXin Li // rdar://problem/12072531
172*67e74705SXin Li // Test the boundary condition of minimal signed integers.
173*67e74705SXin Li namespace test13 {
returnChar()174*67e74705SXin Li template <char c> char returnChar() { return c; }
175*67e74705SXin Li template char returnChar<-128>();
176*67e74705SXin Li // CHECK: @_ZN6test1310returnCharILcn128EEEcv()
177*67e74705SXin Li
returnShort()178*67e74705SXin Li template <short s> short returnShort() { return s; }
179*67e74705SXin Li template short returnShort<-32768>();
180*67e74705SXin Li // CHECK: @_ZN6test1311returnShortILsn32768EEEsv()
181*67e74705SXin Li }
182*67e74705SXin Li
183*67e74705SXin Li namespace test14 {
inl(bool b)184*67e74705SXin Li template <typename> inline int inl(bool b) {
185*67e74705SXin Li if (b) {
186*67e74705SXin Li static struct {
187*67e74705SXin Li int field;
188*67e74705SXin Li } a;
189*67e74705SXin Li // CHECK: @_ZZN6test143inlIvEEibE1a
190*67e74705SXin Li
191*67e74705SXin Li return a.field;
192*67e74705SXin Li } else {
193*67e74705SXin Li static struct {
194*67e74705SXin Li int field;
195*67e74705SXin Li } a;
196*67e74705SXin Li // CHECK: @_ZZN6test143inlIvEEibE1a_0
197*67e74705SXin Li
198*67e74705SXin Li return a.field;
199*67e74705SXin Li }
200*67e74705SXin Li }
201*67e74705SXin Li
call(bool b)202*67e74705SXin Li int call(bool b) { return inl<void>(b); }
203*67e74705SXin Li }
204*67e74705SXin Li
205*67e74705SXin Li namespace std {
206*67e74705SXin Li template <class _Tp, _Tp...> struct integer_sequence {};
207*67e74705SXin Li }
208*67e74705SXin Li
209*67e74705SXin Li namespace test15 {
210*67e74705SXin Li template <int N>
make()211*67e74705SXin Li __make_integer_seq<std::integer_sequence, int, N> make() {}
212*67e74705SXin Li template __make_integer_seq<std::integer_sequence, int, 5> make<5>();
213*67e74705SXin Li // CHECK: define weak_odr {{.*}} @_ZN6test154makeILi5EEE18__make_integer_seqISt16integer_sequenceiXT_EEv(
214*67e74705SXin Li }
215