Module Name: src
Committed By: rillig
Date: Sat Jul 2 10:41:13 UTC 2022
Modified Files:
src/usr.bin/xlint/lint1: tree.c
Log Message:
lint: document usage of 'convert'
No functional change.
To generate a diff of this commit:
cvs rdiff -u -r1.467 -r1.468 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/tree.c
diff -u src/usr.bin/xlint/lint1/tree.c:1.467 src/usr.bin/xlint/lint1/tree.c:1.468
--- src/usr.bin/xlint/lint1/tree.c:1.467 Sat Jul 2 10:23:38 2022
+++ src/usr.bin/xlint/lint1/tree.c Sat Jul 2 10:41:13 2022
@@ -1,4 +1,4 @@
-/* $NetBSD: tree.c,v 1.467 2022/07/02 10:23:38 rillig Exp $ */
+/* $NetBSD: tree.c,v 1.468 2022/07/02 10:41:13 rillig Exp $ */
/*
* Copyright (c) 1994, 1995 Jochen Pohl
@@ -37,7 +37,7 @@
#include <sys/cdefs.h>
#if defined(__RCSID)
-__RCSID("$NetBSD: tree.c,v 1.467 2022/07/02 10:23:38 rillig Exp $");
+__RCSID("$NetBSD: tree.c,v 1.468 2022/07/02 10:41:13 rillig Exp $");
#endif
#include <float.h>
@@ -2272,7 +2272,15 @@ balance(op_t op, tnode_t **lnp, tnode_t
/*
* Insert a conversion operator, which converts the type of the node
* to another given type.
- * If op is FARG, arg is the number of the argument (used for warnings).
+ *
+ * Possible values for 'op':
+ * CVT a cast-expression
+ * binary integer promotion for one of the operands, or a usual
+ * arithmetic conversion
+ * binary plain or compound assignments to bit-fields
+ * FARG 'arg' is the number of the argument (used for warnings)
+ * NOOP several other implicit conversions
+ * ...
*/
tnode_t *
convert(op_t op, int arg, type_t *tp, tnode_t *tn)
@@ -3499,6 +3507,7 @@ fold(tnode_t *tn)
ovfl = true;
break;
case SHL:
+ /* TODO: warn against out-of-bounds 'sr'. */
q = utyp ? (int64_t)(ul << sr) : sl << sr;
break;
case SHR:
@@ -3506,6 +3515,7 @@ fold(tnode_t *tn)
* The sign must be explicitly extended because
* shifts of signed values are implementation dependent.
*/
+ /* TODO: warn against out-of-bounds 'sr'. */
q = ul >> sr;
q = convert_integer(q, t, size_in_bits(t) - (int)sr);
break;