public inbox for gcc-patches@gcc.gnu.org
 help / color / mirror / Atom feed
* [C PATCH]  _Generic should not warn in non-active branches [PR68193,PR97100]
@ 2023-08-04  6:04 Martin Uecker
  2023-08-04 16:42 ` Joseph Myers
  0 siblings, 1 reply; 2+ messages in thread
From: Martin Uecker @ 2023-08-04  6:04 UTC (permalink / raw)
  To: gcc-patches; +Cc: Joseph Myers



Here is a patch to reduce false positives in _Generic.

Bootstrapped and regression tested on x86_64-linux.

Martin

    c: _Generic should not warn in non-active branches [PR68193,PR97100]
    
    To avoid false diagnostics, use c_inhibit_evaluation_warnings when
    a generic association is known to match during parsing.  We may still
    generate false positives if the default branch comes earler than
    a specific association that matches.
    
    PR c/68193
    PR c/97100
    
    gcc/c/:
            * c-parser.cc (c_parser_generic_selection): Inhibit evaluation
            warnings branches that are known not be taken during parsing.
    
    gcc/testsuite/ChangeLog:
            * gcc.dg/pr68193.c: New test.


diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
index 24a6eb6e459..d1863b301e0 100644
--- a/gcc/c/c-parser.cc
+++ b/gcc/c/c-parser.cc
@@ -9350,7 +9350,17 @@ c_parser_generic_selection (c_parser *parser)
 	  return error_expr;
 	}
 
+      bool match = assoc.type == NULL_TREE
+		   || comptypes (assoc.type, selector_type);
+
+      if (!match)
+	c_inhibit_evaluation_warnings++;
+
       assoc.expression = c_parser_expr_no_commas (parser, NULL);
+
+      if (!match)
+	  c_inhibit_evaluation_warnings--;
+
       if (assoc.expression.value == error_mark_node)
 	{
 	  c_parser_skip_until_found (parser, CPP_CLOSE_PAREN, NULL);
@@ -9387,7 +9397,7 @@ c_parser_generic_selection (c_parser *parser)
 	      match_found = associations.length ();
 	    }
 	}
-      else if (comptypes (assoc.type, selector_type))
+      else if (match)
 	{
 	  if (match_found < 0 || matched_assoc.type == NULL_TREE)
 	    {
diff --git a/gcc/testsuite/gcc.dg/pr68193.c b/gcc/testsuite/gcc.dg/pr68193.c
new file mode 100644
index 00000000000..2267593e363
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr68193.c
@@ -0,0 +1,15 @@
+/*  pr69193 */
+/* { dg-do compile } */
+/* { dg-options "-Wall" } */
+
+int
+main (void)
+{
+  int i = 0;
+  int j = _Generic (i,
+		    int: 0,
+		    long int: (i = (long int) 9223372036854775808UL));
+  return i + j;
+}
+
+



^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [C PATCH]  _Generic should not warn in non-active branches [PR68193,PR97100]
  2023-08-04  6:04 [C PATCH] _Generic should not warn in non-active branches [PR68193,PR97100] Martin Uecker
@ 2023-08-04 16:42 ` Joseph Myers
  0 siblings, 0 replies; 2+ messages in thread
From: Joseph Myers @ 2023-08-04 16:42 UTC (permalink / raw)
  To: Martin Uecker; +Cc: gcc-patches

On Fri, 4 Aug 2023, Martin Uecker via Gcc-patches wrote:

> Here is a patch to reduce false positives in _Generic.
> 
> Bootstrapped and regression tested on x86_64-linux.
> 
> Martin
> 
>     c: _Generic should not warn in non-active branches [PR68193,PR97100]
>     
>     To avoid false diagnostics, use c_inhibit_evaluation_warnings when
>     a generic association is known to match during parsing.  We may still
>     generate false positives if the default branch comes earler than
>     a specific association that matches.
>     
>     PR c/68193
>     PR c/97100
>     
>     gcc/c/:
>             * c-parser.cc (c_parser_generic_selection): Inhibit evaluation
>             warnings branches that are known not be taken during parsing.
>     
>     gcc/testsuite/ChangeLog:
>             * gcc.dg/pr68193.c: New test.

OK.

-- 
Joseph S. Myers
joseph@codesourcery.com

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2023-08-04 16:42 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-08-04  6:04 [C PATCH] _Generic should not warn in non-active branches [PR68193,PR97100] Martin Uecker
2023-08-04 16:42 ` Joseph Myers

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).