forked from OSchip/llvm-project
fix pr18645. Correct logic concerning 'T &&' deduction against lvalues.
llvm-svn: 225587
This commit is contained in:
parent
a0040df38c
commit
f9701c6e83
|
@ -3136,34 +3136,16 @@ static bool AdjustFunctionParmAndArgTypesForDeduction(Sema &S,
|
||||||
// are ignored for type deduction.
|
// are ignored for type deduction.
|
||||||
if (ParamType.hasQualifiers())
|
if (ParamType.hasQualifiers())
|
||||||
ParamType = ParamType.getUnqualifiedType();
|
ParamType = ParamType.getUnqualifiedType();
|
||||||
|
|
||||||
|
// [...] If P is a reference type, the type referred to by P is
|
||||||
|
// used for type deduction.
|
||||||
const ReferenceType *ParamRefType = ParamType->getAs<ReferenceType>();
|
const ReferenceType *ParamRefType = ParamType->getAs<ReferenceType>();
|
||||||
if (ParamRefType) {
|
if (ParamRefType)
|
||||||
QualType PointeeType = ParamRefType->getPointeeType();
|
ParamType = ParamRefType->getPointeeType();
|
||||||
|
|
||||||
// If the argument has incomplete array type, try to complete its type.
|
// Overload sets usually make this parameter an undeduced context,
|
||||||
if (ArgType->isIncompleteArrayType() && !S.RequireCompleteExprType(Arg, 0))
|
// but there are sometimes special circumstances. Typically
|
||||||
ArgType = Arg->getType();
|
// involving a template-id-expr.
|
||||||
|
|
||||||
// [C++0x] If P is an rvalue reference to a cv-unqualified
|
|
||||||
// template parameter and the argument is an lvalue, the type
|
|
||||||
// "lvalue reference to A" is used in place of A for type
|
|
||||||
// deduction.
|
|
||||||
if (isa<RValueReferenceType>(ParamType)) {
|
|
||||||
if (!PointeeType.getQualifiers() &&
|
|
||||||
isa<TemplateTypeParmType>(PointeeType) &&
|
|
||||||
Arg->Classify(S.Context).isLValue() &&
|
|
||||||
Arg->getType() != S.Context.OverloadTy &&
|
|
||||||
Arg->getType() != S.Context.BoundMemberTy)
|
|
||||||
ArgType = S.Context.getLValueReferenceType(ArgType);
|
|
||||||
}
|
|
||||||
|
|
||||||
// [...] If P is a reference type, the type referred to by P is used
|
|
||||||
// for type deduction.
|
|
||||||
ParamType = PointeeType;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Overload sets usually make this parameter an undeduced
|
|
||||||
// context, but there are sometimes special circumstances.
|
|
||||||
if (ArgType == S.Context.OverloadTy) {
|
if (ArgType == S.Context.OverloadTy) {
|
||||||
ArgType = ResolveOverloadForDeduction(S, TemplateParams,
|
ArgType = ResolveOverloadForDeduction(S, TemplateParams,
|
||||||
Arg, ParamType,
|
Arg, ParamType,
|
||||||
|
@ -3173,12 +3155,17 @@ static bool AdjustFunctionParmAndArgTypesForDeduction(Sema &S,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ParamRefType) {
|
if (ParamRefType) {
|
||||||
|
// If the argument has incomplete array type, try to complete its type.
|
||||||
|
if (ArgType->isIncompleteArrayType() && !S.RequireCompleteExprType(Arg, 0))
|
||||||
|
ArgType = Arg->getType();
|
||||||
|
|
||||||
// C++0x [temp.deduct.call]p3:
|
// C++0x [temp.deduct.call]p3:
|
||||||
// [...] If P is of the form T&&, where T is a template parameter, and
|
// If P is an rvalue reference to a cv-unqualified template
|
||||||
// the argument is an lvalue, the type A& is used in place of A for
|
// parameter and the argument is an lvalue, the type "lvalue
|
||||||
// type deduction.
|
// reference to A" is used in place of A for type deduction.
|
||||||
if (ParamRefType->isRValueReferenceType() &&
|
if (ParamRefType->isRValueReferenceType() &&
|
||||||
ParamRefType->getAs<TemplateTypeParmType>() &&
|
!ParamType.getQualifiers() &&
|
||||||
|
isa<TemplateTypeParmType>(ParamType) &&
|
||||||
Arg->isLValue())
|
Arg->isLValue())
|
||||||
ArgType = S.Context.getLValueReferenceType(ArgType);
|
ArgType = S.Context.getLValueReferenceType(ArgType);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -202,3 +202,8 @@ namespace PR19372 {
|
||||||
using T = S<int, int>;
|
using T = S<int, int>;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
namespace PR18645 {
|
||||||
|
template<typename F> F Quux(F &&f);
|
||||||
|
auto Baz = Quux(Quux<float>);
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue