diff options
Diffstat (limited to 'clang/lib')
-rw-r--r-- | clang/lib/Sema/Sema.h | 2 | ||||
-rw-r--r-- | clang/lib/Sema/SemaDecl.cpp | 7 | ||||
-rw-r--r-- | clang/lib/Sema/SemaDeclCXX.cpp | 12 |
3 files changed, 14 insertions, 7 deletions
diff --git a/clang/lib/Sema/Sema.h b/clang/lib/Sema/Sema.h index a60c60c4e15..363f3ade790 100644 --- a/clang/lib/Sema/Sema.h +++ b/clang/lib/Sema/Sema.h @@ -1747,7 +1747,7 @@ public: /// InitializeVarWithConstructor - Creates an CXXConstructExpr /// and sets it as the initializer for the the passed in VarDecl. - void InitializeVarWithConstructor(VarDecl *VD, + bool InitializeVarWithConstructor(VarDecl *VD, CXXConstructorDecl *Constructor, QualType DeclInitType, Expr **Exprs, unsigned NumExprs); diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp index 6668aeaac55..99c1338fbae 100644 --- a/clang/lib/Sema/SemaDecl.cpp +++ b/clang/lib/Sema/SemaDecl.cpp @@ -3257,8 +3257,11 @@ void Sema::ActOnUninitializedDecl(DeclPtrTy dcl, if (!Constructor) Var->setInvalidDecl(); else { - if (!RD->hasTrivialConstructor() || !RD->hasTrivialDestructor()) - InitializeVarWithConstructor(Var, Constructor, InitType, 0, 0); + if (!RD->hasTrivialConstructor() || !RD->hasTrivialDestructor()) { + if (InitializeVarWithConstructor(Var, Constructor, InitType, 0, 0)) + Var->setInvalidDecl(); + } + FinalizeVarWithDestructor(Var, InitType); } } diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp index 17e88b3512e..f4b5a57ed53 100644 --- a/clang/lib/Sema/SemaDeclCXX.cpp +++ b/clang/lib/Sema/SemaDeclCXX.cpp @@ -2467,18 +2467,21 @@ Sema::BuildCXXConstructExpr(QualType DeclInitType, return Owned(Temp); } -void Sema::InitializeVarWithConstructor(VarDecl *VD, +bool Sema::InitializeVarWithConstructor(VarDecl *VD, CXXConstructorDecl *Constructor, QualType DeclInitType, Expr **Exprs, unsigned NumExprs) { OwningExprResult TempResult = BuildCXXConstructExpr(DeclInitType, Constructor, Exprs, NumExprs); - assert(!TempResult.isInvalid() && "FIXME: Error handling"); + if (TempResult.isInvalid()) + return true; Expr *Temp = TempResult.takeAs<Expr>(); MarkDeclarationReferenced(VD->getLocation(), Constructor); Temp = MaybeCreateCXXExprWithTemporaries(Temp, /*DestroyTemps=*/true); VD->setInit(Context, Temp); + + return false; } void Sema::FinalizeVarWithDestructor(VarDecl *VD, QualType DeclInitType) @@ -2555,8 +2558,9 @@ void Sema::AddCXXDirectInitializerToDecl(DeclPtrTy Dcl, RealDecl->setInvalidDecl(); else { VDecl->setCXXDirectInitializer(true); - InitializeVarWithConstructor(VDecl, Constructor, DeclInitType, - (Expr**)Exprs.release(), NumExprs); + if (InitializeVarWithConstructor(VDecl, Constructor, DeclInitType, + (Expr**)Exprs.release(), NumExprs)) + RealDecl->setInvalidDecl(); FinalizeVarWithDestructor(VDecl, DeclInitType); } return; |