Module Name:    src
Committed By:   rillig
Date:           Tue Jun 29 21:16:54 UTC 2021

Modified Files:
        src/usr.bin/xlint/lint1: externs1.h lex.c tree.c

Log Message:
lint: rename xsign to convert_integer

The term sign-extend was too specific, the function actually does a
broader conversion.

No functional change.


To generate a diff of this commit:
cvs rdiff -u -r1.113 -r1.114 src/usr.bin/xlint/lint1/externs1.h
cvs rdiff -u -r1.48 -r1.49 src/usr.bin/xlint/lint1/lex.c
cvs rdiff -u -r1.297 -r1.298 src/usr.bin/xlint/lint1/tree.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/usr.bin/xlint/lint1/externs1.h
diff -u src/usr.bin/xlint/lint1/externs1.h:1.113 src/usr.bin/xlint/lint1/externs1.h:1.114
--- src/usr.bin/xlint/lint1/externs1.h:1.113	Mon Jun 28 08:52:55 2021
+++ src/usr.bin/xlint/lint1/externs1.h	Tue Jun 29 21:16:54 2021
@@ -1,4 +1,4 @@
-/*	$NetBSD: externs1.h,v 1.113 2021/06/28 08:52:55 rillig Exp $	*/
+/*	$NetBSD: externs1.h,v 1.114 2021/06/29 21:16:54 rillig Exp $	*/
 
 /*
  * Copyright (c) 1994, 1995 Jochen Pohl
@@ -78,7 +78,7 @@ extern	FILE	*yyin;
 
 extern	void	initscan(void);
 extern	int	msb(int64_t, tspec_t, int);
-extern	int64_t	xsign(int64_t, tspec_t, int);
+extern	int64_t	convert_integer(int64_t, tspec_t, int);
 extern	void	clear_warn_flags(void);
 extern	sym_t	*getsym(sbuf_t *);
 extern	void	cleanup(void);

Index: src/usr.bin/xlint/lint1/lex.c
diff -u src/usr.bin/xlint/lint1/lex.c:1.48 src/usr.bin/xlint/lint1/lex.c:1.49
--- src/usr.bin/xlint/lint1/lex.c:1.48	Tue Jun 29 13:48:24 2021
+++ src/usr.bin/xlint/lint1/lex.c	Tue Jun 29 21:16:54 2021
@@ -1,4 +1,4 @@
-/* $NetBSD: lex.c,v 1.48 2021/06/29 13:48:24 rillig Exp $ */
+/* $NetBSD: lex.c,v 1.49 2021/06/29 21:16:54 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.48 2021/06/29 13:48:24 rillig Exp $");
+__RCSID("$NetBSD: lex.c,v 1.49 2021/06/29 21:16:54 rillig Exp $");
 #endif
 
 #include <ctype.h>
@@ -668,7 +668,7 @@ lex_integer_constant(const char *yytext,
 		break;
 	}
 
-	uq = (uint64_t)xsign((int64_t)uq, typ, -1);
+	uq = (uint64_t)convert_integer((int64_t)uq, typ, -1);
 
 	yylval.y_val = xcalloc(1, sizeof(*yylval.y_val));
 	yylval.y_val->v_tspec = typ;
@@ -703,10 +703,10 @@ msb(int64_t q, tspec_t t, int len)
 }
 
 /*
- * Extends the sign of q.
+ * Extend or truncate q to match t.  If t is signed, sign-extend.
  */
 int64_t
-xsign(int64_t q, tspec_t t, int len)
+convert_integer(int64_t q, tspec_t t, int len)
 {
 	uint64_t vbits;
 

Index: src/usr.bin/xlint/lint1/tree.c
diff -u src/usr.bin/xlint/lint1/tree.c:1.297 src/usr.bin/xlint/lint1/tree.c:1.298
--- src/usr.bin/xlint/lint1/tree.c:1.297	Tue Jun 29 20:44:38 2021
+++ src/usr.bin/xlint/lint1/tree.c	Tue Jun 29 21:16:54 2021
@@ -1,4 +1,4 @@
-/*	$NetBSD: tree.c,v 1.297 2021/06/29 20:44:38 rillig Exp $	*/
+/*	$NetBSD: tree.c,v 1.298 2021/06/29 21:16:54 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.297 2021/06/29 20:44:38 rillig Exp $");
+__RCSID("$NetBSD: tree.c,v 1.298 2021/06/29 21:16:54 rillig Exp $");
 #endif
 
 #include <float.h>
@@ -2402,13 +2402,8 @@ convert_constant(op_t op, int arg, const
 	}
 
 	if (is_integer(nt)) {
-		/*
-		 * FIXME: There must be no sign extension when converting
-		 *  from int to char on a platform where char == unsigned
-		 *  char.  See test lex_char_uchar.c.
-		 */
 		sz = tp->t_bitfield ? tp->t_flen : size_in_bits(nt);
-		nv->v_quad = xsign(nv->v_quad, nt, sz);
+		nv->v_quad = convert_integer(nv->v_quad, nt, sz);
 	}
 
 	if (range_check && op != CVT)
@@ -3027,7 +3022,7 @@ fold(tnode_t *tn)
 		 * shifts of signed values are implementation dependent.
 		 */
 		q = ul >> sr;
-		q = xsign(q, t, size_in_bits(t) - (int)sr);
+		q = convert_integer(q, t, size_in_bits(t) - (int)sr);
 		break;
 	case LT:
 		q = (utyp ? ul < ur : sl < sr) ? 1 : 0;
@@ -3068,7 +3063,7 @@ fold(tnode_t *tn)
 			warning(141, op_name(tn->tn_op));
 	}
 
-	v->v_quad = xsign(q, t, -1);
+	v->v_quad = convert_integer(q, t, -1);
 
 	cn = expr_new_constant(tn->tn_type, v);
 	if (tn->tn_left->tn_system_dependent)

Reply via email to