1 // RUN: %clang_cc1 -emit-llvm %s -o - -triple=x86_64-apple-darwin9 -fblocks -std=c++11 | FileCheck %s
5 // CHECK: @unmangled_variable ={{.*}} global
6 // CHECK: @_ZN1N1iE ={{.*}} global
7 // CHECK: @_ZZN1N1fEiiE1b = internal global
8 // CHECK: @_ZZN1N1gEvE1a = internal global
9 // CHECK: @_ZGVZN1N1gEvE1a = internal global
11 //CHECK: @pr5966_i = external global
12 //CHECK: @_ZL8pr5966_j = internal global
14 // CHECK-LABEL: define{{.*}} zeroext i1 @_ZplRK1YRA100_P1X
15 bool operator+(const Y
&, X
* (&xs
)[100]) { return false; }
17 // CHECK-LABEL: define{{.*}} void @_Z1f1s
18 typedef struct { int a
; } s
;
21 // CHECK-LABEL: define{{.*}} void @_Z1f1e
22 typedef enum { foo
} e
;
25 // CHECK-LABEL: define{{.*}} void @_Z1f1u
26 typedef union { int a
; } u
;
29 // CHECK-LABEL: define{{.*}} void @_Z1f1x
30 typedef struct { int a
; } x
,y
;
33 // CHECK-LABEL: define{{.*}} void @_Z1fv
36 // CHECK-LABEL: define{{.*}} void @_ZN1N1fEv
37 namespace N
{ void f() { } }
39 // CHECK-LABEL: define{{.*}} void @_ZN1N1N1fEv
40 namespace N
{ namespace N
{ void f() { } } }
42 // CHECK-LABEL: define{{.*}} void @unmangled_function
43 extern "C" { namespace N
{ void unmangled_function() { } } }
45 extern "C" { namespace N
{ int unmangled_variable
= 10; } }
47 namespace N
{ int i
; }
49 namespace N
{ int f(int, int) { static int b
; return b
; } }
51 namespace N
{ int h(); void g() { static int a
= h(); } }
53 // CHECK-LABEL: define{{.*}} void @_Z1fno
54 void f(__int128_t
, __uint128_t
) {}
56 template <typename T
> struct S1
{};
58 // CHECK-LABEL: define{{.*}} void @_Z1f2S1IiE
61 // CHECK-LABEL: define{{.*}} void @_Z1f2S1IdE
64 template <int N
> struct S2
{};
65 // CHECK-LABEL: define{{.*}} void @_Z1f2S2ILi100EE
68 // CHECK-LABEL: define{{.*}} void @_Z1f2S2ILin100EE
71 template <bool B
> struct S3
{};
73 // CHECK-LABEL: define{{.*}} void @_Z1f2S3ILb1EE
76 // CHECK-LABEL: define{{.*}} void @_Z1f2S3ILb0EE
81 // CHECK-LABEL: define{{.*}} void @_Z1fM1SKFvvE
82 void f(void (S::*)() const) {}
84 // CHECK-LABEL: define{{.*}} void @_Z1fM1SFvvE
85 void f(void (S::*)()) {}
87 // CHECK-LABEL: define{{.*}} void @_Z1fi
90 template<typename T
, typename U
> void ft1(U u
, T t
) { }
92 template<typename T
> void ft2(T t
, void (*)(T
), void (*)(T
)) { }
94 template<typename T
, typename U
= S1
<T
> > struct S4
{ };
95 template<typename T
> void ft3(S4
<T
>*) { }
98 template<typename T
> void ft1(T
) { }
102 // CHECK: @_Z3ft1IidEvT0_T_
103 ft1
<int, double>(1, 0);
105 // CHECK: @_Z3ft2IcEvT_PFvS0_ES2_
108 // CHECK: @_Z3ft3IiEvP2S4IT_2S1IS1_EE
111 // CHECK: @_ZN2NS3ft1IiEEvT_
116 template<int I
> struct S5
{ };
118 template<int I
> void ft4(S5
<I
>) { }
120 // CHECK: @_Z3ft4ILi10EEv2S5IXT_EE
123 // CHECK: @_Z3ft4ILi20EEv2S5IXT_EE
133 extern "C" { struct a
{ int b
; }; }
143 const Debug
& operator<< (unsigned a
) const { return *this; }
146 // CHECK: @_ZNK5DebuglsEj
147 int main(void) { dbg
<< 32 ;}
150 template<typename T
> struct S6
{
154 template<typename T
> void ft5(typename S6
<T
>::B
) { }
155 // CHECK: @_Z3ft5IiEvN2S6IT_E1BE
156 template void ft5
<int>(int);
158 template<typename T
> class A
{};
161 template<typename T
> bool operator==(const A
<T
>&, const A
<T
>&) { return true; }
164 // CHECK: @_ZN2NSeqIcEEbRK1AIT_ES5_
165 template bool NS::operator==(const ::A
<char>&, const ::A
<char>&);
168 template<typename T
> bool operator==(const A
<T
>&, const A
<T
>&) { return true; }
171 // CHECK: @_ZSteqIcEbRK1AIT_ES4_
172 template bool std::operator==(const ::A
<char>&, const ::A
<char>&);
178 template <typename T
> typename
T::U
ft6(const T
&) { return 0; }
180 // CHECK: @_Z3ft6I1SENT_1UERKS1_
181 template int ft6
<S
>(const S
&);
183 template<typename
> struct __is_scalar_type
{
184 enum { __value
= 1 };
187 template<bool, typename
> struct __enable_if
{ };
189 template<typename T
> struct __enable_if
<true, T
> {
194 template<typename T
> typename __enable_if
<__is_scalar_type
<T
>::__value
, void>::__type
ft7() { }
196 // CHECK: @_Z3ft7IiEN11__enable_ifIXsr16__is_scalar_typeIT_EE7__valueEvE6__typeEv
197 template void ft7
<int>();
198 // CHECK: @_Z3ft7IPvEN11__enable_ifIXsr16__is_scalar_typeIT_EE7__valueEvE6__typeEv
199 template void ft7
<void*>();
207 void extern_f(void) { }
219 // CHECK: @_ZN2S7C2Ev
220 // CHECK: @_ZN2S7Ut_C1Ev
221 // CHECK: @_ZN2S7C1Ev
225 template<typename T
> typename __enable_if
<(__is_scalar_type
<T
>::__value
), void>::__type
ft8() { }
226 // CHECK: @_Z3ft8IiEN11__enable_ifIXsr16__is_scalar_typeIT_EE7__valueEvE6__typeEv
227 template void ft8
<int>();
228 // CHECK: @_Z3ft8IPvEN11__enable_ifIXsr16__is_scalar_typeIT_EE7__valueEvE6__typeEv
229 template void ft8
<void*>();
233 template<typename
> struct __is_scalar_type
{
234 enum { __value
= 0 };
237 template<bool, typename
> struct __enable_if
{};
238 template<typename T
> struct __enable_if
<true, T
> { typedef T __type
; };
241 // CHECK-LABEL: define linkonce_odr void @_ZN6PR57968__fill_aIiEENS_11__enable_ifIXntsr16__is_scalar_typeIT_EE7__valueEvE6__typeEv
242 typename __enable_if
<!__is_scalar_type
<T
>::__value
, void>::__type
__fill_a() { };
244 void f() { __fill_a
<int>(); }
247 namespace Expressions
{
250 // CHECK-LABEL: define weak_odr void @_ZN11Expressions2f1ILi1EEEvPAplngT_Li2E_i
251 template <int i
> void f1(int (*)[(-i
) + 2]) { };
252 template void f1
<1>(int (*)[1]);
254 // CHECK-LABEL: define weak_odr void @_ZN11Expressions2f2ILi1EEEvPApsT__i
255 template <int i
> void f2(int (*)[+i
]) { };
256 template void f2
<1>(int (*)[1]);
260 // CHECK-LABEL: define weak_odr void @_ZN11Expressions2f3ILi1EEEvPAplT_T__i
261 template <int i
> void f3(int (*)[i
+i
]) { };
262 template void f3
<1>(int (*)[2]);
264 // CHECK-LABEL: define weak_odr void @_ZN11Expressions2f4ILi1EEEvPAplplLi2ET_T__i
265 template <int i
> void f4(int (*)[2 + i
+i
]) { };
266 template void f4
<1>(int (*)[4]);
268 // The ternary operator.
269 // CHECK-LABEL: define weak_odr void @_ZN11Expressions2f4ILb1EEEvPAquT_Li1ELi2E_i
270 template <bool b
> void f4(int (*)[b
? 1 : 2]) { };
271 template void f4
<true>(int (*)[1]);
275 Ops
& operator+(const Ops
&);
276 Ops
& operator-(const Ops
&);
277 Ops
& operator&(const Ops
&);
278 Ops
& operator*(const Ops
&);
283 // CHECK-LABEL: define{{.*}} nonnull align {{[0-9]+}} dereferenceable({{[0-9]+}}) ptr @_ZN3OpsplERKS_
284 Ops
& Ops::operator+(const Ops
&) { return *this; }
285 // CHECK-LABEL: define{{.*}} nonnull align {{[0-9]+}} dereferenceable({{[0-9]+}}) ptr @_ZN3OpsmiERKS_
286 Ops
& Ops::operator-(const Ops
&) { return *this; }
287 // CHECK-LABEL: define{{.*}} nonnull align {{[0-9]+}} dereferenceable({{[0-9]+}}) ptr @_ZN3OpsanERKS_
288 Ops
& Ops::operator&(const Ops
&) { return *this; }
289 // CHECK-LABEL: define{{.*}} nonnull align {{[0-9]+}} dereferenceable({{[0-9]+}}) ptr @_ZN3OpsmlERKS_
290 Ops
& Ops::operator*(const Ops
&) { return *this; }
294 template<bool> class P
;
295 template<> class P
<true> {};
297 template<template <bool> class, bool>
300 template<typename T
, typename
= Policy
<P
, true> > class Alloc
302 T
*allocate(int, const void*) { return 0; }
305 // CHECK-LABEL: define weak_odr noundef ptr @_ZN6PR58615AllocIcNS_6PolicyINS_1PELb1EEEE8allocateEiPKv
306 template class Alloc
<char>;
309 // CHECK-LABEL: define{{.*}} void @_Z1fU13block_pointerFiiiE
310 void f(int (^)(int, int)) { }
327 template <class T
> void f(T
, char (&buffer
)[sizeof(ovl(T()))]) {}
333 // CHECK-LABEL: define{{.*}} void @_ZN5test05test0Ev()
334 // CHECK-LABEL: define linkonce_odr void @_ZN5test01fIdEEvT_RAszcl3ovlcvS1__EE_c(
337 char buffer
[sizeof(int)];
340 // CHECK-LABEL: define{{.*}} void @_ZN5test05test1Ev()
341 // CHECK-LABEL: define linkonce_odr void @_ZN5test01fIiEEvT_RAszcl3ovlcvS1__EE_c(
343 template <class T
> void g(char (&buffer
)[sizeof(T() + 5.0f
)]) {}
345 char buffer
[sizeof(float)];
348 // CHECK-LABEL: define linkonce_odr void @_ZN5test01gIfEEvRAszplcvT__ELf40a00000E_c(
350 template <class T
> void h(char (&buffer
)[sizeof(T() + 5.0)]) {}
352 char buffer
[sizeof(double)];
355 // CHECK-LABEL: define linkonce_odr void @_ZN5test01hIfEEvRAszplcvT__ELd4014000000000000E_c(
357 template <class T
> void j(char (&buffer
)[sizeof(T().buffer
)]) {}
358 struct A
{ double buffer
[128]; };
363 // CHECK-LABEL: define linkonce_odr void @_ZN5test01jINS_1AEEEvRAszdtcvT__E6buffer_c(
365 template <class T
> void k(char (&buffer
)[sizeof(T() + 0.0f
)]) {}
367 char buffer
[sizeof(float)];
370 // CHECK-LABEL: define linkonce_odr void @_ZN5test01kIfEEvRAszplcvT__ELf00000000E_c(
375 template<typename T
> struct X
{ };
376 template<template<class> class Y
, typename T
> void f(Y
<T
>) { }
377 // CHECK-LABEL: define weak_odr void @_ZN5test11fINS_1XEiEEvT_IT0_E
378 template void f(X
<int>);
381 // CHECK-LABEL: define internal void @_ZL27functionWithInternalLinkagev()
382 static void functionWithInternalLinkage() { }
383 void g() { functionWithInternalLinkage(); }
386 template <class T
> decltype(((T
*) 0)->member
) read_member(T
& obj
) {
390 struct A
{ int member
; } obj
;
392 return read_member(obj
);
395 // CHECK-LABEL: define linkonce_odr noundef i32 @_ZN5test211read_memberINS_1AEEEDtptcvPT_Li0E6memberERS2_(
399 struct AmbiguousBase
{ int ab
; };
400 struct Path1
: AmbiguousBase
{ float p
; };
401 struct Path2
: AmbiguousBase
{ double p
; };
402 struct Derived
: Path1
, Path2
{ };
404 // CHECK-LABEL: define linkonce_odr noundef i32 @_ZN5test38get_ab_1INS_7DerivedEEEDtptcvPT_Li0Esr5Path1E2abERS2_(
405 template <class T
> decltype(((T
*) 0)->Path1::ab
) get_ab_1(T
&ref
) { return ref
.Path1::ab
; }
407 // CHECK-LABEL: define linkonce_odr noundef i32 @_ZN5test38get_ab_2INS_7DerivedEEEDtptcvPT_Li0Esr5Path2E2abERS2_(
408 template <class T
> decltype(((T
*) 0)->Path2::ab
) get_ab_2(T
&ref
) { return ref
.Path2::ab
; }
410 // CHECK-LABEL: define linkonce_odr noundef float @_ZN5test37get_p_1INS_7DerivedEEEDtptcvPT_Li0Esr5Path1E1pERS2_(
411 template <class T
> decltype(((T
*) 0)->Path1::p
) get_p_1(T
&ref
) { return ref
.Path1::p
; }
413 // CHECK-LABEL: define linkonce_odr noundef double @_ZN5test37get_p_2INS_7DerivedEEEDtptcvPT_Li0Esr5Path2E1pERS2_(
414 template <class T
> decltype(((T
*) 0)->Path2::p
) get_p_2(T
&ref
) { return ref
.Path2::p
; }
425 // CHECK-LABEL: define{{.*}} void @_ZN5test41gEPNS_3zedIXadL_ZNS_3foo3barEEEEE
427 struct foo
{ int bar
; };
428 template <int (foo::*)>
430 void g(zed
<&foo::bar
>*)
433 // CHECK-LABEL: define{{.*}} void @_ZN5test51gEPNS_3zedIXadL_ZNS_3foo3barEEEEE
435 struct foo
{ static int bar
; };
438 void g(zed
<&foo::bar
>*)
441 // CHECK-LABEL: define{{.*}} void @_ZN5test61gEPNS_3zedIXadL_ZNS_3foo3barEvEEEE
443 struct foo
{ int bar(); };
444 template <int (foo::*)()>
446 void g(zed
<&foo::bar
>*)
449 // CHECK-LABEL: define{{.*}} void @_ZN5test71gEPNS_3zedIXadL_ZNS_3foo3barEvEEEE
451 struct foo
{ static int bar(); };
452 template <int (*f
)()>
454 void g(zed
<&foo::bar
>*)
457 // CHECK-LABEL: define weak_odr void @_ZN5test81AIL_ZNS_1B5valueEEE3incEv
459 template <int &counter
> class A
{ void inc() { counter
++; } };
460 class B
{ public: static int value
; };
461 template class A
<B::value
>;
463 // CHECK: declare void @_ZN5test91fIiNS_3barEEEvRKNT0_3baz1XE
470 typedef foo
<int> baz
;
472 template <class zaz
, class zed
>
473 void f(const typename
zed::baz::X
&);
480 template <char P1
> struct S
{};
481 template <char P2
> void f(struct S
<false ? 'a' : P2
> ) {}
483 // CHECK-LABEL: define weak_odr void @_ZN6test101fILc3EEEvNS_1SIXquLb0ELc97ET_EEE(
484 template void f
<(char) 3>(struct S
<3>);
488 // CHECK: @_ZN6test111fEz
495 // CHECK: @_ZN6test111A1fEz
501 // CHECK: _ZN6test121fENS_1AILt33000EEE
502 template <unsigned short> struct A
{ };
508 template <template <class> class T
> class A
{};
509 template <class U
> class B
{};
511 template <template<class> class T
> void foo(const A
<T
> &a
) {}
513 // CHECK-LABEL: define weak_odr void @_ZN6test133fooINS_1BEEEvRKNS_1AIT_EE(
514 template void foo(const A
<B
> &a
);
522 // CHECK-LABEL: define{{.*}} i32 @_ZN6test141S1aEv
523 // CHECK: load i32, ptr @_ZN6test141S1xE
524 int S::a() { return S::x
; }
530 template <int I
> struct S
{};
532 template <int I
> void f(S
<I
+ e
>) {}
534 // CHECK-LABEL: define weak_odr void @_ZN6test151fILi7EEEvNS_1SIXplT_LNS_1EE3EEEE(
535 template void f
<7>(S
<7 + e
>);
539 template <int N
> struct A
{};
542 static int foo(void);
545 template <class T
> A
<sizeof(T::foo())> func(void);
547 // CHECK-LABEL: define{{.*}} void @_ZN6test174testEv()
548 // CHECK: call {{.*}} @_ZN6test174funcINS_1BEEENS_1AIXszclsrT_3fooEEEEv()
562 template <int (A::*)()> struct S
{};
564 template <typename T
> void f(S
<&T::operator+>) {}
565 template void f
<A
>(S
<&A::operator+>);
567 template <typename T
> void f(S
<&T::operator- >) {}
568 template void f
<A
>(S
<&A::operator- >);
570 template <typename T
> void f(S
<&T::operator*>) {}
571 template void f
<A
>(S
<&A::operator*>);
573 template <typename T
> void f(S
<&T::operator&>) {}
574 template void f
<A
>(S
<&A::operator&>);
576 // CHECK-LABEL: define weak_odr void @_ZN6test181fINS_1AEEEvNS_1SIXadsrT_onplEEE
577 // CHECK-LABEL: define weak_odr void @_ZN6test181fINS_1AEEEvNS_1SIXadsrT_onmiEEE
578 // CHECK-LABEL: define weak_odr void @_ZN6test181fINS_1AEEEvNS_1SIXadsrT_onmlEEE
579 // CHECK-LABEL: define weak_odr void @_ZN6test181fINS_1AEEEvNS_1SIXadsrT_onanEEE
584 template <typename T
> int f();
587 template <typename T
> int operator-();
590 template <int (A::*)()> struct S
{};
592 template <typename T
> void g (S
<&T::template f
<int> >) {}
593 template <typename T
> void g (S
<&T::operator+ >) {}
594 template <typename T
> void g (S
<&T::operator int>) {}
595 template <typename T
> void g (S
<&T::template operator- <double> >) {}
597 // CHECK-LABEL: define weak_odr void @_ZN6test191gINS_1AEEEvNS_1SIXadsrT_1fIiEEEE(
598 template void g
<A
>(S
<&A::f
<int> >);
599 // CHECK-LABEL: define weak_odr void @_ZN6test191gINS_1AEEEvNS_1SIXadsrT_onplEEE(
600 template void g
<A
>(S
<&A::operator+>);
601 // CHECK-LABEL: define weak_odr void @_ZN6test191gINS_1AEEEvNS_1SIXadsrT_oncviEEE(
602 template void g
<A
>(S
<&A::operator int>);
603 // CHECK-LABEL: define weak_odr void @_ZN6test191gINS_1AEEEvNS_1SIXadsrT_onmiIdEEEE(
604 template void g
<A
>(S
<&A::operator-<double> >);
608 template <class T
> T
*f(const T
&);
609 template <class T
> T
*f(T
*);
611 // CHECK-LABEL: define weak_odr void @_ZN6test205test0IiEEvDTcl1fIPT_ELi0EEE(
612 template <class T
> void test0(decltype(f
<T
*>(0))) {}
613 template void test0
<int>(decltype(f
<int*>(0)));
615 // CHECK-LABEL: define weak_odr void @_ZN6test205test1IiEEvDTcl1fIEcvT__EEE(
616 template <class T
> void test1(decltype(f
<>(T()))) {}
617 template void test1
<int>(decltype(f
<>(int())));
621 // CHECK-LABEL: define{{.*}} void @_ZN6test2112vla_arg_funcEiPA_i(
622 void vla_arg_func(int X
, int a
[X
][X
]) {}
626 // CHECK-LABEL: define{{.*}} void @_ZN6test221fEDn(
627 void f(decltype(nullptr)) { }
631 typedef void * const vpc
;
633 // CHECK-LABEL: define{{.*}} void @_ZN6test231fERA10_KPv(
634 void f(vpc (&)[10]) {}
636 typedef vpc vpca5
[5];
637 void f(vpca5
volatile (&)[10]) {}
638 // CHECK-LABEL: define{{.*}} void @_ZN6test231fERA10_A5_VKPv(
644 // CHECK: call noundef i32 @_ZN6test243fooEv()
650 // CHECK: call noundef signext i8 @_ZN6test24L3barEv()
656 template <void (*fn
)()> struct A
{
657 static void call() { fn(); }
661 // CHECK: call void @_ZN6test251AIXadL_ZNS_3fooEvEEE4callEv()
667 template <template <class> class T
> void foo(decltype(T
<float>::object
) &object
) {}
669 template <class T
> struct holder
{ static T object
; };
674 // CHECK: call void @_ZN6test263fooINS_6holderEEEvRDtsrT_IfE6objectE(
689 template <class T
> void a(decltype(T::inner::object
) &object
) {}
690 template <class T
> void b(decltype(T().Alias::meth()) &object
) {}
694 // CHECK: call void @_ZN6test271aINS_1AEEEvRDtsrNT_5innerE6objectE(
696 // CHECK: call void @_ZN6test271bINS_1AEEEvRDTcldtcvT__Esr5AliasE4methEE(
701 // An injected class name type in a unresolved-name.
703 template <class T
> struct A
{
707 template <class T
> void foo(decltype(A
<T
>::A::bit
) x
);
710 foo
<char>(A
<char>::bit
);
711 // CHECK: call void @_ZN6test283fooIcEEvDtsr1AIT_E1AE3bitE(
715 // An enclosing template type parameter in an unresolved-name.
717 template <class T
> struct A
{
718 template <class U
> static void foo(decltype(T::fn(U())) x
);
720 struct B
{ static int fn(int); static long fn(long); };
724 // CHECK: call void @_ZN6test291AINS_1BEE3fooIiEEvDTclsrS1_2fncvT__EEE(
728 // An enclosing template template parameter in an unresolved-name.
730 template <template <class> class T
> struct A
{
731 template <class U
> static void foo(decltype(T
<U
>::fn()) x
);
733 template <class T
> struct B
{ static T
fn(); };
737 // CHECK: call void @_ZN6test301AINS_1BEE3fooIiEEvDTclsrS1_IT_EE2fnEE(
741 namespace test31
{ // instantiation-dependent mangling of decltype
743 template<class T
> auto f1(T p
)->decltype(x
) { return 0; }
744 // The return type in the mangling of the template signature
745 // is encoded as "i".
746 template<class T
> auto f2(T p
)->decltype(p
) { return 0; }
747 // The return type in the mangling of the template signature
748 // is encoded as "Dtfp_E".
750 template<class T
> auto f3(T p
)->decltype(g(p
)) {}
752 // CHECK-LABEL: define weak_odr noundef i32 @_ZN6test312f1IiEEiT_(
753 template int f1(int);
754 // CHECK-LABEL: define weak_odr noundef i32 @_ZN6test312f2IiEEDtfp_ET_
755 template int f2(int);
756 // CHECK-LABEL: define weak_odr void @_ZN6test312f3IiEEDTcl1gfp_EET_
757 template void f3(int);
762 template<typename T
, int=T::value
> struct A
{
765 struct B
{ enum { value
= 4 }; };
767 template <class T
> typename A
<T
>::type
foo() { return 0; }
770 // CHECK: call noundef i32 @_ZN6test323fooINS_1BEEENS_1AIT_XsrS3_5valueEE4typeEv()
775 template <class T
> struct X
{
776 enum { value
= T::value
};
779 template<typename T
, int=X
<T
>::value
> struct A
{
782 struct B
{ enum { value
= 4 }; };
784 template <class T
> typename A
<T
>::type
foo() { return 0; }
788 // CHECK: call noundef i32 @_ZN6test333fooINS_1BEEENS_1AIT_Xsr1XIS3_EE5valueEE4typeEv()
793 // Mangling for instantiation-dependent decltype expressions.
795 void f(decltype(sizeof(decltype(T() + T())))) {}
797 // CHECK-LABEL: define weak_odr void @_ZN6test341fIiEEvDTstDTplcvT__EcvS1__EEE
798 template void f
<int>(decltype(sizeof(1)));
800 // Mangling for non-instantiation-dependent sizeof expressions.
802 void f2(int (&)[N
+ sizeof(int*)]) {}
804 // CHECK-LABEL: define weak_odr void @_ZN6test342f2ILj4EEEvRAplT_Lm8E_i
805 template void f2
<4>(int (&)[4 + sizeof(int*)]);
807 // Mangling for non-instantiation-dependent sizeof expressions
808 // involving an implicit conversion of the result of the sizeof.
809 template<unsigned long long N
>
810 void f3(int (&)[N
+ sizeof(int*)]) {}
812 // CHECK-LABEL: define weak_odr void @_ZN6test342f3ILy4EEEvRAplT_Ly8E_i
813 template void f3
<4>(int (&)[4 + sizeof(int*)]);
815 // Mangling for instantiation-dependent sizeof() expressions as
816 // template arguments.
817 template<unsigned> struct A
{ };
819 template<typename T
> void f4(::test34::A
<sizeof(sizeof(decltype(T() + T())))>) { }
821 // CHECK-LABEL: define weak_odr void @_ZN6test342f4IiEEvNS_1AIXszstDTplcvT__EcvS2__EEEEE
822 template void f4
<int>(A
<sizeof(sizeof(int))>);
826 // Dependent operator names of unknown arity.
828 template <typename U
> A
operator+(U
) const;
832 void f1(decltype(sizeof(&T::template operator+<int>))) {}
834 // CHECK-LABEL: define weak_odr void @_ZN6test352f1INS_1AEEEvDTszadsrT_onplIiEE
835 template void f1
<A
>(__SIZE_TYPE__
);
839 template<unsigned> struct A
{ };
841 template<typename
...Types
>
842 auto f1(Types
... values
) -> A
<sizeof...(values
)> { }
844 // CHECK: define weak_odr {{.*}} @_ZN6test362f1IJifEEENS_1AIXsZfp_EEEDpT_
845 template A
<2> f1(int, float);
852 typedef struct { } b
;
853 typedef struct { } *c
;
857 template<typename T
> void func(T
) { }
859 // CHECK-LABEL: define linkonce_odr void @_ZN6test374funcINS_3fooUt_EEEvT_
861 // CHECK-LABEL: define linkonce_odr void @_ZN6test374funcINS_3fooUt0_EEEvT_
863 // CHECK-LABEL: define linkonce_odr void @_ZN6test374funcINS_3fooUt1_EEEvT_
868 // CHECK-LABEL: define{{.*}} void @_Z6ASfuncPU3AS3i
869 void ASfunc(__attribute__((address_space(3))) int* x
) {}
872 // CHECK-LABEL: define linkonce_odr void @_ZN6test384funcINS_3fooUt_EEEvT_
878 template <typename T
> void func(T
) {}
879 void test() { func(foo().a
); }
883 // CHECK-LABEL: define internal void @"_ZN6test394funcINS_3$_03$_1EEEvT_"
887 template<typename T
> void func(T
) {}
895 // CHECK: ptr {{.*}} @_ZZN6test401fEvE1a_0
908 // CHECK: define linkonce_odr void @_ZN6test414funcINS_1XEEEvNS_3fooILi20ES1_EE
909 template <int i
, class T
> struct foo
{
910 template <class T2
= T
> friend void func(foo x
) {}
915 void g() { func(foo
<20, X
>()); }
919 // CHECK: define linkonce_odr void @_ZN6test424funcINS_1XEEEvNS_3fooILi20ES1_EE
920 template <int i
, template <class> class T
> struct foo
{
921 template <template <class> class T2
= T
> friend void func(foo x
) {}
924 template <class V
> struct X
{
927 void g() { func(foo
<20, X
>()); }
931 // CHECK-LABEL: define{{.*}} void @_ZN6test431gEPNS_3zedIXadL_ZNS_3fooUt_3barEEEEE
932 struct foo
{ union { int bar
; }; };
933 template <int (foo::*)>
935 void g(zed
<&foo::bar
>*)
940 struct foo
{ void bar() __restrict
{ }; } obj
;
945 // CHECK-LABEL: define linkonce_odr void @_ZN6test443foo3barEv(ptr {{[^,]*}} %this)
952 template <typename T
>
953 void f(enum T::e
*) {}
954 template void f
<S
>(S::e
*);
955 // CHECK-LABEL: define weak_odr void @_ZN6test451fINS_1SEEEvPTeNT_1eE(ptr noundef %0)
962 template <typename T
>
963 void f(struct T::s
*) {}
964 template void f
<S
>(S::s
*);
965 // CHECK-LABEL: define weak_odr void @_ZN6test461fINS_1SEEEvPTsNT_1sE(ptr noundef %0)
972 template <typename T
>
973 void f(class T::c
*) {}
974 template void f
<S
>(S::c
*);
975 // CHECK-LABEL: define weak_odr void @_ZN6test471fINS_1SEEEvPTsNT_1cE(ptr noundef %0)
982 template <typename T
>
983 void f(union T::u
*) {}
984 template void f
<S
>(S::u
*);
985 // CHECK-LABEL: define weak_odr void @_ZN6test481fINS_1SEEEvPTuNT_1uE(ptr noundef %0)
992 template <template <int> class T
>
996 // CHECK-LABEL: declare void @_ZN6test493finINS_1SEEET_ILi3EES3_()
1003 template <template <int> class T
>
1007 // CHECK-LABEL: declare void @_ZN6test503finINS_1SEEET_ILi3EES2_ILi4EE()
1011 template <typename T
>
1012 decltype(T().~T()) fun() {}
1013 template void fun
<int>();
1014 // CHECK-LABEL: @_ZN6test513funIiEEDTcldtcvT__EdnS1_EEv
1015 template void fun
<X
>();
1016 // CHECK-LABEL: @_ZN6test513funI1XEEDTcldtcvT__EdnS2_EEv
1017 template void fun
<S1
<int> >();
1018 // CHECK-LABEL: @_ZN6test513funI2S1IiEEEDTcldtcvT__EdnS3_EEv
1021 template <typename T
>
1026 template <typename T
>
1027 decltype(S1
<T
>().~S1
<T
>()) fun1() {};
1028 template <typename U
, typename T
>
1029 decltype(U().~S1
<T
>()) fun2() {}
1030 template <typename U
, typename T
>
1031 decltype(S1
<T
>().~U()) fun3() {}
1032 template <typename T
>
1033 decltype(S1
<T
>().~S1
<T
>(), S1
<T
>().~S1
<T
>()) fun4() {};
1034 template <typename T
>
1035 decltype(S1
<int>().~S1
<T
>()) fun5(){};
1036 template <template <typename T
> class U
>
1037 decltype(S1
<int>().~U
<int>()) fun6(){};
1038 template <typename T
>
1039 decltype(E().E::~T()) fun7() {}
1040 template <template <typename
> class U
>
1041 decltype(X
<int>::Y().U
<int>::Y::~Y()) fun8() {}
1042 template void fun1
<int>();
1043 // CHECK-LABEL: @_ZN6test514fun1IiEEDTcldtcv2S1IT_E_Edn2S1IS2_EEEv
1044 template void fun2
<S1
<int>, int>();
1045 // CHECK-LABEL: @_ZN6test514fun2I2S1IiEiEEDTcldtcvT__Edn2S1IT0_EEEv
1046 template void fun3
<S1
<int>, int>();
1047 // CHECK-LABEL: @_ZN6test514fun3I2S1IiEiEEDTcldtcvS1_IT0_E_EdnT_EEv
1048 template void fun4
<int>();
1049 // CHECK-LABEL: @_ZN6test514fun4IiEEDTcmcldtcv2S1IT_E_Edn2S1IS2_EEcldtcvS3__Edn2S1IS2_EEEv
1050 template void fun5
<int>();
1051 // CHECK-LABEL: @_ZN6test514fun5IiEEDTcldtcv2S1IiE_Edn2S1IT_EEEv
1052 template void fun6
<S1
>();
1053 // CHECK-LABEL: @_ZN6test514fun6I2S1EEDTcldtcvS1_IiE_EdnT_IiEEEv
1054 template void fun7
<E
>();
1055 // CHECK-LABEL: @_ZN6test514fun7INS_1EEEEDTcldtcvS1__Esr1EEdnT_EEv
1056 template void fun8
<X
>();
1062 template <typename
... T
>
1063 auto f4(T
... x
) -> decltype(operator+(x
...));
1064 // CHECK-LABEL: @_ZN6test522f4IJNS_1XEEEEDTclonplspfp_EEDpT_
1065 void use() { f4(X
{}); }
1070 using t1
= struct { int z
; };
1071 using t2
= struct { double z
; };
1072 using t3
= struct { float z
; };
1073 using t4
= struct { float z
; };
1075 __attribute__((used
)) c(t1
) {}
1076 __attribute__((used
)) c(t2
) {}
1077 __attribute__((used
)) c(t3
) {}
1078 __attribute__((used
)) c(t4
) {}
1079 // CHECK-LABEL: @_ZN6test531cC2ENS0_2t1E
1080 // CHECK-LABEL: @_ZN6test531cC2ENS0_2t2E
1081 // CHECK-LABEL: @_ZN6test531cC2ENS0_2t3E
1082 // CHECK-LABEL: @_ZN6test531cC2ENS0_2t4E
1088 using t1
= struct { int z
; } *;
1089 using t2
= struct { double z
; } *;
1091 __attribute__((used
)) c(t1
) {}
1092 __attribute__((used
)) c(t2
) {}
1093 // CHECK-LABEL: @_ZN6test541cC2EPNS0_Ut_E
1094 // CHECK-LABEL: @_ZN6test541cC2EPNS0_Ut0_E
1101 template <typename T
>
1102 void f1(T
, __underlying_type(T
)) {}
1103 template void f1
<E
>(E
, __underlying_type(E
));
1104 // CHECK-LABEL: @_ZN6test552f1INS_1EEEEvT_u17__underlying_typeIS2_E
1106 template <typename T
> void f2(T
, __add_lvalue_reference(T
)) {}
1107 template void f2
<int>(int, __add_lvalue_reference(int));
1108 // CHECK-LABEL: @_ZN6test552f2IiEEvT_u22__add_lvalue_referenceIS1_E
1110 template <typename T
> void f3(T
, __add_pointer(T
)) {}
1111 template void f3
<int>(int, __add_pointer(int));
1112 // CHECK-LABEL: @_ZN6test552f3IiEEvT_u13__add_pointerIS1_E
1114 template <typename T
> void f4(T
, __add_rvalue_reference(T
)) {}
1115 template void f4
<int>(int, __add_rvalue_reference(int));
1116 // CHECK-LABEL: @_ZN6test552f4IiEEvT_u22__add_rvalue_referenceIS1_E
1118 template <typename T
> void f5(T
, __decay(T
)) {}
1119 template void f5
<int>(int, __decay(int));
1120 // CHECK-LABEL: @_ZN6test552f5IiEEvT_u7__decayIS1_E
1122 template <typename T
> void f6(T
, __make_signed(T
)) {}
1123 template void f6
<int>(int, __make_signed(int));
1124 // CHECK-LABEL: @_ZN6test552f6IiEEvT_u13__make_signedIS1_E
1126 template <typename T
> void f7(T
, __make_unsigned(T
)) {}
1127 template void f7
<int>(int, __make_unsigned(int));
1128 // CHECK-LABEL: @_ZN6test552f7IiEEvT_u15__make_unsignedIS1_E
1130 template <typename T
> void f8(T
, __remove_const(T
)) {}
1131 template void f8
<int>(int, __remove_const(int));
1132 // CHECK-LABEL: @_ZN6test552f8IiEEvT_u14__remove_constIS1_E
1134 template <typename T
> void f9(T
, __remove_cv(T
)) {}
1135 template void f9
<int>(int, __remove_cv(int));
1136 // CHECK-LABEL: @_ZN6test552f9IiEEvT_u11__remove_cvIS1_E
1138 template <typename T
> void f10(T
, __remove_cvref(T
)) {}
1139 template void f10
<int>(int, __remove_cvref(int));
1140 // CHECK-LABEL: @_ZN6test553f10IiEEvT_u14__remove_cvrefIS1_E
1142 template <typename T
> void f11(T
, __remove_volatile(T
)) {}
1143 template void f11
<int>(int, __remove_volatile(int));
1144 // CHECK-LABEL: @_ZN6test553f11IiEEvT_u17__remove_volatileIS1_E
1146 template <typename T
> void f12(T
, __remove_extent(T
)) {}
1147 template void f12
<int>(int, __remove_extent(int));
1148 // CHECK-LABEL: @_ZN6test553f12IiEEvT_u15__remove_extentIS1_E
1150 template <typename T
> void f13(T
, __remove_all_extents(T
)) {}
1151 template void f13
<int>(int, __remove_all_extents(int));
1152 // CHECK-LABEL: @_ZN6test553f13IiEEvT_u20__remove_all_extentsIS1_E
1154 template <typename T
> void f14(T
, __remove_pointer(T
)) {}
1155 template void f14
<int>(int, __remove_pointer(int));
1156 // CHECK-LABEL: @_ZN6test553f14IiEEvT_u16__remove_pointerIS1_E
1158 template <typename T
> void f15(T
, __remove_reference_t(T
)) {}
1159 template void f15
<int>(int, __remove_reference_t(int));
1160 // CHECK-LABEL: @_ZN6test553f15IiEEvT_u20__remove_reference_tIS1_E
1162 template <typename T
> void f16(T
, __remove_volatile(T
)) {}
1163 template void f16
<int>(int, __remove_volatile(int));
1164 // CHECK-LABEL: @_ZN6test553f16IiEEvT_u17__remove_volatileIS1_E
1166 template <typename T
> void f17(T
, __remove_restrict(T
)) {}
1167 template void f17
<int>(int, __remove_restrict(int));
1168 // CHECK-LABEL: @_ZN6test553f17IiEEvT_u17__remove_restrictIS1_E
1169 } // namespace test55
1172 struct A
{ A
*operator->(); int n
; } a
;
1173 template<int N
> void f(decltype(a
->n
+ N
)) {}
1174 // CHECK-LABEL: @_ZN6test561fILi0EEEvDTplptL_ZNS_1aEE1nT_E
1175 template void f
<0>(int);
1179 struct X
{ template <int N
> int f(); } x
;
1180 template<int N
> void f(decltype(x
.f
<0>() + N
)) {}
1181 // CHECK-LABEL: @_ZN6test571fILi0EEEvDTplcldtL_ZNS_1xEE1fILi0EEET_E
1182 template void f
<0>(int);
1189 template <class T
> struct identity
{ typedef T type
; };
1191 template <typename T
> A(T
, bool (identity
<T
>::type::*)());
1193 // CHECK-LABEL: @_ZN6test581AC1INS_5StateEEET_MNS_8identityIS3_E4typeEFbvE
1194 void fn1() { A(a
, &State::m_fn1
); }
1199 template<typename T
>
1207 struct X
{ int i
, j
; };
1208 auto [a
,b
] = X
{1,2};
1209 template<typename T
> void f(decltype(a
+ T())) {}
1210 // CHECK-LABEL: @_ZN6test601fIiEEvDTplL_ZNS_1aEEcvT__EE
1211 template void f
<int>(int);
1221 template <typename T
> void f(typename
T::Y::a
, typename
T::Y::b
) {}
1222 // CHECK-LABEL: @_ZN6test611fINS_1XEEEvNT_1Y1aENS3_1bE
1223 template void f
<X
>(int, int);