diff options
| author | Nuno Lopes <nunoplopes@sapo.pt> | 2009-01-15 20:14:33 +0000 |
|---|---|---|
| committer | Nuno Lopes <nunoplopes@sapo.pt> | 2009-01-15 20:14:33 +0000 |
| commit | 7ffcf93b2450ca373cdf3147744a029e9b00e095 (patch) | |
| tree | ce91c73c92a5382f84a567256da4120dea382f72 /clang/lib/CodeGen | |
| parent | 4bbb79a642faf4e65622dcf72affee523de6c968 (diff) | |
| download | bcm5719-llvm-7ffcf93b2450ca373cdf3147744a029e9b00e095.tar.gz bcm5719-llvm-7ffcf93b2450ca373cdf3147744a029e9b00e095.zip | |
add codegen support to union casts
init of static vars still not working. I'll get back to it tomorrow or so
llvm-svn: 62278
Diffstat (limited to 'clang/lib/CodeGen')
| -rw-r--r-- | clang/lib/CodeGen/CGExprAgg.cpp | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/clang/lib/CodeGen/CGExprAgg.cpp b/clang/lib/CodeGen/CGExprAgg.cpp index 7571149b5a7..5e36751fb76 100644 --- a/clang/lib/CodeGen/CGExprAgg.cpp +++ b/clang/lib/CodeGen/CGExprAgg.cpp @@ -74,6 +74,7 @@ public: // Operators. // case Expr::UnaryOperatorClass: // case Expr::CastExprClass: + void VisitCStyleCastExpr(CStyleCastExpr *E); void VisitImplicitCastExpr(ImplicitCastExpr *E); void VisitCallExpr(const CallExpr *E); void VisitStmtExpr(const StmtExpr *E); @@ -127,6 +128,18 @@ void AggExprEmitter::EmitAggLoadOfLValue(const Expr *E) { // Visitor Methods //===----------------------------------------------------------------------===// +void AggExprEmitter::VisitCStyleCastExpr(CStyleCastExpr *E) { + // GCC union extension + if (E->getType()->isUnionType()) { + RecordDecl *SD = E->getType()->getAsRecordType()->getDecl(); + LValue FieldLoc = CGF.EmitLValueForField(DestPtr, *SD->field_begin(), true, 0); + EmitInitializationToLValue(E->getSubExpr(), FieldLoc); + return; + } + + Visit(E->getSubExpr()); +} + void AggExprEmitter::VisitImplicitCastExpr(ImplicitCastExpr *E) { assert(CGF.getContext().typesAreCompatible( E->getSubExpr()->getType().getUnqualifiedType(), @@ -467,7 +480,7 @@ void AggExprEmitter::VisitInitListExpr(InitListExpr *E) { // Unions only initialize one field. // (things can get weird with designators, but they aren't // supported yet.) - if (E->getType()->isUnionType()) + if (isUnion) break; } } |

