diff options
author | Fariborz Jahanian <fjahanian@apple.com> | 2010-05-11 16:31:10 +0000 |
---|---|---|
committer | Fariborz Jahanian <fjahanian@apple.com> | 2010-05-11 16:31:10 +0000 |
commit | 2d2623c710e2c98dcc63bbc260a6a15a9a598c52 (patch) | |
tree | b7ccad697bd43c1505d6e960ce16ee6fea206f72 | |
parent | 4df9d9ce118e994e095471861a509770e9ac7a0e (diff) | |
download | llvm-2d2623c710e2c98dcc63bbc260a6a15a9a598c52.zip llvm-2d2623c710e2c98dcc63bbc260a6a15a9a598c52.tar.gz llvm-2d2623c710e2c98dcc63bbc260a6a15a9a598c52.tar.bz2 |
Minor refactoring of my last patch.
llvm-svn: 103475
-rw-r--r-- | clang/lib/CodeGen/CGExpr.cpp | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/clang/lib/CodeGen/CGExpr.cpp b/clang/lib/CodeGen/CGExpr.cpp index 8b8b659..5379415 100644 --- a/clang/lib/CodeGen/CGExpr.cpp +++ b/clang/lib/CodeGen/CGExpr.cpp @@ -1672,11 +1672,12 @@ LValue CodeGenFunction::EmitCastLValue(const CastExpr *E) { case CastExpr::CK_NoOp: { LValue LV = EmitLValue(E->getSubExpr()); - // FIXME. assign a meaningfull cast kind. if (LV.isPropertyRef()) { - RValue RV = EmitLoadOfPropertyRefLValue(LV, E->getSubExpr()->getType()); - llvm::Value *V = RV.isScalar() ? RV.getScalarVal() : RV.getAggregateAddr(); - return LValue::MakeAddr(V, MakeQualifiers(E->getSubExpr()->getType())); + QualType QT = E->getSubExpr()->getType(); + RValue RV = EmitLoadOfPropertyRefLValue(LV, QT); + assert(!RV.isScalar() && "EmitCastLValue - scalar cast of property ref"); + llvm::Value *V = RV.getAggregateAddr(); + return LValue::MakeAddr(V, MakeQualifiers(QT)); } return LV; } |