diff options
| author | Devang Patel <dpatel@apple.com> | 2007-10-26 18:15:21 +0000 |
|---|---|---|
| committer | Devang Patel <dpatel@apple.com> | 2007-10-26 18:15:21 +0000 |
| commit | 7718d7a2eba45a6dc322b54d09f1e00bb73f509f (patch) | |
| tree | 3ee84d4c2988f07dac3bac2f98f2babb99cfad65 /clang/CodeGen | |
| parent | ffdb07c9396ad9f8099231aa5cc826027349136d (diff) | |
| download | bcm5719-llvm-7718d7a2eba45a6dc322b54d09f1e00bb73f509f.tar.gz bcm5719-llvm-7718d7a2eba45a6dc322b54d09f1e00bb73f509f.zip | |
Handle non LValue base expressions.
llvm-svn: 43387
Diffstat (limited to 'clang/CodeGen')
| -rw-r--r-- | clang/CodeGen/CGExpr.cpp | 13 |
1 files changed, 5 insertions, 8 deletions
diff --git a/clang/CodeGen/CGExpr.cpp b/clang/CodeGen/CGExpr.cpp index b03caaa6666..1c8eda1f607 100644 --- a/clang/CodeGen/CGExpr.cpp +++ b/clang/CodeGen/CGExpr.cpp @@ -394,21 +394,18 @@ LValue CodeGenFunction::EmitMemberExpr(const MemberExpr *E) { } llvm::Value *BaseValue = NULL; - if (const CallExpr *CE = dyn_cast<CallExpr>(BaseExpr)) { - RValue Base = EmitCallExpr(CE); - BaseValue = Base.getScalarVal(); - } - else { + if (BaseExpr->isLvalue() == Expr::LV_Valid) { LValue BaseLV = EmitLValue(BaseExpr); BaseValue = BaseLV.getAddress(); - + if (E->isArrow()) { QualType PTy = cast<PointerType>(BaseExpr->getType())->getPointeeType(); BaseValue = Builder.CreateBitCast(BaseValue, - llvm::PointerType::get(ConvertType(PTy)), + llvm::PointerType::get(ConvertType(PTy)), "tmp"); } - } + } else + BaseValue = EmitScalarExpr(BaseExpr); FieldDecl *Field = E->getMemberDecl(); unsigned idx = CGM.getTypes().getLLVMFieldNo(Field); |

