forked from OSchip/llvm-project
[clang] fix regression deducing pack expansion arguments introduced by D110216
This test case had been missing when the original code
was introduced by 2fcb863b2b
.
Signed-off-by: Matheus Izvekov <mizvekov@gmail.com>
Differential Revision: https://reviews.llvm.org/D114207
This commit is contained in:
parent
0425ea4621
commit
85914b7570
|
@ -1337,6 +1337,13 @@ static Sema::TemplateDeductionResult DeduceTemplateArgumentsByTypeMatch(
|
|||
TemplateDeductionInfo &Info,
|
||||
SmallVectorImpl<DeducedTemplateArgument> &Deduced, unsigned TDF,
|
||||
bool PartialOrdering, bool DeducedFromArrayBound) {
|
||||
|
||||
// If the argument type is a pack expansion, look at its pattern.
|
||||
// This isn't explicitly called out
|
||||
if (const auto *AExp = dyn_cast<PackExpansionType>(A))
|
||||
A = AExp->getPattern();
|
||||
assert(!isa<PackExpansionType>(A.getCanonicalType()));
|
||||
|
||||
if (PartialOrdering) {
|
||||
// C++11 [temp.deduct.partial]p5:
|
||||
// Before the partial ordering is done, certain transformations are
|
||||
|
|
|
@ -1,5 +1,4 @@
|
|||
// RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify %s
|
||||
// expected-no-diagnostics
|
||||
|
||||
// Note: Partial ordering of function templates containing template
|
||||
// parameter packs is independent of the number of deduced arguments
|
||||
|
@ -26,3 +25,15 @@ void test_h() {
|
|||
double &dr1 = h((int(*)(int, float&))0);
|
||||
double &dr2 = h((int(*)(int))0);
|
||||
}
|
||||
|
||||
namespace test_j {
|
||||
|
||||
template <int I> struct ref {};
|
||||
|
||||
template <int... L> void map(ref<L>...);
|
||||
template <int head, int... tail> void map(ref<head> x, ref<tail>... xs); // expected-note {{here}}
|
||||
|
||||
template void map<0, 1>(ref<0>, ref<1>);
|
||||
// expected-error@-1 {{explicit instantiation of undefined function template 'map'}}
|
||||
|
||||
} // namespace test_j
|
||||
|
|
Loading…
Reference in New Issue