summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaInit.cpp
diff options
context:
space:
mode:
authorRichard Smith <richard-llvm@metafoo.co.uk>2013-05-23 23:20:04 +0000
committerRichard Smith <richard-llvm@metafoo.co.uk>2013-05-23 23:20:04 +0000
commitcd09065ec399e21132c00d4d5efb54fdf4481740 (patch)
treebf2ccc87e76de89cbbe7fa7a3da71385b83d27f8 /clang/lib/Sema/SemaInit.cpp
parent48143175160033fa388a7bf612a7aae86d9aeef7 (diff)
downloadbcm5719-llvm-cd09065ec399e21132c00d4d5efb54fdf4481740.tar.gz
bcm5719-llvm-cd09065ec399e21132c00d4d5efb54fdf4481740.zip
Fix crash-on-invalid if list-initialization works, but we bail out when
building the resulting expression because it invokes a deleted constructor. llvm-svn: 182624
Diffstat (limited to 'clang/lib/Sema/SemaInit.cpp')
-rw-r--r--clang/lib/Sema/SemaInit.cpp3
1 files changed, 2 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaInit.cpp b/clang/lib/Sema/SemaInit.cpp
index f7b53b2be21..fdb8777d41e 100644
--- a/clang/lib/Sema/SemaInit.cpp
+++ b/clang/lib/Sema/SemaInit.cpp
@@ -5745,7 +5745,8 @@ InitializationSequence::Perform(Sema &S,
ExprResult Res = S.PerformCopyInitialization(
Element, Init.get()->getExprLoc(), Init,
/*TopLevelOfInitList=*/ true);
- assert(!Res.isInvalid() && "Result changed since try phase.");
+ if (Res.isInvalid())
+ return ExprError();
Converted[i] = Res.take();
}
InitListExpr *Semantic = new (S.Context)
OpenPOWER on IntegriCloud