diff options
author | Fariborz Jahanian <fjahanian@apple.com> | 2009-12-09 23:35:29 +0000 |
---|---|---|
committer | Fariborz Jahanian <fjahanian@apple.com> | 2009-12-09 23:35:29 +0000 |
commit | 531c16f9fb040950ff068d8237e656bf12e3d070 (patch) | |
tree | 6f5110da14a53d0c51eaedc093ed4d481337f36a /clang/lib/CodeGen/CGExprScalar.cpp | |
parent | 25b20fc2ae8c08ee391b8b6a7f7856c2c275ead1 (diff) | |
download | bcm5719-llvm-531c16f9fb040950ff068d8237e656bf12e3d070.tar.gz bcm5719-llvm-531c16f9fb040950ff068d8237e656bf12e3d070.zip |
Code gen for ObjCIsaExpr AST used as lvalue.
(fixes radar 7457534).
llvm-svn: 90995
Diffstat (limited to 'clang/lib/CodeGen/CGExprScalar.cpp')
-rw-r--r-- | clang/lib/CodeGen/CGExprScalar.cpp | 36 |
1 files changed, 21 insertions, 15 deletions
diff --git a/clang/lib/CodeGen/CGExprScalar.cpp b/clang/lib/CodeGen/CGExprScalar.cpp index 9ac8b4d8b3c..1ce4c5aef4c 100644 --- a/clang/lib/CodeGen/CGExprScalar.cpp +++ b/clang/lib/CodeGen/CGExprScalar.cpp @@ -168,21 +168,8 @@ public: } Value *VisitObjCIsaExpr(ObjCIsaExpr *E) { - Value *V; - // object->isa or (*object).isa - // Generate code as for: *(Class*)object - Expr *BaseExpr = E->getBase(); - if (E->isArrow()) - V = EmitLoadOfLValue(BaseExpr); - else - V = EmitLValue(BaseExpr).getAddress(); - - // build Class* type - const llvm::Type *ClassPtrTy = ConvertType(E->getType()); - ClassPtrTy = ClassPtrTy->getPointerTo(); - V = Builder.CreateBitCast(V, ClassPtrTy); - LValue LV = LValue::MakeAddr(V, CGF.MakeQualifiers(E->getType())); - V = CGF.EmitLoadOfLValue(LV, E->getType()).getScalarVal(); + LValue LV = CGF.EmitObjCIsaExpr(E); + Value *V = CGF.EmitLoadOfLValue(LV, E->getType()).getScalarVal(); return V; } @@ -1997,3 +1984,22 @@ llvm::Value *CodeGenFunction::EmitVector(llvm::Value * const *Vals, return Vec; } + +LValue CodeGenFunction::EmitObjCIsaExpr(const ObjCIsaExpr *E) { + llvm::Value *V; + // object->isa or (*object).isa + // Generate code as for: *(Class*)object + Expr *BaseExpr = E->getBase(); + if (E->isArrow()) + V = ScalarExprEmitter(*this).EmitLoadOfLValue(BaseExpr); + else + V = EmitLValue(BaseExpr).getAddress(); + + // build Class* type + const llvm::Type *ClassPtrTy = ConvertType(E->getType()); + ClassPtrTy = ClassPtrTy->getPointerTo(); + V = Builder.CreateBitCast(V, ClassPtrTy); + LValue LV = LValue::MakeAddr(V, MakeQualifiers(E->getType())); + return LV; +} + |