diagnostic.c (diagnostic_action_after_output): Remove max error handling here ....
authorNathan Sidwell <nathan@acm.org>
Fri, 14 Oct 2016 20:32:03 +0000 (20:32 +0000)
committerNathan Sidwell <nathan@gcc.gnu.org>
Fri, 14 Oct 2016 20:32:03 +0000 (20:32 +0000)
* diagnostic.c (diagnostic_action_after_output): Remove max error
handling here ....
(diagnostic_report_diagnostic): ... do it here instead.

testsuite/
* c-c++-common/fmax-errors.c: Make sure note is emitted.

From-SVN: r241186

gcc/ChangeLog
gcc/diagnostic.c
gcc/testsuite/ChangeLog
gcc/testsuite/c-c++-common/fmax-errors.c

index 2cf3f940d8824e761f88c0169b36105971aaf871..a131bba2909ca91777ed6f08f4bc86346766d93e 100644 (file)
@@ -1,3 +1,9 @@
+2016-10-14  Nathan Sidwell  <nathan@acm.org>
+
+       * diagnostic.c (diagnostic_action_after_output): Remove fatal
+       and max error handling here ....
+       (diagnostic_report_diagnostic): ... do it here instead.
+
 2016-10-14  David Malcolm  <dmalcolm@redhat.com>
 
        * print-rtl-function.c (print_edge): Omit "(flags)" when none are
index 2304e14c76185c2da0eab53db5f4a97e633a12d5..24aceec558ccec4d2f67659ee5000db1ad0ba591 100644 (file)
@@ -470,18 +470,8 @@ diagnostic_action_after_output (diagnostic_context *context,
          diagnostic_finish (context);
          exit (FATAL_EXIT_CODE);
        }
-      if (context->max_errors != 0
-         && ((unsigned) (diagnostic_kind_count (context, DK_ERROR)
-                         + diagnostic_kind_count (context, DK_SORRY)
-                         + diagnostic_kind_count (context, DK_WERROR))
-             >= context->max_errors))
-       {
-         fnotice (stderr,
-                  "compilation terminated due to -fmax-errors=%u.\n",
-                  context->max_errors);
-         diagnostic_finish (context);
-         exit (FATAL_EXIT_CODE);
-       }
+      /* -fmax-error handling is just before the next diagnostic is
+        emitted.  */
       break;
 
     case DK_ICE:
@@ -834,9 +824,7 @@ diagnostic_report_diagnostic (diagnostic_context *context,
      -Wno-error=*.  */
   if (context->warning_as_error_requested
       && diagnostic->kind == DK_WARNING)
-    {
-      diagnostic->kind = DK_ERROR;
-    }
+    diagnostic->kind = DK_ERROR;
 
   if (diagnostic->option_index
       && diagnostic->option_index != permissive_error_option (context))
@@ -892,6 +880,25 @@ diagnostic_report_diagnostic (diagnostic_context *context,
        return false;
     }
 
+  if (diagnostic->kind != DK_NOTE && context->max_errors)
+    {
+      /* Check, before emitting the diagnostic, whether we would
+        exceed the limit.  This way we will emit notes relevant to
+        the final emitted error.  */
+      int count = (diagnostic_kind_count (context, DK_ERROR)
+                  + diagnostic_kind_count (context, DK_SORRY)
+                  + diagnostic_kind_count (context, DK_WERROR));
+
+      if ((unsigned) count >= context->max_errors)
+       {
+         fnotice (stderr,
+                  "compilation terminated due to -fmax-errors=%u.\n",
+                  context->max_errors);
+         diagnostic_finish (context);
+         exit (FATAL_EXIT_CODE);
+       }
+    }
+
   context->lock++;
 
   if (diagnostic->kind == DK_ICE || diagnostic->kind == DK_ICE_NOBT)
index 849c6e49de6809cec913f47190c35c7023d7cb44..0e3b399ed4ab41b11cb4c3b4c5a891720d7b795a 100644 (file)
@@ -1,3 +1,7 @@
+2016-10-14  Nathan Sidwell  <nathan@acm.org>
+
+       * c-c++-common/fmax-errors.c: Add error with note.
+
 2016-10-14  Jakub Jelinek  <jakub@redhat.com>
 
        PR middle-end/77959
index 1ef78eb9eb8ff870bd0baf866a86340808f4df7a..b44e2386ae566360aa89fb1d7a569b28a3dd5c5b 100644 (file)
@@ -1,11 +1,21 @@
 /* PR c/44782 */
 /* { dg-do compile } */
-/* { dg-options "-fmax-errors=3" } */
+/* { dg-options "-fmax-errors=3 -Wall" } */
 
 void foo (unsigned int i, unsigned int j)
 {
   (i) ();                      /* { dg-error "" } */
   (j) ();                      /* { dg-error "" } */
-  (i+j) ();                    /* { dg-error "" } */
+
+  i + j; /* { dg-warning "" }  */
+
+  (k) ();                      /* { dg-error "" } */
+  /* Make sure we see the notes related to the final error we emit.  */
+  /* { dg-message "identifier" "" { target c } 12 } */
+
+  /* Warnings after the final error should not appear.  */
+  i + j; /* no warning.  */
+
   (i*j) ();                    /* no error here due to -fmax-errors */
+
 } /* { dg-prune-output "compilation terminated" } */