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 | |
parent | ffdb07c9396ad9f8099231aa5cc826027349136d (diff) | |
download | bcm5719-llvm-7718d7a2eba45a6dc322b54d09f1e00bb73f509f.tar.gz bcm5719-llvm-7718d7a2eba45a6dc322b54d09f1e00bb73f509f.zip |
Handle non LValue base expressions.
llvm-svn: 43387
-rw-r--r-- | clang/CodeGen/CGExpr.cpp | 13 | ||||
-rw-r--r-- | clang/test/CodeGen/struct.c | 4 |
2 files changed, 9 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); diff --git a/clang/test/CodeGen/struct.c b/clang/test/CodeGen/struct.c index 4e73cd47af0..443fc33ccb3 100644 --- a/clang/test/CodeGen/struct.c +++ b/clang/test/CodeGen/struct.c @@ -59,3 +59,7 @@ extern NB *f3(); void f4() { f3()->d1 = 42; } + +void f5() { + (f3())->d1 = 42; +} |