From: Douglas Gregor Date: Tue, 11 Jan 2011 15:36:52 +0000 (+0000) Subject: Add example from C++0x [temp.deduct.type]p21, which already works X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2e996d929d2593e5131640e774d04fe433ba5f89;p=clang 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 --- 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