Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/xlint/lint1 lint: do not warn about comparison 'unsi...



details:   https://anonhg.NetBSD.org/src/rev/5c7dda5d6550
branches:  trunk
changeset: 985728:5c7dda5d6550
user:      rillig <rillig%NetBSD.org@localhost>
date:      Sun Sep 05 17:49:55 2021 +0000

description:
lint: do not warn about comparison 'unsigned <= 0'

Seen in scanners generated by Flex, and about 50 occurrences in the
NetBSD src and xsrc tree, all of which are not suspicious of being bugs.

diffstat:

 tests/usr.bin/xlint/lint1/msg_162.c   |  21 ++++++++++++++-------
 tests/usr.bin/xlint/lint1/msg_162.exp |  13 +++++--------
 usr.bin/xlint/lint1/Makefile          |   3 +--
 usr.bin/xlint/lint1/tree.c            |   8 ++++----
 4 files changed, 24 insertions(+), 21 deletions(-)

diffs (130 lines):

diff -r 8cd82904ff80 -r 5c7dda5d6550 tests/usr.bin/xlint/lint1/msg_162.c
--- a/tests/usr.bin/xlint/lint1/msg_162.c       Sun Sep 05 17:29:27 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_162.c       Sun Sep 05 17:49:55 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: msg_162.c,v 1.5 2021/09/05 16:47:24 rillig Exp $       */
+/*     $NetBSD: msg_162.c,v 1.6 2021/09/05 17:49:55 rillig Exp $       */
 # 3 "msg_162.c"
 
 // Test for message: comparison of %s with %s, op %s [162]
@@ -23,7 +23,7 @@
        if (ui >= 0) {
        }
 
-       /* expect+1: warning: comparison of unsigned int with 0, op <= [162] */
+       /* before 2021-09-05: comparison of unsigned int with 0, op <= [162] */
        if (ui <= 0) {
        }
 }
@@ -47,7 +47,7 @@
        if (0 <= ui) {
        }
 
-       /* expect+1: warning: comparison of 0 with unsigned int, op >= [162] */
+       /* before 2021-09-05: comparison of 0 with unsigned int, op >= [162] */
        if (0 >= ui) {
        }
 }
@@ -97,11 +97,18 @@
        /* expect+1: warning: comparison of unsigned int with negative constant, op <= [162] */
        take_bool(x <= -1);
        /*
-        * XXX: The expression 'x <= 0' is equivalent to 'x < 1', so lint
-        * should not warn about it, just as it doesn't warn about the
-        * inverted condition, which is 'x > 0'.
+        * Before tree.c 1.379 from 2021-09-05, lint warned about
+        * 'unsigned <= 0' as well as '0 >= unsigned'.  In all cases where
+        * the programmer knows whether the underlying data type is signed or
+        * unsigned, it is clearer to express the same thought as
+        * 'unsigned == 0', but that's a stylistic issue only.
+        *
+        * Removing this particular case of the warning is not expected to
+        * miss any bugs.  The expression 'x <= 0' is equivalent to 'x < 1',
+        * so lint should not warn about it, just as it doesn't warn about
+        * the inverted condition, which is 'x > 0'.
         */
-       /* expect+1: warning: comparison of unsigned int with 0, op <= [162] */
+       /* before 2021-09-05: comparison of unsigned int with 0, op <= [162] */
        take_bool(x <= 0);
        take_bool(x <= 1);
 
diff -r 8cd82904ff80 -r 5c7dda5d6550 tests/usr.bin/xlint/lint1/msg_162.exp
--- a/tests/usr.bin/xlint/lint1/msg_162.exp     Sun Sep 05 17:29:27 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_162.exp     Sun Sep 05 17:49:55 2021 +0000
@@ -1,18 +1,15 @@
 msg_162.c(15): warning: comparison of unsigned int with negative constant, op < [162]
 msg_162.c(19): warning: comparison of unsigned int with 0, op < [162]
 msg_162.c(23): warning: comparison of unsigned int with 0, op >= [162]
-msg_162.c(27): warning: comparison of unsigned int with 0, op <= [162]
 msg_162.c(39): warning: comparison of negative constant with unsigned int, op > [162]
 msg_162.c(43): warning: comparison of 0 with unsigned int, op > [162]
 msg_162.c(47): warning: comparison of 0 with unsigned int, op <= [162]
