public inbox for gcc@gcc.gnu.org
 help / color / mirror / Atom feed
* No warning about duplicate values in enum
@ 2023-03-10 12:57 Andrea Monaco
  2023-03-10 13:05 ` Marek Polacek
  0 siblings, 1 reply; 6+ messages in thread
From: Andrea Monaco @ 2023-03-10 12:57 UTC (permalink / raw)
  To: gcc


In gcc 8.3.0, compiling


enum
test
  {
    FIRST = 1,
    SECOND = 1,
    THIRD = 2
  };

int
main (void)
{
  return 0;
}


generates no warning even with -Wextra.  That hit me today, because I
had a large enum with many explicitly assigned constants and I
accidentally used the same value twice, which is an obvious source of
problems.



Andrea Monaco


^ permalink raw reply	[flat|nested] 6+ messages in thread
* No warning about duplicate values in enum
@ 2023-03-11 12:54 Basile Starynkevitch
  2023-03-11 16:48 ` Jonathan Wakely
  0 siblings, 1 reply; 6+ messages in thread
From: Basile Starynkevitch @ 2023-03-11 12:54 UTC (permalink / raw)
  To: Andrea Monaco; +Cc: gcc

Hello all,


Andrea observed that:

In gcc 8.3.0, compiling


enum
test
   {
     FIRST = 1,
     SECOND = 1,
     THIRD = 2
   };

int
main (void)
{
   return 0;
}


generates no warning even with -Wextra.

I believe that the C standard (which I don't have here, but see also https://port70.net/~nsz/c/c11/n1570.html or buy it from ISO) explicitly allow duplicate values in enum.

For readability of some weird code, or in the case of C code generated by other tools.

By the way, gcc version 12.2.0 (Debian 12.2.0-14) don't emit any warnings neither when used on your example as gcc -Wall -Wextra -fanalyzer /tmp/andrea.c -o /tmp/andrea

If you really want to get warnings, consider writing your GCC plugin (perhaps starting with https://github.com/bstarynk/bismon/ ....) or using static analysis tools like https://frama-c.com/

Regards.

NB my pet open source project is the RefPerSys open source inference engine (work in progress) on http://refpersys.org/

-- 
Basile Starynkevitch <basile@starynkevitch.net>
92340 Bourg-la-Reine, France
http://starynkevitch.net/Basile/ and http://refpersys.org/


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

end of thread, other threads:[~2023-03-13 13:38 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-03-10 12:57 No warning about duplicate values in enum Andrea Monaco
2023-03-10 13:05 ` Marek Polacek
2023-03-11 12:54 Basile Starynkevitch
2023-03-11 16:48 ` Jonathan Wakely
2023-03-13 13:29   ` Marek Polacek
2023-03-13 13:38     ` Basile Starynkevitch

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).