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: extract duplicate code for modifyi...
details: https://anonhg.NetBSD.org/src/rev/4ff88d55faa7
branches: trunk
changeset: 1022663:4ff88d55faa7
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Aug 01 06:58:58 2021 +0000
description:
lint: extract duplicate code for modifying the symbol table
No functional change.
diffstat:
usr.bin/xlint/lint1/lex.c | 63 ++++++++++++++++++++++------------------------
1 files changed, 30 insertions(+), 33 deletions(-)
diffs (161 lines):
diff -r 0948f2e44612 -r 4ff88d55faa7 usr.bin/xlint/lint1/lex.c
--- a/usr.bin/xlint/lint1/lex.c Sun Aug 01 06:40:37 2021 +0000
+++ b/usr.bin/xlint/lint1/lex.c Sun Aug 01 06:58:58 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lex.c,v 1.59 2021/08/01 06:40:37 rillig Exp $ */
+/* $NetBSD: lex.c,v 1.60 2021/08/01 06:58:58 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.59 2021/08/01 06:40:37 rillig Exp $");
+__RCSID("$NetBSD: lex.c,v 1.60 2021/08/01 06:58:58 rillig Exp $");
#endif
#include <ctype.h>
@@ -259,10 +259,28 @@
static void
+symtab_add_hash(sym_t *sym, size_t h)
+{
+
+ if ((sym->s_link = symtab[h]) != NULL)
+ symtab[h]->s_rlink = &sym->s_link;
+ sym->s_rlink = &symtab[h];
+ symtab[h] = sym;
+}
+
+static void
+symtab_add(sym_t *sym)
+{
+ size_t h;
+
+ h = hash(sym->s_name);
+ symtab_add_hash(sym, h);
+}
+
+static void
add_keyword(const struct kwtab *kw, u_int deco)
{
sym_t *sym;
- size_t h;
char buf[256];
const char *name;
@@ -298,11 +316,8 @@
} else if (kw->kw_token == T_QUAL) {
sym->s_tqual = kw->kw_tqual;
}
- h = hash(sym->s_name);
- if ((sym->s_link = symtab[h]) != NULL)
- symtab[h]->s_rlink = &sym->s_link;
- sym->s_rlink = &symtab[h];
- symtab[h] = sym;
+
+ symtab_add(sym);
}
/*
@@ -1380,15 +1395,15 @@
}
/*
- * As noted above the scanner does not create new symbol table entries
+ * As noted above, the scanner does not create new symbol table entries
* for symbols it cannot find in the symbol table. This is to avoid
* putting undeclared symbols into the symbol table if a syntax error
* occurs.
*
- * getsym() is called as soon as it is probably ok to put the symbol to the
+ * getsym() is called as soon as it is probably ok to put the symbol in the
* symbol table. It is still possible that symbols are put in the symbol
* table that are not completely declared due to syntax errors. To avoid too
- * many problems in this case, symbols get type int in getsym().
+ * many problems in this case, symbols get type 'int' in getsym().
*
* XXX calls to getsym() should be delayed until decl1*() is called.
*/
@@ -1446,10 +1461,7 @@
symtyp = FVFT;
- if ((sym->s_link = symtab[sb->sb_hash]) != NULL)
- symtab[sb->sb_hash]->s_rlink = &sym->s_link;
- sym->s_rlink = &symtab[sb->sb_hash];
- symtab[sb->sb_hash] = sym;
+ symtab_add_hash(sym, sb->sb_hash);
*di->d_ldlsym = sym;
di->d_ldlsym = &sym->s_dlnxt;
@@ -1466,13 +1478,11 @@
mktempsym(type_t *t)
{
static int n = 0;
- int h;
char *s = getlblk(block_level, 64);
sym_t *sym = getblk(sizeof(*sym));
scl_t scl;
(void)snprintf(s, 64, "%.8d_tmp", n++);
- h = hash(s);
scl = dcs->d_scl;
if (scl == NOSCL)
@@ -1486,10 +1496,7 @@
sym->s_used = true;
sym->s_set = true;
- if ((sym->s_link = symtab[h]) != NULL)
- symtab[h]->s_rlink = &sym->s_link;
- sym->s_rlink = &symtab[h];
- symtab[h] = sym;
+ symtab_add(sym);
*dcs->d_ldlsym = sym;
dcs->d_ldlsym = &sym->s_dlnxt;
@@ -1542,15 +1549,10 @@
void
inssym(int bl, sym_t *sym)
{
- int h;
debug_step("inssym '%s' %d '%s'",
sym->s_name, sym->s_kind, type_name(sym->s_type));
- h = hash(sym->s_name);
- if ((sym->s_link = symtab[h]) != NULL)
- symtab[h]->s_rlink = &sym->s_link;
- sym->s_rlink = &symtab[h];
- symtab[h] = sym;
+ symtab_add(sym);
sym->s_block_level = bl;
lint_assert(sym->s_link == NULL ||
sym->s_block_level >= sym->s_link->s_block_level);
@@ -1589,12 +1591,10 @@
sym_t *
pushdown(const sym_t *sym)
{
- int h;
sym_t *nsym;
debug_step("pushdown '%s' %d '%s'",
sym->s_name, (int)sym->s_kind, type_name(sym->s_type));
- h = hash(sym->s_name);
nsym = getblk(sizeof(*nsym));
lint_assert(sym->s_block_level <= block_level);
nsym->s_name = sym->s_name;
@@ -1602,10 +1602,7 @@
nsym->s_kind = sym->s_kind;
nsym->s_block_level = block_level;
- if ((nsym->s_link = symtab[h]) != NULL)
- symtab[h]->s_rlink = &nsym->s_link;
- nsym->s_rlink = &symtab[h];
- symtab[h] = nsym;
+ symtab_add(nsym);
*dcs->d_ldlsym = nsym;
dcs->d_ldlsym = &nsym->s_dlnxt;
Home |
Main Index |
Thread Index |
Old Index