]> granicus.if.org Git - clang/commitdiff
Fix a crash in the diangostic code in EvalConstant. PR12043.
authorEli Friedman <eli.friedman@gmail.com>
Tue, 21 Feb 2012 22:41:33 +0000 (22:41 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Tue, 21 Feb 2012 22:41:33 +0000 (22:41 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@151100 91177308-0d34-0410-b5e6-96231b3b80d8

lib/AST/ExprConstant.cpp
test/Sema/const-eval.c

index 4ae5ab42ff79d0a043cd77e9341b28a8b4a01a60..5420876866d35dda1c0a6d55cde12b9673a6443f 100644 (file)
@@ -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);
     }
 
index 22ac67adad99fcf415c726a6d04a54272dfcb380..a9c8806b5d99b52f609ac794f15cdcddd0b263cb 100644 (file)
@@ -112,3 +112,8 @@ int castViaInt[*(int*)(unsigned long)"test"]; // expected-error {{variable lengt
 // PR11391.
 struct PR11391 { _Complex float f; } pr11391;
 EVAL_EXPR(42, __builtin_constant_p(pr11391.f = 1))
+
+// PR12043
+float varfloat;
+const float constfloat = 0;
+EVAL_EXPR(43, varfloat && constfloat) // expected-error {{must have a constant size}}