diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2011-10-26 06:49:26 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2011-10-26 06:49:26 +0000 |
commit | f1f6d85694fcf772f6d602fd9709318b08b96328 (patch) | |
tree | 8117476e6ff0e8d6ab0a411a02aec53789932353 /lib/Sema/TreeTransform.h | |
parent | 601d2ee8dd783503f9d556e1ed3b107abf196a1e (diff) |
Fix crash due to missing array-to-pointer decay when instantiating an unresolved
member expression. Refactoring to follow.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@143017 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/TreeTransform.h')
-rw-r--r-- | lib/Sema/TreeTransform.h | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/lib/Sema/TreeTransform.h b/lib/Sema/TreeTransform.h index 7fb2d35c70..6fb1315c2e 100644 --- a/lib/Sema/TreeTransform.h +++ b/lib/Sema/TreeTransform.h @@ -2145,11 +2145,17 @@ public: CXXScopeSpec SS; SS.Adopt(QualifierLoc); - if (BaseE && IsArrow) { - ExprResult BaseResult = getSema().DefaultLvalueConversion(BaseE); + if (BaseE) { + ExprResult BaseResult = getSema().DefaultFunctionArrayConversion(BaseE); if (BaseResult.isInvalid()) return ExprError(); + if (IsArrow) { + BaseResult = getSema().DefaultLvalueConversion(BaseResult.take()); + if (BaseResult.isInvalid()) + return ExprError(); + } BaseE = BaseResult.take(); + BaseType = BaseE->getType(); } return SemaRef.BuildMemberReferenceExpr(BaseE, BaseType, @@ -7701,7 +7707,6 @@ TreeTransform<Derived>::TransformUnresolvedMemberExpr(UnresolvedMemberExpr *Old) Base = getDerived().TransformExpr(Old->getBase()); if (Base.isInvalid()) return ExprError(); - BaseType = ((Expr*) Base.get())->getType(); } else { BaseType = getDerived().TransformType(Old->getBaseType()); } |