diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-01-13 18:47:47 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-01-13 18:47:47 +0000 |
commit | c421f546e63b2f85caa1ca0d94d508f99bb871cb (patch) | |
tree | 59087bbe8a20604d7052f5b89445f1e78b8d7978 /test/CXX/temp/temp.decls/temp.variadic/parameter-matching.cpp | |
parent | dce73976163207916d5e6eb9529090ea7f70219e (diff) |
Only apply the parameter pack matching of C++0x [temp.arg.template]p3
when we're actually matching a template template argument to a
template template parameter. Otherwise, use strict matching.
Fixes <rdar://problem/8859985> clang++: variadics and out-of-line definitions.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@123385 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CXX/temp/temp.decls/temp.variadic/parameter-matching.cpp')
-rw-r--r-- | test/CXX/temp/temp.decls/temp.variadic/parameter-matching.cpp | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/test/CXX/temp/temp.decls/temp.variadic/parameter-matching.cpp b/test/CXX/temp/temp.decls/temp.variadic/parameter-matching.cpp index 3fc774cbfa..989ff9f6d9 100644 --- a/test/CXX/temp/temp.decls/temp.variadic/parameter-matching.cpp +++ b/test/CXX/temp/temp.decls/temp.variadic/parameter-matching.cpp @@ -25,3 +25,19 @@ template<int Values> struct X1nt; // expected-error{{non-type template parameter template<template<class T> class> class X1tt; // expected-note{{previous template template parameter declared here}} template<template<class T> class...> class X1tt; // expected-error{{template template parameter pack conflicts with previous template template parameter}} + +// Check for matching with out-of-line definitions +namespace rdar8859985 { + template<typename ...> struct tuple { }; + template<int ...> struct int_tuple { }; + + template<typename T> + struct X { + template<typename ...Args1, int ...Indices1> + X(tuple<Args1...>, int_tuple<Indices1...>); + }; + + template<typename T> + template<typename ...Args1, int ...Indices1> + X<T>::X(tuple<Args1...>, int_tuple<Indices1...>) {} +} |