diff options
author | Anders Carlsson <andersca@mac.com> | 2009-05-30 23:23:33 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-05-30 23:23:33 +0000 |
commit | b58d017f2b9eeed33f2ab3ede968b89cf5296bf2 (patch) | |
tree | 7001b9fe49bc4197b0c286af6546b9749e384e23 /lib/CodeGen/CGExprAgg.cpp | |
parent | 75bbb97f6e413633f2537e42f90547ccac559fde (diff) |
More temporary support.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@72648 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGExprAgg.cpp')
-rw-r--r-- | lib/CodeGen/CGExprAgg.cpp | 29 |
1 files changed, 25 insertions, 4 deletions
diff --git a/lib/CodeGen/CGExprAgg.cpp b/lib/CodeGen/CGExprAgg.cpp index cfb67ade79..343163ff2c 100644 --- a/lib/CodeGen/CGExprAgg.cpp +++ b/lib/CodeGen/CGExprAgg.cpp @@ -105,6 +105,7 @@ public: void VisitCXXDefaultArgExpr(CXXDefaultArgExpr *DAE) { Visit(DAE->getExpr()); } + void VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *E); void VisitCXXConstructExpr(const CXXConstructExpr *E); void VisitCXXExprWithTemporaries(CXXExprWithTemporaries *E); @@ -290,16 +291,36 @@ void AggExprEmitter::VisitVAArgExpr(VAArgExpr *VE) { EmitFinalDestCopy(VE, LValue::MakeAddr(ArgPtr, 0)); } +void AggExprEmitter::VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *E) { + llvm::Value *Val = DestPtr; + + if (!Val) { + // Create a temporary variable. + Val = CGF.CreateTempAlloca(CGF.ConvertTypeForMem(E->getType()), "tmp"); + + // FIXME: volatile + CGF.EmitAggExpr(E->getSubExpr(), Val, false); + } else + Visit(E->getSubExpr()); + + // FIXME: Record the value and dest ptr. + Val->dump(); +} + void AggExprEmitter::VisitCXXConstructExpr(const CXXConstructExpr *E) { - assert(DestPtr && "Must have somewhere to emit into!"); + llvm::Value *Val = DestPtr; + + if (!Val) { + // Create a temporary variable. + Val = CGF.CreateTempAlloca(CGF.ConvertTypeForMem(E->getType()), "tmp"); + } - CGF.EmitCXXConstructExpr(DestPtr, E); + CGF.EmitCXXConstructExpr(Val, E); } void AggExprEmitter::VisitCXXExprWithTemporaries(CXXExprWithTemporaries *E) { - // FIXME: Do something with the temporaries! - Visit(E->getSubExpr()); + CGF.EmitCXXExprWithTemporaries(E, DestPtr, VolatileDest); } void AggExprEmitter::EmitInitializationToLValue(Expr* E, LValue LV) { |