From 2e996d929d2593e5131640e774d04fe433ba5f89 Mon Sep 17 00:00:00 2001 From: Douglas Gregor Date: Tue, 11 Jan 2011 15:36:52 +0000 Subject: [PATCH] Add example from C++0x [temp.deduct.type]p21, which already works git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@123237 91177308-0d34-0410-b5e6-96231b3b80d8 --- .../temp.deduct/temp.deduct.type/p21.cpp | 31 +++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 test/CXX/temp/temp.fct.spec/temp.deduct/temp.deduct.type/p21.cpp diff --git a/test/CXX/temp/temp.fct.spec/temp.deduct/temp.deduct.type/p21.cpp b/test/CXX/temp/temp.fct.spec/temp.deduct/temp.deduct.type/p21.cpp new file mode 100644 index 0000000000..247b98113a --- /dev/null +++ b/test/CXX/temp/temp.fct.spec/temp.deduct/temp.deduct.type/p21.cpp @@ -0,0 +1,31 @@ +// RUN: %clang_cc1 -std=c++0x -fsyntax-only -verify %s + +// Note: Template argument deduction involving parameter packs +// (14.5.3) can deduce zero or more arguments for each parameter pack. + +template struct X { + static const unsigned value = 0; +}; + +template struct X { + static const unsigned value = 1; +}; + +template struct Y { + static const unsigned value = 0; +}; + +template struct Y { + static const unsigned value = 1; +}; + +template int f(void (*)(Types ...)); +void g(int, float); + +int check0[X::value == 0? 1 : -1]; // uses primary template +int check1[X::value == 1? 1 : -1]; // uses partial specialization +int check2[X::value == 0? 1 : -1]; // uses primary template +int check3[Y<>::value == 0? 1 : -1]; // uses primary template +int check4[Y::value == 1? 1 : -1]; // uses partial specialization +int check5[Y::value == 0? 1 : -1]; // uses primary template +int fv = f(g); // okay -- 2.50.1