aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-04-24 05:23:13 +0000
committerAnders Carlsson <andersca@mac.com>2009-04-24 05:23:13 +0000
commit26de54983e7977fad615c94012f2f67d0d1cf404 (patch)
tree91f1a9d1d8edb9d8268a1a7b7b0060b575e5eea5
parent49d44018436761c0cfdda80d609b7dcdf8431064 (diff)
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.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@69957 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--include/clang/AST/ExprCXX.h3
-rw-r--r--lib/AST/ExprCXX.cpp3
-rw-r--r--lib/Sema/SemaExprCXX.cpp9
3 files changed, 11 insertions, 4 deletions
diff --git a/include/clang/AST/ExprCXX.h b/include/clang/AST/ExprCXX.h
index 9d3710a2a6..9c948f9f82 100644
--- a/include/clang/AST/ExprCXX.h
+++ b/include/clang/AST/ExprCXX.h
@@ -480,7 +480,8 @@ class CXXTemporaryObjectExpr : public Expr {
unsigned NumArgs;
public:
- CXXTemporaryObjectExpr(CXXConstructorDecl *Cons, QualType writtenTy,
+ CXXTemporaryObjectExpr(VarDecl *vd,
+ CXXConstructorDecl *Cons, QualType writtenTy,
SourceLocation tyBeginLoc, Expr **Args,
unsigned NumArgs, SourceLocation rParenLoc);
diff --git a/lib/AST/ExprCXX.cpp b/lib/AST/ExprCXX.cpp
index e0a988bf66..01290d9472 100644
--- a/lib/AST/ExprCXX.cpp
+++ b/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/lib/Sema/SemaExprCXX.cpp b/lib/Sema/SemaExprCXX.cpp
index d3a46dc1ac..753d1e47ba 100644
--- a/lib/Sema/SemaExprCXX.cpp
+++ b/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));
}