diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-01-13 16:39:34 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-01-13 16:39:34 +0000 |
commit | d81c7c1659747d8a0c9a687c4d15bbbf33f87dc4 (patch) | |
tree | d7930b9afb199d12ff422a0011876b9a02dcadd6 /clang/test/CodeGenCXX/mangle-variadic-templates.cpp | |
parent | b7c43b8c59678c388a42a90993f72f0bd3aebd64 (diff) | |
download | bcm5719-llvm-d81c7c1659747d8a0c9a687c4d15bbbf33f87dc4.tar.gz bcm5719-llvm-d81c7c1659747d8a0c9a687c4d15bbbf33f87dc4.zip |
Add tests for name mangling of variadic templates.
llvm-svn: 123378
Diffstat (limited to 'clang/test/CodeGenCXX/mangle-variadic-templates.cpp')
-rw-r--r-- | clang/test/CodeGenCXX/mangle-variadic-templates.cpp | 56 |
1 files changed, 55 insertions, 1 deletions
diff --git a/clang/test/CodeGenCXX/mangle-variadic-templates.cpp b/clang/test/CodeGenCXX/mangle-variadic-templates.cpp index e078f3e3bab..0167726b0d9 100644 --- a/clang/test/CodeGenCXX/mangle-variadic-templates.cpp +++ b/clang/test/CodeGenCXX/mangle-variadic-templates.cpp @@ -1,8 +1,14 @@ -// RUN: %clang_cc1 -std=c++0x -emit-llvm -o - %s | FileCheck %s +// RUN: %clang_cc1 -std=c++0x -emit-llvm -triple=x86_64-apple-darwin9 -o - %s | FileCheck %s template<unsigned I, typename ...Types> struct X { }; +template<typename T> struct identity { }; +template<typename T> struct add_reference; +template<typename ...Types> struct tuple { }; +template<int ...Values> struct int_tuple { }; +template<template<typename> class ...Templates> struct template_tuple { }; + // CHECK: define weak_odr void @_Z2f0IJEEv1XIXsZT_EJspRT_EE template<typename ...Types> void f0(X<sizeof...(Types), Types&...>) { } @@ -11,3 +17,51 @@ template void f0(X<0>); // CHECK: define weak_odr void @_Z2f0IJifdEEv1XIXsZT_EJspRT_EE template void f0<int, float, double>(X<3, int&, float&, double&>); + +// Mangling for template argument packs +template<typename ...Types> void f1() {} +// CHECK: define weak_odr void @_Z2f1IJEEvv +template void f1<>(); +// CHECK: define weak_odr void @_Z2f1IJiEEvv +template void f1<int>(); +// CHECK: define weak_odr void @_Z2f1IJifEEvv +template void f1<int, float>(); + +// Mangling function parameter packs +template<typename ...Types> void f2(Types...) {} +// CHECK: define weak_odr void @_Z2f2IJEEvspT_ +template void f2<>(); +// CHECK: define weak_odr void @_Z2f2IJiEEvspT_ +template void f2<int>(int); +// CHECK: define weak_odr void @_Z2f2IJifEEvspT_ +template void f2<int, float>(int, float); + +// Mangling non-trivial function parameter packs +template<typename ...Types> void f3(const Types *...) {} +// CHECK: define weak_odr void @_Z2f3IJEEvspPKT_ +template void f3<>(); +// CHECK: define weak_odr void @_Z2f3IJiEEvspPKT_ +template void f3<int>(const int*); +// CHECK: define weak_odr void @_Z2f3IJifEEvspPKT_ +template void f3<int, float>(const int*, const float*); + +// Mangling of type pack expansions in a template argument +template<typename ...Types> tuple<Types...> f4() {} +// CHECK: define weak_odr void @_Z2f4IJifdEE5tupleIJspT_EEv +template tuple<int, float, double> f4(); + +// Mangling of type pack expansions in a function type +template<typename R, typename ...ArgTypes> identity<R(ArgTypes...)> f5() {} +// CHECK: define weak_odr void @_Z2f5IiJifdEE8identityIFT_spT0_EEv +template identity<int(int, float, double)> f5(); + +// Mangling of non-type template argument expansions +template<int ...Values> int_tuple<Values...> f6() {} +// CHECK: define weak_odr void @_Z2f6IJLi1ELi2ELi3EEE9int_tupleIJXspT_EEEv +template int_tuple<1, 2, 3> f6(); + +// Mangling of template template argument expansions +template<template<typename> class ...Templates> +template_tuple<Templates...> f7() {} +// CHECK: define weak_odr void @_Z2f7IJ8identity13add_referenceEE14template_tupleIJDpT_EEv +template template_tuple<identity, add_reference> f7(); |