diff options
| author | Anders Carlsson <andersca@mac.com> | 2009-04-24 05:23:13 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2009-04-24 05:23:13 +0000 |
| commit | 56c5bd8d236c51e1f103644f7fe6b0fe9b32664b (patch) | |
| tree | 7fdda9af23094dd6de2b11b0cb4c0070e8f69c02 /clang/lib | |
| parent | e500faf8c8a625080400538df04ccfae9225cb0a (diff) | |
| download | bcm5719-llvm-56c5bd8d236c51e1f103644f7fe6b0fe9b32664b.tar.gz bcm5719-llvm-56c5bd8d236c51e1f103644f7fe6b0fe9b32664b.zip | |
Add a VarDecl parameter to the CXXTemporaryObjectExpr constructor. It's unused for now, so no functionality change yet. Also, create CXXTempVarDecls to pass to the CXXTemporaryObjectExpr ctor.
llvm-svn: 69957
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/AST/ExprCXX.cpp | 3 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaExprCXX.cpp | 9 |
2 files changed, 9 insertions, 3 deletions
diff --git a/clang/lib/AST/ExprCXX.cpp b/clang/lib/AST/ExprCXX.cpp index e0a988bf669..01290d94722 100644 --- a/clang/lib/AST/ExprCXX.cpp +++ b/clang/lib/AST/ExprCXX.cpp @@ -231,7 +231,8 @@ const char *CXXNamedCastExpr::getCastName() const { } } -CXXTemporaryObjectExpr::CXXTemporaryObjectExpr(CXXConstructorDecl *Cons, +CXXTemporaryObjectExpr::CXXTemporaryObjectExpr(VarDecl *vd, + CXXConstructorDecl *Cons, QualType writtenTy, SourceLocation tyBeginLoc, Expr **Args, diff --git a/clang/lib/Sema/SemaExprCXX.cpp b/clang/lib/Sema/SemaExprCXX.cpp index d3a46dc1acb..753d1e47ba3 100644 --- a/clang/lib/Sema/SemaExprCXX.cpp +++ b/clang/lib/Sema/SemaExprCXX.cpp @@ -128,7 +128,10 @@ Sema::ActOnCXXTypeConstructExpr(SourceRange TypeRange, TypeTy *TypeRep, if (Ty->isDependentType() || CallExpr::hasAnyTypeDependentArguments(Exprs, NumExprs)) { exprs.release(); - return Owned(new (Context) CXXTemporaryObjectExpr(0, Ty, TyBeginLoc, + + // FIXME: Is this correct? + CXXTempVarDecl *Temp = CXXTempVarDecl::Create(Context, CurContext, Ty); + return Owned(new (Context) CXXTemporaryObjectExpr(Temp, 0, Ty, TyBeginLoc, Exprs, NumExprs, RParenLoc)); } @@ -163,8 +166,10 @@ Sema::ActOnCXXTypeConstructExpr(SourceRange TypeRange, TypeTy *TypeRep, if (!Constructor) return ExprError(); + CXXTempVarDecl *Temp = CXXTempVarDecl::Create(Context, CurContext, Ty); + exprs.release(); - return Owned(new (Context) CXXTemporaryObjectExpr(Constructor, Ty, + return Owned(new (Context) CXXTemporaryObjectExpr(Temp, Constructor, Ty, TyBeginLoc, Exprs, NumExprs, RParenLoc)); } |

