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: don't warn about constant conditio...



details:   https://anonhg.NetBSD.org/src/rev/a0d2f230e31b
branches:  trunk
changeset: 980316:a0d2f230e31b
user:      rillig <rillig%NetBSD.org@localhost>
date:      Sun Jan 31 12:44:34 2021 +0000

description:
lint: don't warn about constant condition in 'do { } while (0)'

diffstat:

 tests/usr.bin/xlint/lint1/msg_161.c   |   6 +++---
 tests/usr.bin/xlint/lint1/msg_161.exp |   1 -
 usr.bin/xlint/lint1/cgram.y           |   8 ++++----
 usr.bin/xlint/lint1/externs1.h        |   4 ++--
 usr.bin/xlint/lint1/func.c            |  20 ++++++++++----------
 usr.bin/xlint/lint1/init.c            |   8 ++++----
 usr.bin/xlint/lint1/tree.c            |  10 ++++++----
 7 files changed, 29 insertions(+), 28 deletions(-)

diffs (250 lines):

diff -r d473fbce32d7 -r a0d2f230e31b tests/usr.bin/xlint/lint1/msg_161.c
--- a/tests/usr.bin/xlint/lint1/msg_161.c       Sun Jan 31 12:30:53 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_161.c       Sun Jan 31 12:44:34 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: msg_161.c,v 1.3 2021/01/31 12:30:53 rillig Exp $       */
+/*     $NetBSD: msg_161.c,v 1.4 2021/01/31 12:44:34 rillig Exp $       */
 # 3 "msg_161.c"
 
 // Test for message: constant in conditional context [161]
@@ -23,14 +23,14 @@
  * The pattern 'do { } while (0)' is a common technique to define a
  * preprocessor macro that behaves like a single statement.  There is
  * nothing unusual or surprising about the constant condition.
- * Still, lint warns about it. FIXME don't.
+ * Before tree.c 1.202 from 2021-01-31, lint warned about it.
  */
 void
 do_while_0(void)
 {
        do {
 
-       } while (0);            /* expect: 161 */
+       } while (0);
 }
 
 void
diff -r d473fbce32d7 -r a0d2f230e31b tests/usr.bin/xlint/lint1/msg_161.exp
--- a/tests/usr.bin/xlint/lint1/msg_161.exp     Sun Jan 31 12:30:53 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_161.exp     Sun Jan 31 12:44:34 2021 +0000
@@ -1,4 +1,3 @@
 msg_161.c(11): warning: constant in conditional context [161]
 msg_161.c(18): warning: constant in conditional context [161]
-msg_161.c(33): warning: constant in conditional context [161]
 msg_161.c(41): warning: constant in conditional context [161]
