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 lint warnings
details: https://anonhg.NetBSD.org/src/rev/bbabc7195a1d
branches: trunk
changeset: 985723:bbabc7195a1d
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Sep 05 16:03:55 2021 +0000
description:
lint: fix lint warnings
diffstat:
usr.bin/xlint/lint1/decl.c | 11 +++----
usr.bin/xlint/lint1/lex.c | 15 +++++------
usr.bin/xlint/lint1/tree.c | 59 ++++++++++++++++++++++++---------------------
3 files changed, 43 insertions(+), 42 deletions(-)
diffs (246 lines):
diff -r 5bca59a232f6 -r bbabc7195a1d usr.bin/xlint/lint1/decl.c
--- a/usr.bin/xlint/lint1/decl.c Sun Sep 05 15:15:58 2021 +0000
+++ b/usr.bin/xlint/lint1/decl.c Sun Sep 05 16:03:55 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: decl.c,v 1.233 2021/09/04 13:45:37 rillig Exp $ */
+/* $NetBSD: decl.c,v 1.234 2021/09/05 16:03:55 rillig Exp $ */
/*
* Copyright (c) 1996 Christopher G. Demetriou. All Rights Reserved.
@@ -38,7 +38,7 @@
#include <sys/cdefs.h>
#if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: decl.c,v 1.233 2021/09/04 13:45:37 rillig Exp $");
+__RCSID("$NetBSD: decl.c,v 1.234 2021/09/05 16:03:55 rillig Exp $");
#endif
#include <sys/param.h>
@@ -907,8 +907,7 @@
/* FALLTHROUGH */
default:
elsz = size_in_bits(tp->t_tspec);
- if (elsz <= 0)
- INTERNAL_ERROR("length(%d)", elsz);
+ lint_assert(elsz > 0);
break;
}
return (int)(elem * elsz);
@@ -917,8 +916,8 @@
unsigned int
alignment_in_bits(const type_t *tp)
{
- size_t a;
- tspec_t t;
+ unsigned int a;
+ tspec_t t;
while (tp->t_tspec == ARRAY)
tp = tp->t_subt;
diff -r 5bca59a232f6 -r bbabc7195a1d usr.bin/xlint/lint1/lex.c
--- a/usr.bin/xlint/lint1/lex.c Sun Sep 05 15:15:58 2021 +0000
+++ b/usr.bin/xlint/lint1/lex.c Sun Sep 05 16:03:55 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lex.c,v 1.80 2021/08/29 09:29:32 rillig Exp $ */
+/* $NetBSD: lex.c,v 1.81 2021/09/05 16:03:55 rillig Exp $ */
/*
* Copyright (c) 1996 Christopher G. Demetriou. All Rights Reserved.
@@ -38,7 +38,7 @@
#include <sys/cdefs.h>
#if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: lex.c,v 1.80 2021/08/29 09:29:32 rillig Exp $");
+__RCSID("$NetBSD: lex.c,v 1.81 2021/09/05 16:03:55 rillig Exp $");
#endif
#include <ctype.h>
@@ -555,7 +555,7 @@
errno = 0;
- uq = strtoull(cp, &eptr, base);
+ uq = (uint64_t)strtoull(cp, &eptr, base);
lint_assert(eptr == cp + len);
if (errno != 0) {
/* integer constant out of range */
@@ -679,7 +679,7 @@
lex_floating_constant(const char *yytext, size_t yyleng)
{
const char *cp;
- int len;
+ size_t len;
tspec_t typ;
char c, *eptr;
double d;
@@ -688,10 +688,9 @@
cp = yytext;
len = yyleng;
- if (cp[len - 1] == 'i') {
- /* imaginary, do nothing for now */
- len--;
- }
+ if (cp[len - 1] == 'i')
+ len--; /* imaginary, do nothing for now */
+
if ((c = cp[len - 1]) == 'f' || c == 'F') {
typ = FLOAT;
len--;
diff -r 5bca59a232f6 -r bbabc7195a1d usr.bin/xlint/lint1/tree.c
--- a/usr.bin/xlint/lint1/tree.c Sun Sep 05 15:15:58 2021 +0000
+++ b/usr.bin/xlint/lint1/tree.c Sun Sep 05 16:03:55 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: tree.c,v 1.377 2021/09/04 12:30:46 rillig Exp $ */
+/* $NetBSD: tree.c,v 1.378 2021/09/05 16:03: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.377 2021/09/04 12:30:46 rillig Exp $");
+__RCSID("$NetBSD: tree.c,v 1.378 2021/09/05 16:03:55 rillig Exp $");
#endif
#include <float.h>
@@ -311,7 +311,7 @@
tp = expr_zalloc(sizeof(*tp));
tp->t_tspec = ARRAY;
tp->t_subt = gettyp(strg->st_tspec);
- tp->t_dim = len + 1;
+ tp->t_dim = (int)(len + 1);
n->tn_op = STRING;
n->tn_type = tp;
@@ -1426,8 +1426,7 @@
}
static void
-check_unconst_function(const type_t *lstp,
- const tnode_t *rn, const type_t *rstp)
+check_unconst_function(const type_t *lstp, const tnode_t *rn)
{
const char *function_name;
@@ -1512,7 +1511,7 @@
}
if (!tflag)
- check_unconst_function(lstp, rn, rstp);
+ check_unconst_function(lstp, rn);
return true;
}
@@ -2290,7 +2289,8 @@
/* Got already an error because of float --> ptr */
case LDOUBLE:
case LCOMPLEX:
- max = LDBL_MAX; min = -LDBL_MAX; break;
+ /* LINTED 248 */
+ max = LDBL_MAX; min = -max; break;
default:
lint_assert(/*CONSTCOND*/false);
}
@@ -2363,7 +2363,7 @@
const type_t *tp, op_t op)
{
if (nsz > osz &&
- (nv->v_quad & bit(osz - 1)) != 0 &&
+ (nv->v_quad & bit((unsigned int)(osz - 1))) != 0 &&
(nv->v_quad & xmask) != xmask) {
/* extra bits set to 0 in conversion of '%s' to '%s', ... */
warning(309, type_name(gettyp(ot)),
@@ -2470,8 +2470,8 @@
convert_constant_check_range(tspec_t ot, const type_t *tp, tspec_t nt,
op_t op, int arg, const val_t *v, val_t *nv)
{
- int osz, nsz;
- int64_t xmask, xmsk1;
+ unsigned int osz, nsz;
+ uint64_t xmask, xmsk1;
osz = size_in_bits(ot);
nsz = tp->t_bitfield ? tp->t_flen : size_in_bits(nt);
@@ -2511,9 +2511,9 @@
void
convert_constant(op_t op, int arg, const type_t *tp, val_t *nv, val_t *v)
{
- tspec_t ot, nt;
- int sz;
- bool range_check;
+ tspec_t ot, nt;
+ unsigned int sz;
+ bool range_check;
/*
* TODO: make 'v' const; the name of this function does not suggest
@@ -3123,7 +3123,7 @@
if (sr == 0) {
/* division by 0 */
error(139);
- q = utyp ? UQUAD_MAX : QUAD_MAX;
+ q = utyp ? -1 : INT64_MAX;
} else {
q = utyp ? (int64_t)(ul / ur) : sl / sr;
}
@@ -3249,6 +3249,20 @@
return build_constant(tn->tn_type, v);
}
+static ldbl_t
+floating_error_value(tspec_t t, ldbl_t lv)
+{
+ if (t == FLOAT) {
+ return lv < 0 ? -FLT_MAX : FLT_MAX;
+ } else if (t == DOUBLE) {
+ return lv < 0 ? -DBL_MAX : DBL_MAX;
+ } else {
+ /* LINTED 248: floating-point constant out of range */
+ ldbl_t max = LDBL_MAX;
+ return lv < 0 ? -max : max;
+ }
+}
+
/*
* Fold constant nodes having operands with floating point type.
*/
@@ -3285,13 +3299,7 @@
if (rv == 0.0) {
/* division by 0 */
error(139);
- if (t == FLOAT) {
- v->v_ldbl = lv < 0 ? -FLT_MAX : FLT_MAX;
- } else if (t == DOUBLE) {
- v->v_ldbl = lv < 0 ? -DBL_MAX : DBL_MAX;
- } else {
- v->v_ldbl = lv < 0 ? -LDBL_MAX : LDBL_MAX;
- }
+ v->v_ldbl = floating_error_value(t, lv);
} else {
v->v_ldbl = lv / rv;
}
@@ -3332,13 +3340,7 @@
(v->v_ldbl > DBL_MAX || v->v_ldbl < -DBL_MAX))) {
/* floating point overflow detected, op %s */
warning(142, op_name(tn->tn_op));
- if (t == FLOAT) {
- v->v_ldbl = v->v_ldbl < 0 ? -FLT_MAX : FLT_MAX;
- } else if (t == DOUBLE) {
- v->v_ldbl = v->v_ldbl < 0 ? -DBL_MAX : DBL_MAX;
- } else {
- v->v_ldbl = v->v_ldbl < 0 ? -LDBL_MAX : LDBL_MAX;
- }
+ v->v_ldbl = floating_error_value(t, v->v_ldbl);
fpe = 0;
}
@@ -3361,6 +3363,7 @@
/*
* Create a constant node for offsetof.
*/
+/* ARGSUSED */ /* See implementation comments. */
tnode_t *
build_offsetof(const type_t *tp, const sym_t *sym)
{
Home |
Main Index |
Thread Index |
Old Index