diff options
| author | Anders Carlsson <andersca@mac.com> | 2009-10-13 17:41:28 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2009-10-13 17:41:28 +0000 |
| commit | 6bfee8f3e33627880eb5dfdb566c51f71a741f0d (patch) | |
| tree | 203d51114c555cfaa68a4e16f15de9522c10f21a /clang/lib/CodeGen | |
| parent | faa0320f27a28110316dae6a92f8e03969b4fff7 (diff) | |
| download | bcm5719-llvm-6bfee8f3e33627880eb5dfdb566c51f71a741f0d.tar.gz bcm5719-llvm-6bfee8f3e33627880eb5dfdb566c51f71a741f0d.zip | |
Don't assume that the LHS and RHS of a member pointer expression is a DeclRefExpr. Fixes PR5177.
llvm-svn: 83986
Diffstat (limited to 'clang/lib/CodeGen')
| -rw-r--r-- | clang/lib/CodeGen/CGCXX.cpp | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/clang/lib/CodeGen/CGCXX.cpp b/clang/lib/CodeGen/CGCXX.cpp index ff56c8c85a2..3960cf51868 100644 --- a/clang/lib/CodeGen/CGCXX.cpp +++ b/clang/lib/CodeGen/CGCXX.cpp @@ -278,10 +278,11 @@ RValue CodeGenFunction::EmitCXXMemberCallExpr(const CXXMemberCallExpr *CE) { RValue CodeGenFunction::EmitCXXMemberPointerCallExpr(const CXXMemberCallExpr *E) { const BinaryOperator *BO = cast<BinaryOperator>(E->getCallee()); - const DeclRefExpr *BaseExpr = cast<DeclRefExpr>(BO->getLHS()); - const DeclRefExpr *MemFn = cast<DeclRefExpr>(BO->getRHS()); + const Expr *BaseExpr = BO->getLHS(); + const Expr *MemFnExpr = BO->getRHS(); - const MemberPointerType *MPT = MemFn->getType()->getAs<MemberPointerType>(); + const MemberPointerType *MPT = + MemFnExpr->getType()->getAs<MemberPointerType>(); const FunctionProtoType *FPT = MPT->getPointeeType()->getAs<FunctionProtoType>(); const CXXRecordDecl *RD = @@ -296,8 +297,8 @@ CodeGenFunction::EmitCXXMemberPointerCallExpr(const CXXMemberCallExpr *E) { // Get the member function pointer. llvm::Value *MemFnPtr = - CreateTempAlloca(ConvertType(MemFn->getType()), "mem.fn"); - EmitAggExpr(MemFn, MemFnPtr, /*VolatileDest=*/false); + CreateTempAlloca(ConvertType(MemFnExpr->getType()), "mem.fn"); + EmitAggExpr(MemFnExpr, MemFnPtr, /*VolatileDest=*/false); // Emit the 'this' pointer. llvm::Value *This; |