-msg_162.c(51): warning: comparison of 0 with unsigned int, op >= [162]
 msg_162.c(76): warning: comparison of unsigned char with negative constant, op == [162]
 msg_162.c(92): warning: comparison of unsigned int with negative constant, op < [162]
 msg_162.c(94): warning: comparison of unsigned int with 0, op < [162]
 msg_162.c(98): warning: comparison of unsigned int with negative constant, op <= [162]
-msg_162.c(105): warning: comparison of unsigned int with 0, op <= [162]
-msg_162.c(109): warning: comparison of unsigned int with negative constant, op > [162]
-msg_162.c(114): warning: comparison of unsigned int with negative constant, op >= [162]
-msg_162.c(116): warning: comparison of unsigned int with 0, op >= [162]
-msg_162.c(120): warning: comparison of unsigned int with negative constant, op == [162]
-msg_162.c(125): warning: comparison of unsigned int with negative constant, op != [162]
+msg_162.c(116): warning: comparison of unsigned int with negative constant, op > [162]
+msg_162.c(121): warning: comparison of unsigned int with negative constant, op >= [162]
+msg_162.c(123): warning: comparison of unsigned int with 0, op >= [162]
+msg_162.c(127): warning: comparison of unsigned int with negative constant, op == [162]
+msg_162.c(132): warning: comparison of unsigned int with negative constant, op != [162]
diff -r 8cd82904ff80 -r 5c7dda5d6550 usr.bin/xlint/lint1/Makefile
--- a/usr.bin/xlint/lint1/Makefile      Sun Sep 05 17:29:27 2021 +0000
+++ b/usr.bin/xlint/lint1/Makefile      Sun Sep 05 17:49:55 2021 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: Makefile,v 1.86 2021/09/05 16:36:56 rillig Exp $
+#      $NetBSD: Makefile,v 1.87 2021/09/05 17:49:55 rillig Exp $
 
 .include <bsd.own.mk>
 
@@ -20,7 +20,6 @@
 LOBJS.${PROG}+=                ${SRCS:M*.y:.y=.ln}
 LOBJS.${PROG}+=                ${SRCS:M*.l:.l=.ln}
 LINTFLAGS.scan.c+=     -X 107,126,330,331,332,333      # strict bool mode
-LINTFLAGS.scan.c+=     -X 162          # comparison of 'unsigned <= 0'
 LINTFLAGS.scan.c+=     -X 192,214      # due to suppressed bool errors
 LINTFLAGS.scan.c+=     -X 307          # static variable unused
 
diff -r 8cd82904ff80 -r 5c7dda5d6550 usr.bin/xlint/lint1/tree.c
--- a/usr.bin/xlint/lint1/tree.c        Sun Sep 05 17:29:27 2021 +0000
+++ b/usr.bin/xlint/lint1/tree.c        Sun Sep 05 17:49:55 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: tree.c,v 1.378 2021/09/05 16:03:55 rillig Exp $        */
+/*     $NetBSD: tree.c,v 1.379 2021/09/05 17:49:55 rillig Exp $        */
 
 /*
  * Copyright (c) 1994, 1995 Jochen Pohl
@@ -37,7 +37,7 @@
 
 #include <sys/cdefs.h>
 #if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: tree.c,v 1.378 2021/09/05 16:03:55 rillig Exp $");
+__RCSID("$NetBSD: tree.c,v 1.379 2021/09/05 17:49:55 rillig Exp $");
 #endif
 
 #include <float.h>
@@ -4232,7 +4232,7 @@
                        /* comparison of %s with %s, op %s */
                        warning(162, type_name(ln->tn_type),
                            "negative constant", op_name(op));
-               } else if (op == LT || op == GE || (hflag && op == LE)) {
+               } else if (op == LT || op == GE) {
                        /* comparison of %s with %s, op %s */
                        warning(162, type_name(ln->tn_type), "0", op_name(op));
                }
@@ -4244,7 +4244,7 @@
                        /* comparison of %s with %s, op %s */
                        warning(162, "negative constant",
                            type_name(rn->tn_type), op_name(op));
-               } else if (op == GT || op == LE || (hflag && op == GE)) {
+               } else if (op == GT || op == LE) {
                        /* comparison of %s with %s, op %s */
                        warning(162, "0", type_name(rn->tn_type), op_name(op));
                }



Home | Main Index | Thread Index | Old Index