aboutsummaryrefslogtreecommitdiff
path: root/lib/AST/ExprConstant.cpp
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2012-02-21 22:41:33 +0000
committerEli Friedman <eli.friedman@gmail.com>2012-02-21 22:41:33 +0000
commit51e47df5a57430f1b691b04258e663cce68aef9d (patch)
tree9a406576e50e18aff9b96303e5960c9ca6e53112 /lib/AST/ExprConstant.cpp
parent2789d8e753a9bdd36f2f90ba03ba4fb7521bcbb1 (diff)
Fix a crash in the diangostic code in EvalConstant. PR12043.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@151100 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/AST/ExprConstant.cpp')
-rw-r--r--lib/AST/ExprConstant.cpp4
1 files changed, 3 insertions, 1 deletions
diff --git a/lib/AST/ExprConstant.cpp b/lib/AST/ExprConstant.cpp
index 4ae5ab42ff..5420876866 100644
--- a/lib/AST/ExprConstant.cpp
+++ b/lib/AST/ExprConstant.cpp
@@ -538,8 +538,10 @@ namespace {
= diag::note_invalid_subexpr_in_const_expr,
unsigned ExtraNotes = 0) {
// Don't override a previous diagnostic.
- if (!EvalStatus.Diag || !EvalStatus.Diag->empty())
+ if (!EvalStatus.Diag || !EvalStatus.Diag->empty()) {
+ HasActiveDiagnostic = false;
return OptionalDiagnostic();
+ }
return Diag(Loc, DiagId, ExtraNotes);
}