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: precedence confusion is only possi...
details: https://anonhg.NetBSD.org/src/rev/5a34e0d3146c
branches: trunk
changeset: 1017703:5a34e0d3146c
user: rillig <rillig%NetBSD.org@localhost>
date: Mon Jan 04 23:58:19 2021 +0000
description:
lint: precedence confusion is only possible with binary operators
No functional change.
The operator table in ops.def states that every operator that has
possibly confusing precedence is also a binary operator, so assert that
instead of having two different code paths.
diffstat:
usr.bin/xlint/lint1/op.h | 4 ++--
usr.bin/xlint/lint1/tree.c | 21 ++++++++++-----------
2 files changed, 12 insertions(+), 13 deletions(-)
diffs (75 lines):
diff -r f38b725b7a5e -r 5a34e0d3146c usr.bin/xlint/lint1/op.h
--- a/usr.bin/xlint/lint1/op.h Mon Jan 04 23:50:46 2021 +0000
+++ b/usr.bin/xlint/lint1/op.h Mon Jan 04 23:58:19 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: op.h,v 1.8 2021/01/02 01:06:15 rillig Exp $ */
+/* $NetBSD: op.h,v 1.9 2021/01/04 23:58:19 rillig Exp $ */
/*
* Copyright (c) 1994, 1995 Jochen Pohl
@@ -49,7 +49,7 @@
bool m_sideeff : 1; /* operator has side effect */
bool m_tlansiu : 1; /* warn if left op. is unsign. in ANSI C */
bool m_transiu : 1; /* warn if right op. is unsign. in ANSI C */
- bool m_tpconf : 1; /* test possible precedence confusion */
+ bool m_possible_precedence_confusion : 1;
bool m_comp : 1; /* operator performs comparison */
bool m_valid_on_enum : 1; /* valid operation on enums */
bool m_bad_on_enum : 1; /* dubious operation on enums */
diff -r f38b725b7a5e -r 5a34e0d3146c usr.bin/xlint/lint1/tree.c
--- a/usr.bin/xlint/lint1/tree.c Mon Jan 04 23:50:46 2021 +0000
+++ b/usr.bin/xlint/lint1/tree.c Mon Jan 04 23:58:19 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: tree.c,v 1.132 2021/01/04 23:50:46 rillig Exp $ */
+/* $NetBSD: tree.c,v 1.133 2021/01/04 23:58:19 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.132 2021/01/04 23:50:46 rillig Exp $");
+__RCSID("$NetBSD: tree.c,v 1.133 2021/01/04 23:58:19 rillig Exp $");
#endif
#include <float.h>
@@ -608,7 +608,7 @@
return NULL;
/* Print a warning if precedence confusion is possible */
- if (mp->m_tpconf)
+ if (mp->m_possible_precedence_confusion)
check_precedence_confusion(ntn);
/*
@@ -3997,6 +3997,9 @@
return;
mp = &modtab[tn->tn_op];
+ lint_assert(mp->m_binary);
+
+ dprint_node(tn);
lparn = 0;
for (ln = tn->tn_left; ln->tn_op == CVT; ln = ln->tn_left)
@@ -4004,15 +4007,11 @@
lparn |= ln->tn_parenthesized;
lop = ln->tn_op;
- dprint_node(tn);
-
- if (mp->m_binary) {
- rparn = 0;
- for (rn = tn->tn_right; rn->tn_op == CVT; rn = rn->tn_left)
- rparn |= rn->tn_parenthesized;
+ rparn = 0;
+ for (rn = tn->tn_right; rn->tn_op == CVT; rn = rn->tn_left)
rparn |= rn->tn_parenthesized;
- rop = rn->tn_op;
- }
+ rparn |= rn->tn_parenthesized;
+ rop = rn->tn_op;
dowarn = 0;
Home |
Main Index |
Thread Index |
Old Index