public inbox for gcc-bugs@sourceware.org
help / color / mirror / Atom feed
* [Bug c/64518] New: Warning about comparison between signed and unsigned can be useless in some cases
@ 2015-01-07  9:04 patrick.pelissier at gmail dot com
  0 siblings, 0 replies; only message in thread
From: patrick.pelissier at gmail dot com @ 2015-01-07  9:04 UTC (permalink / raw)
  To: gcc-bugs

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

            Bug ID: 64518
           Summary: Warning about comparison between signed and unsigned
                    can be useless in some cases
           Product: gcc
           Version: 4.9.1
            Status: UNCONFIRMED
          Severity: enhancement
          Priority: P3
         Component: c
          Assignee: unassigned at gcc dot gnu.org
          Reporter: patrick.pelissier at gmail dot com

For the following function:

int f(int x) { return ( x >= 0 && x < sizeof(int)); } 


I get the following warning with gcc -Wsign-compare -c f.c :
f.c: In function 'f':
f.c:1:37: warning: comparison between signed and unsigned integer expressions
[-Wsign-compare]
 int f(int x) { return ( x >= 0 && x < sizeof(int)); } 
                                     ^


However, as x has been checked as positive due to the first comparison, I don't
see how the comparison between x (signed) and sizeof(int) (unsigned) can be
wrong.

The proposed enhancement is to improve the warning to handle this case properly
without adding a (useless) cast in the user code like this:

int f(int x) { return ( x >= 0 && (unsigned int) x < sizeof(int)); }


^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2015-01-07  9:04 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-01-07  9:04 [Bug c/64518] New: Warning about comparison between signed and unsigned can be useless in some cases patrick.pelissier 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).