On Nov 6, 2011, at 1:58 PM, Alexander Best wrote:

> On Sun Nov  6 11, Dimitry Andric wrote:
>> On 2011-11-06 21:33, Alexander Best wrote:
>> ... 
>>> the problem is, something like
>>> 
>>> uint x;
>>> 
>>> if (x < 0) ...
>>> 
>>> clang will warn about this, yet it is 100% valid code so my vote would be to
>>> make such an error into a warning.
>> 
>> Sorry, but checking something unsigned to be smaller than zero is bogus,
>> or at the least superfluous, and it's perfectly sane to warn about this,
>> especially since the compiler is not going to emit code for it at all.
> 
> there was a discussion with the topic
> "disable -Wtautological-compare for clang" on freebsd-toolchain@ and most of
> the devs considered this code *not* to be bogus. ;)

The code actually is bogus.  It may be masking a real problem, because often 
times it is a "sanity check" to make sure that you aren't doing something 
naughty, like passing -1 for the length.  However, if you then pass the 
unsigned through a signed value, it suddenly becomes negative, and you have a 
hard to spot bug.  IIR the the tread, there weren't too many people offering an 
opinion...

Warner_______________________________________________
freebsd-toolchain@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-toolchain
To unsubscribe, send any mail to "freebsd-toolchain-unsubscr...@freebsd.org"

Reply via email to