summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-05-30 20:56:46 +0000
committerAnders Carlsson <andersca@mac.com>2009-05-30 20:56:46 +0000
commit4b2434da54633662efb8ce31dd6ea15d47bc190f (patch)
tree12a33afe9e009a25f8c0d78e44849a157c63a6c0 /clang/lib/Sema
parentb2288185549354d6faa57b6362d4c27a24914973 (diff)
downloadbcm5719-llvm-4b2434da54633662efb8ce31dd6ea15d47bc190f.tar.gz
bcm5719-llvm-4b2434da54633662efb8ce31dd6ea15d47bc190f.zip
Remove VarDecl from CXXConstructExpr.
llvm-svn: 72633
Diffstat (limited to 'clang/lib/Sema')
-rw-r--r--clang/lib/Sema/SemaDeclCXX.cpp2
-rw-r--r--clang/lib/Sema/SemaExprCXX.cpp5
-rw-r--r--clang/lib/Sema/SemaInit.cpp4
-rw-r--r--clang/lib/Sema/SemaTemplateInstantiateExpr.cpp10
4 files changed, 6 insertions, 15 deletions
diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp
index 67c6dc3fae4..f13179f0438 100644
--- a/clang/lib/Sema/SemaDeclCXX.cpp
+++ b/clang/lib/Sema/SemaDeclCXX.cpp
@@ -1800,7 +1800,7 @@ void Sema::InitializeVarWithConstructor(VarDecl *VD,
CXXConstructorDecl *Constructor,
QualType DeclInitType,
Expr **Exprs, unsigned NumExprs) {
- Expr *Temp = CXXConstructExpr::Create(Context, VD, DeclInitType, Constructor,
+ Expr *Temp = CXXConstructExpr::Create(Context, DeclInitType, Constructor,
false, Exprs, NumExprs);
VD->setInit(Context, Temp);
}
diff --git a/clang/lib/Sema/SemaExprCXX.cpp b/clang/lib/Sema/SemaExprCXX.cpp
index b6ccb99d6ba..e9b68d7a5e0 100644
--- a/clang/lib/Sema/SemaExprCXX.cpp
+++ b/clang/lib/Sema/SemaExprCXX.cpp
@@ -208,7 +208,7 @@ Sema::ActOnCXXTypeConstructExpr(SourceRange TypeRange, TypeTy *TypeRep,
exprs.release();
- Expr *E = new (Context) CXXTemporaryObjectExpr(Context, Temp, Constructor,
+ Expr *E = new (Context) CXXTemporaryObjectExpr(Context, Constructor,
Ty, TyBeginLoc, Exprs,
NumExprs, RParenLoc);
return MaybeBindToTemporary(E);
@@ -883,9 +883,8 @@ Sema::PerformImplicitConversion(Expr *&From, QualType ToType,
// FIXME: When can ToType be a reference type?
assert(!ToType->isReferenceType());
- CXXTempVarDecl *Temp = CXXTempVarDecl::Create(Context, CurContext, ToType);
// FIXME: Keep track of whether the copy constructor is elidable or not.
- From = CXXConstructExpr::Create(Context, Temp, ToType,
+ From = CXXConstructExpr::Create(Context, ToType,
SCS.CopyConstructor, false, &From, 1);
return false;
}
diff --git a/clang/lib/Sema/SemaInit.cpp b/clang/lib/Sema/SemaInit.cpp
index 20c712fa293..4976bd466fc 100644
--- a/clang/lib/Sema/SemaInit.cpp
+++ b/clang/lib/Sema/SemaInit.cpp
@@ -174,8 +174,8 @@ bool Sema::CheckInitializerTypes(Expr *&Init, QualType &DeclType,
if (!Constructor)
return true;
- Init = CXXConstructExpr::Create(Context, 0, DeclType, Constructor,
- false, &Init, 1);
+ Init = CXXConstructExpr::Create(Context, DeclType, Constructor, false,
+ &Init, 1);
return false;
}
diff --git a/clang/lib/Sema/SemaTemplateInstantiateExpr.cpp b/clang/lib/Sema/SemaTemplateInstantiateExpr.cpp
index c37bf2b2c43..a6b9703cee0 100644
--- a/clang/lib/Sema/SemaTemplateInstantiateExpr.cpp
+++ b/clang/lib/Sema/SemaTemplateInstantiateExpr.cpp
@@ -1007,15 +1007,7 @@ TemplateExprInstantiator::VisitCXXConstructExpr(CXXConstructExpr *E) {
Args.push_back(ArgInst.takeAs<Expr>());
}
-
- VarDecl *Var = cast_or_null<VarDecl>(SemaRef.InstantiateDecl(E->getVarDecl(),
- SemaRef.CurContext,
- TemplateArgs));
- if (!Var)
- return SemaRef.ExprError();
-
- SemaRef.CurrentInstantiationScope->InstantiatedLocal(E->getVarDecl(), Var);
- return SemaRef.Owned(CXXConstructExpr::Create(SemaRef.Context, Var, T,
+ return SemaRef.Owned(CXXConstructExpr::Create(SemaRef.Context, T,
E->getConstructor(),
E->isElidable(),
Args.takeAs<Expr>(),
OpenPOWER on IntegriCloud