Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.bin/indent indent: clean up lexical analyzer
details: https://anonhg.NetBSD.org/src/rev/eca31c2479ef
branches: trunk
changeset: 1024678:eca31c2479ef
user: rillig <rillig%NetBSD.org@localhost>
date: Sat Oct 30 22:15:51 2021 +0000
description:
indent: clean up lexical analyzer
Use traditional type for small unsigned numbers instead of uint8_t; the
required header was not included.
Remove assertion for debug mode; lint takes care of ensuring that the
enum constants match the length of the names array.
Constify a name array.
Move the comparison function for bsearch closer to its caller.
No functional change.
diffstat:
usr.bin/indent/indent.h | 3 ++-
usr.bin/indent/lexi.c | 31 +++++++++++++------------------
2 files changed, 15 insertions(+), 19 deletions(-)
diffs (110 lines):
diff -r a6d0141a96aa -r eca31c2479ef usr.bin/indent/indent.h
--- a/usr.bin/indent/indent.h Sat Oct 30 22:04:42 2021 +0000
+++ b/usr.bin/indent/indent.h Sat Oct 30 22:15:51 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: indent.h,v 1.64 2021/10/30 11:49:38 rillig Exp $ */
+/* $NetBSD: indent.h,v 1.65 2021/10/30 22:15:51 rillig Exp $ */
/*-
* SPDX-License-Identifier: BSD-2-Clause-FreeBSD
@@ -69,6 +69,7 @@
#endif
#include <stdbool.h>
+#include <stdio.h>
typedef enum lexer_symbol {
lsym_eof,
diff -r a6d0141a96aa -r eca31c2479ef usr.bin/indent/lexi.c
--- a/usr.bin/indent/lexi.c Sat Oct 30 22:04:42 2021 +0000
+++ b/usr.bin/indent/lexi.c Sat Oct 30 22:15:51 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lexi.c,v 1.114 2021/10/29 23:48:50 rillig Exp $ */
+/* $NetBSD: lexi.c,v 1.115 2021/10/30 22:15:51 rillig Exp $ */
/*-
* SPDX-License-Identifier: BSD-4-Clause
@@ -43,14 +43,11 @@
#include <sys/cdefs.h>
#if defined(__NetBSD__)
-__RCSID("$NetBSD: lexi.c,v 1.114 2021/10/29 23:48:50 rillig Exp $");
+__RCSID("$NetBSD: lexi.c,v 1.115 2021/10/30 22:15:51 rillig Exp $");
#elif defined(__FreeBSD__)
__FBSDID("$FreeBSD: head/usr.bin/indent/lexi.c 337862 2018-08-15 18:19:45Z pstef $");
#endif
-#include <sys/param.h>
-#include <assert.h>
-#include <stdio.h>
#include <ctype.h>
#include <stdlib.h>
#include <string.h>
@@ -157,7 +154,7 @@
};
/* INDENT ON */
-static const uint8_t lex_number_row[] = {
+static const unsigned char lex_number_row[] = {
['0'] = 1,
['1'] = 2,
['2'] = 3, ['3'] = 3, ['4'] = 3, ['5'] = 3, ['6'] = 3, ['7'] = 3,
@@ -211,12 +208,6 @@
*token.e++ = ch;
}
-static int
-cmp_keyword_by_name(const void *key, const void *elem)
-{
- return strcmp(key, ((const struct keyword *)elem)->name);
-}
-
#ifdef debug
static const char *
lsym_name(lexer_symbol sym)
@@ -255,15 +246,13 @@
"while",
};
- assert(array_length(name) == (int)lsym_while + 1);
-
return name[sym];
}
static const char *
kw_name(enum keyword_kind kw)
{
- static const char *name[] = {
+ static const char *const name[] = {
"0",
"offsetof",
"sizeof",
@@ -376,12 +365,12 @@
static void
lex_number(void)
{
- for (uint8_t s = 'A'; s != 'f' && s != 'i' && s != 'u';) {
- uint8_t ch = (uint8_t)*inp.s;
+ for (unsigned char s = 'A'; s != 'f' && s != 'i' && s != 'u';) {
+ unsigned char ch = (unsigned char)*inp.s;
if (ch >= array_length(lex_number_row) || lex_number_row[ch] == 0)
break;
- uint8_t row = lex_number_row[ch];
+ unsigned char row = lex_number_row[ch];
if (lex_number_state[row][s - 'A'] == ' ') {
/*-
* lex_number_state[0][s - 'A'] now indicates the type:
@@ -485,6 +474,12 @@
return bsearch_typenames(token.s) >= 0;
}
+static int
+cmp_keyword_by_name(const void *key, const void *elem)
+{
+ return strcmp(key, ((const struct keyword *)elem)->name);
+}
+
/* Read an alphanumeric token into 'token', or return end_of_file. */
static lexer_symbol
lexi_alnum(void)
Home |
Main Index |
Thread Index |
Old Index