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: fix reachability for constant cont...
details: https://anonhg.NetBSD.org/src/rev/36f4edf15d81
branches: trunk
changeset: 981808:36f4edf15d81
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Mar 21 15:34:13 2021 +0000
description:
lint: fix reachability for constant controlling expression in for loop
diffstat:
tests/usr.bin/xlint/lint1/msg_193.c | 4 ++--
tests/usr.bin/xlint/lint1/msg_193.exp | 1 +
usr.bin/xlint/lint1/func.c | 9 ++++-----
usr.bin/xlint/lint1/lint1.h | 14 +++++++++++++-
4 files changed, 20 insertions(+), 8 deletions(-)
diffs (87 lines):
diff -r 4f28112f5146 -r 36f4edf15d81 tests/usr.bin/xlint/lint1/msg_193.c
--- a/tests/usr.bin/xlint/lint1/msg_193.c Sun Mar 21 15:24:55 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_193.c Sun Mar 21 15:34:13 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: msg_193.c,v 1.5 2021/03/21 15:24:56 rillig Exp $ */
+/* $NetBSD: msg_193.c,v 1.6 2021/03/21 15:34:13 rillig Exp $ */
# 3 "msg_193.c"
// Test for message: statement not reached [193]
@@ -173,7 +173,7 @@
test_for_false(void)
{
for (; 0;)
- unreachable(); /* TODO: expect: 193 */
+ unreachable(); /* expect: 193 */
reachable();
}
diff -r 4f28112f5146 -r 36f4edf15d81 tests/usr.bin/xlint/lint1/msg_193.exp
--- a/tests/usr.bin/xlint/lint1/msg_193.exp Sun Mar 21 15:24:55 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_193.exp Sun Mar 21 15:34:13 2021 +0000
@@ -14,6 +14,7 @@
msg_193.c(152): warning: statement not reached [193]
msg_193.c(161): warning: statement not reached [193]
msg_193.c(169): warning: statement not reached [193]
+msg_193.c(176): warning: statement not reached [193]
msg_193.c(186): warning: statement not reached [193]
msg_193.c(197): warning: statement not reached [193]
msg_193.c(199): warning: statement not reached [193]
diff -r 4f28112f5146 -r 36f4edf15d81 usr.bin/xlint/lint1/func.c
--- a/usr.bin/xlint/lint1/func.c Sun Mar 21 15:24:55 2021 +0000
+++ b/usr.bin/xlint/lint1/func.c Sun Mar 21 15:34:13 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: func.c,v 1.90 2021/03/21 15:24:55 rillig Exp $ */
+/* $NetBSD: func.c,v 1.91 2021/03/21 15:34:13 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.90 2021/03/21 15:24:55 rillig Exp $");
+__RCSID("$NetBSD: func.c,v 1.91 2021/03/21 15:34:13 rillig Exp $");
#endif
#include <stdlib.h>
@@ -883,12 +883,11 @@
if (tn2 != NULL)
expr(tn2, false, true, true, false);
- cstmt->c_maybe_endless =
- tn2 == NULL || (tn2->tn_op == CON && constant_is_nonzero(tn2));
+ cstmt->c_maybe_endless = tn2 == NULL || is_nonzero(tn2);
/* Checking the reinitialization expression is done in for2() */
- reached = true;
+ reached = !is_zero(tn2);
}
/*
diff -r 4f28112f5146 -r 36f4edf15d81 usr.bin/xlint/lint1/lint1.h
--- a/usr.bin/xlint/lint1/lint1.h Sun Mar 21 15:24:55 2021 +0000
+++ b/usr.bin/xlint/lint1/lint1.h Sun Mar 21 15:34:13 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lint1.h,v 1.86 2021/03/21 14:36:59 rillig Exp $ */
+/* $NetBSD: lint1.h,v 1.87 2021/03/21 15:34:13 rillig Exp $ */
/*
* Copyright (c) 1996 Christopher G. Demetriou. All Rights Reserved.
@@ -483,3 +483,15 @@
lint_assert(tn->tn_type->t_tspec == tn->tn_val->v_tspec);
return is_nonzero_val(tn->tn_val);
}
+
+static inline bool
+is_zero(const tnode_t *tn)
+{
+ return tn != NULL && tn->tn_op == CON && !is_nonzero_val(tn->tn_val);
+}
+
+static inline bool
+is_nonzero(const tnode_t *tn)
+{
+ return tn != NULL && tn->tn_op == CON && is_nonzero_val(tn->tn_val);
+}
Home |
Main Index |
Thread Index |
Old Index