public inbox for gcc-bugs@sourceware.org
help / color / mirror / Atom feed
* [Bug c++/105534] New: -Wmaybe-uninitialized shouldn't suppress -Wuninitialized warnings
@ 2022-05-09 12:22 redbeard0531 at gmail dot com
  2022-05-09 13:05 ` [Bug c++/105534] -Wmaybe-uninitialized cases " rguenth at gcc dot gnu.org
                   ` (3 more replies)
  0 siblings, 4 replies; 5+ messages in thread
From: redbeard0531 at gmail dot com @ 2022-05-09 12:22 UTC (permalink / raw)
  To: gcc-bugs

https://gcc.gnu.org/bugzilla/show_bug.cgi?id=105534

            Bug ID: 105534
           Summary: -Wmaybe-uninitialized shouldn't suppress
                    -Wuninitialized warnings
           Product: gcc
           Version: unknown
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: c++
          Assignee: unassigned at gcc dot gnu.org
          Reporter: redbeard0531 at gmail dot com
  Target Milestone: ---

The following function emits a -Wuninitialized warning on ++count with -Wall
https://godbolt.org/z/KfaMEETY1:

int test(bool cond) {
    int count;
    ++count;
    return count;
}

Making the increment be conditional changes it to a -Wmaybe-uninitialized
warning, which is suppressed with -Wno-maybe-uninitialized.
https://godbolt.org/z/qarMrqW7E

int test(bool cond) {
    int count;
    if (cond) ++count;
    return count;
}

This makes no sense. count is never initialized on any path through the
function, and it is returned on all paths.

We use -Wall with -Wno-maybe-uninitialized on our codebase because we were
getting too many false-positives with -Wmaybe-initialized, in particular from
third-party headers that we didn't want to modify. At the time we decided to do
that, we didn't realize that we would also be missing out on clearly
uninitialized cases like this.

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

end of thread, other threads:[~2022-05-09 13:51 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-05-09 12:22 [Bug c++/105534] New: -Wmaybe-uninitialized shouldn't suppress -Wuninitialized warnings redbeard0531 at gmail dot com
2022-05-09 13:05 ` [Bug c++/105534] -Wmaybe-uninitialized cases " rguenth at gcc dot gnu.org
2022-05-09 13:21 ` rguenth at gcc dot gnu.org
2022-05-09 13:41 ` redbeard0531 at gmail dot com
2022-05-09 13:51 ` redbeard0531 at gmail dot com

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