diff -r d473fbce32d7 -r a0d2f230e31b usr.bin/xlint/lint1/cgram.y
--- a/usr.bin/xlint/lint1/cgram.y       Sun Jan 31 12:30:53 2021 +0000
+++ b/usr.bin/xlint/lint1/cgram.y       Sun Jan 31 12:44:34 2021 +0000
@@ -1,5 +1,5 @@
 %{
-/* $NetBSD: cgram.y,v 1.159 2021/01/31 11:23:01 rillig Exp $ */
+/* $NetBSD: cgram.y,v 1.160 2021/01/31 12:44:34 rillig Exp $ */
 
 /*
  * Copyright (c) 1996 Christopher G. Demetriou.  All Rights Reserved.
@@ -35,7 +35,7 @@
 
 #include <sys/cdefs.h>
 #if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: cgram.y,v 1.159 2021/01/31 11:23:01 rillig Exp $");
+__RCSID("$NetBSD: cgram.y,v 1.160 2021/01/31 12:44:34 rillig Exp $");
 #endif
 
 #include <limits.h>
@@ -1557,7 +1557,7 @@
 
 expr_statement:
          expr T_SEMI {
-               expr($1, 0, 0, 0);
+               expr($1, false, false, false, false);
                ftflg = false;
          }
        | T_SEMI {
@@ -1576,7 +1576,7 @@
                if ($1->tn_op == NAME)
                        $1->tn_sym->s_used = true;
                $$ = $1;
-               expr($1, 0, 0, 0);
+               expr($1, false, false, false, false);
                ftflg = false;
          }
        | non_expr_statement {
diff -r d473fbce32d7 -r a0d2f230e31b usr.bin/xlint/lint1/externs1.h
--- a/usr.bin/xlint/lint1/externs1.h    Sun Jan 31 12:30:53 2021 +0000
+++ b/usr.bin/xlint/lint1/externs1.h    Sun Jan 31 12:44:34 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: externs1.h,v 1.64 2021/01/30 18:16:45 rillig Exp $     */
+/*     $NetBSD: externs1.h,v 1.65 2021/01/31 12:44:34 rillig Exp $     */
 
 /*
  * Copyright (c) 1994, 1995 Jochen Pohl
@@ -216,7 +216,7 @@
 extern tnode_t *new_function_argument_node(tnode_t *, tnode_t *);
 extern tnode_t *new_function_call_node(tnode_t *, tnode_t *);
 extern val_t   *constant(tnode_t *, bool);
-extern void    expr(tnode_t *, bool, bool, bool);
+extern void    expr(tnode_t *, bool, bool, bool, bool);
 extern void    check_expr_misc(const tnode_t *, bool, bool, bool,
                    bool, bool, bool);
 extern bool    constant_addr(tnode_t *, sym_t **, ptrdiff_t *);
diff -r d473fbce32d7 -r a0d2f230e31b usr.bin/xlint/lint1/func.c
--- a/usr.bin/xlint/lint1/func.c        Sun Jan 31 12:30:53 2021 +0000
+++ b/usr.bin/xlint/lint1/func.c        Sun Jan 31 12:44:34 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: func.c,v 1.66 2021/01/30 18:16:45 rillig Exp $ */
+/*     $NetBSD: func.c,v 1.67 2021/01/31 12:44:34 rillig Exp $ */
 
 /*
  * Copyright (c) 1994, 1995 Jochen Pohl
@@ -37,7 +37,7 @@
 
 #include <sys/cdefs.h>
 #if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: func.c,v 1.66 2021/01/30 18:16:45 rillig Exp $");
+__RCSID("$NetBSD: func.c,v 1.67 2021/01/31 12:44:34 rillig Exp $");
 #endif
 
 #include <stdlib.h>
@@ -569,7 +569,7 @@
        if (tn != NULL)
                tn = check_controlling_expression(tn);
        if (tn != NULL)
-               expr(tn, false, true, false);
+               expr(tn, false, true, false, false);
        pushctrl(T_IF);
 }
 
@@ -642,7 +642,7 @@
                tp->t_tspec = INT;
        }
 
-       expr(tn, true, false, true);
+       expr(tn, true, false, true, false);
 
        pushctrl(T_SWITCH);
        cstmt->c_switch = true;
@@ -726,7 +726,7 @@
        if (tn != NULL && tn->tn_op == CON)
                cstmt->c_infinite = is_nonzero(tn);
 
-       expr(tn, false, true, true);
+       expr(tn, false, true, true, false);
 }
 
 /*
@@ -789,7 +789,7 @@
                        error(323);
        }
 
-       expr(tn, false, true, true);
+       expr(tn, false, true, true, true);
 
        /*
         * The end of the loop is only reached if it is no endless loop
@@ -832,12 +832,12 @@
        cstmt->c_cfpos = csrc_pos;
 
        if (tn1 != NULL)
-               expr(tn1, false, false, true);
+               expr(tn1, false, false, true, false);
 
        if (tn2 != NULL)
                tn2 = check_controlling_expression(tn2);
        if (tn2 != NULL)
-               expr(tn2, false, true, true);
+               expr(tn2, false, true, true, false);
 
        cstmt->c_infinite =
            tn2 == NULL || (tn2->tn_op == CON && is_nonzero(tn2));
@@ -877,7 +877,7 @@
        }
 
        if (tn3 != NULL) {
-               expr(tn3, false, false, true);
+               expr(tn3, false, false, true, false);
        } else {
                tfreeblk();
        }
@@ -1013,7 +1013,7 @@
                        }
                }
 
-               expr(tn, true, false, true);
+               expr(tn, true, false, true, false);
 
        } else {
 
diff -r d473fbce32d7 -r a0d2f230e31b usr.bin/xlint/lint1/init.c
--- a/usr.bin/xlint/lint1/init.c        Sun Jan 31 12:30:53 2021 +0000
+++ b/usr.bin/xlint/lint1/init.c        Sun Jan 31 12:44:34 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: init.c,v 1.65 2021/01/30 18:16:45 rillig Exp $ */
+/*     $NetBSD: init.c,v 1.66 2021/01/31 12:44:34 rillig Exp $ */
 
 /*
  * Copyright (c) 1994, 1995 Jochen Pohl
@@ -37,7 +37,7 @@
 
 #include <sys/cdefs.h>
 #if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: init.c,v 1.65 2021/01/30 18:16:45 rillig Exp $");
+__RCSID("$NetBSD: init.c,v 1.66 2021/01/31 12:44:34 rillig Exp $");
 #endif
 
 #include <stdlib.h>
@@ -584,7 +584,7 @@
                ln->tn_type = tduptyp(ln->tn_type);
                ln->tn_type->t_const = false;
                tn = build(ASSIGN, ln, tn);
-               expr(tn, false, false, false);
+               expr(tn, false, false, false, false);
                return;
        }
 
@@ -628,7 +628,7 @@
         * expr() would free it.
         */
        tmem = tsave();
-       expr(tn, true, false, true);
+       expr(tn, true, false, true, false);
        trestor(tmem);
 
        if (is_integer(lt) && ln->tn_type->t_bitfield && !is_integer(rt)) {
diff -r d473fbce32d7 -r a0d2f230e31b usr.bin/xlint/lint1/tree.c
--- a/usr.bin/xlint/lint1/tree.c        Sun Jan 31 12:30:53 2021 +0000
+++ b/usr.bin/xlint/lint1/tree.c        Sun Jan 31 12:44:34 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: tree.c,v 1.201 2021/01/31 12:20:00 rillig Exp $        */
+/*     $NetBSD: tree.c,v 1.202 2021/01/31 12:44:34 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.201 2021/01/31 12:20:00 rillig Exp $");
+__RCSID("$NetBSD: tree.c,v 1.202 2021/01/31 12:44:34 rillig Exp $");
 #endif
 
 #include <float.h>
@@ -3730,7 +3730,7 @@
  * for the expression.
  */
 void
-expr(tnode_t *tn, bool vctx, bool tctx, bool dofreeblk)
+expr(tnode_t *tn, bool vctx, bool tctx, bool dofreeblk, bool constcond_zero_ok)
 {
 
        lint_assert(tn != NULL || nerr != 0);
@@ -3750,7 +3750,9 @@
                        /* assignment in conditional context */
                        warning(159);
        } else if (tn->tn_op == CON) {
-               if (hflag && tctx && !constcond_flag)
+               if (hflag && tctx && !constcond_flag &&
+                   !(constcond_zero_ok &&
+                     is_int_constant_zero(tn, tn->tn_type->t_tspec)))
                        /* constant in conditional context */
                        warning(161);
        }



Home | Main Index | Thread Index | Old Index