diff options
author | Douglas Gregor <dgregor@apple.com> | 2010-04-27 18:19:34 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2010-04-27 18:19:34 +0000 |
commit | c96be1ea33cdf63d07cec48d18fe8e3afea48f8d (patch) | |
tree | 22f6b578421421f9afcdadacabdd272bff442dea /lib/Sema/TreeTransform.h | |
parent | b170ca5f4a8397c10e52050ff5df6885a3e6eca9 (diff) |
During template instantiation, set the naming class of
UnresolvedLookupExpr and UnresolvedMemberExpr by substituting the
naming class we computed when building the expression in the
template...
... which we didn't always do correctly. Teach
UnresolvedMemberExpr::getNamingClass() all about the new
representation of injected-class-names in templates, so that it can
return a naming class that is the current instantiation.
Also, when decomposing a template-id into its template name and its
arguments, be sure to set the naming class on the LookupResult
structure.
Fixes PR6947 the right way.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@102448 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/TreeTransform.h')
-rw-r--r-- | lib/Sema/TreeTransform.h | 37 |
1 files changed, 10 insertions, 27 deletions
diff --git a/lib/Sema/TreeTransform.h b/lib/Sema/TreeTransform.h index 2f36807659..cca14caa44 100644 --- a/lib/Sema/TreeTransform.h +++ b/lib/Sema/TreeTransform.h @@ -5336,19 +5336,16 @@ TreeTransform<Derived>::TransformUnresolvedLookupExpr( SS.setScopeRep(Qualifier); SS.setRange(Old->getQualifierRange()); - - // If this nested-name-specifier refers to a class type, that is the - // naming class. - if (const Type *NamedType = Qualifier->getAsType()) - if (const RecordType *NamedRecord = NamedType->getAs<RecordType>()) - R.setNamingClass(cast<CXXRecordDecl>(NamedRecord->getDecl())); - } else if (Old->getNamingClass()) { + } + + if (Old->getNamingClass()) { CXXRecordDecl *NamingClass = cast_or_null<CXXRecordDecl>(getDerived().TransformDecl( Old->getNameLoc(), Old->getNamingClass())); if (!NamingClass) return SemaRef.ExprError(); + R.setNamingClass(NamingClass); } @@ -5735,7 +5732,6 @@ TreeTransform<Derived>::TransformUnresolvedMemberExpr(UnresolvedMemberExpr *Old) BaseType = getDerived().TransformType(Old->getBaseType()); } - CXXRecordDecl *NamingClass = 0; NestedNameSpecifier *Qualifier = 0; if (Old->getQualifier()) { Qualifier @@ -5743,12 +5739,6 @@ TreeTransform<Derived>::TransformUnresolvedMemberExpr(UnresolvedMemberExpr *Old) Old->getQualifierRange()); if (Qualifier == 0) return SemaRef.ExprError(); - - // If this nested-name-specifier refers to a class type, that is the - // naming class. - if (const Type *NamedType = Qualifier->getAsType()) - if (const RecordType *NamedRecord = NamedType->getAs<RecordType>()) - NamingClass = cast<CXXRecordDecl>(NamedRecord->getDecl()); } LookupResult R(SemaRef, Old->getMemberName(), Old->getMemberLoc(), @@ -5783,24 +5773,17 @@ TreeTransform<Derived>::TransformUnresolvedMemberExpr(UnresolvedMemberExpr *Old) R.resolveKind(); - // Determine the naming class, if we haven't already. - if (!NamingClass) { - QualType T = BaseType; - if (const PointerType *PointerTy = T->getAs<PointerType>()) - T = PointerTy->getPointeeType(); - if (const RecordType *NamedRecord = T->getAs<RecordType>()) - NamingClass = cast<CXXRecordDecl>(NamedRecord->getDecl()); - } - - if (!NamingClass && Old->getNamingClass()) { - NamingClass = cast_or_null<CXXRecordDecl>(getDerived().TransformDecl( + // Determine the naming class. + if (!Old->getNamingClass()) { + CXXRecordDecl *NamingClass + = cast_or_null<CXXRecordDecl>(getDerived().TransformDecl( Old->getMemberLoc(), Old->getNamingClass())); if (!NamingClass) return SemaRef.ExprError(); - } - if (NamingClass) + R.setNamingClass(NamingClass); + } TemplateArgumentListInfo TransArgs; if (Old->hasExplicitTemplateArgs()) { |