]> granicus.if.org Git - clang/commitdiff
Test template instantiation of pack expansions where the parameter pack is in a neste...
authorDouglas Gregor <dgregor@apple.com>
Mon, 20 Dec 2010 22:46:22 +0000 (22:46 +0000)
committerDouglas Gregor <dgregor@apple.com>
Mon, 20 Dec 2010 22:46:22 +0000 (22:46 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@122282 91177308-0d34-0410-b5e6-96231b3b80d8

test/CXX/temp/temp.decls/temp.variadic/p4.cpp

index db4db7ddd26e58282808231329ff9e17abb574a6..b4f7c09981ff9d3c73f4c52c424653de333cd408 100644 (file)
@@ -1,15 +1,28 @@
 // RUN: %clang_cc1 -std=c++0x -fsyntax-only -verify %s
 
-template<typename... Types> struct Tuple;
+template<typename... Types> struct tuple;
 
 // FIXME: Many more bullets to go
 
 // In a template-argument-list (14.3); the pattern is a template-argument.
 template<typename ...Types>
 struct tuple_of_refs {
-  typedef Tuple<Types& ...> types;
+  typedef tuple<Types& ...> types;
 };
 
-Tuple<int&, float&> *t_int_ref_float_ref;
+tuple<int&, float&> *t_int_ref_float_ref;
 tuple_of_refs<int&, float&>::types *t_int_ref_float_ref_2 =  t_int_ref_float_ref;
 
+template<typename ...Types>
+struct extract_nested_types {
+  typedef tuple<typename Types::type...> types;
+};
+
+template<typename T>
+struct identity {
+  typedef T type;
+};
+
+tuple<int, float> *t_int_float;
+extract_nested_types<identity<int>, identity<float> >::types *t_int_float_2 
+  = t_int_float;