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: split initstack_pop_item into sepa...
details: https://anonhg.NetBSD.org/src/rev/a09aaf80e19e
branches: trunk
changeset: 1019683:a09aaf80e19e
user: rillig <rillig%NetBSD.org@localhost>
date: Fri Mar 19 00:19:32 2021 +0000
description:
lint: split initstack_pop_item into separate functions
No functional change.
diffstat:
usr.bin/xlint/lint1/init.c | 106 +++++++++++++++++++++++++-------------------
1 files changed, 59 insertions(+), 47 deletions(-)
diffs (142 lines):
diff -r 90d3ee9e7ab6 -r a09aaf80e19e usr.bin/xlint/lint1/init.c
--- a/usr.bin/xlint/lint1/init.c Fri Mar 19 00:08:13 2021 +0000
+++ b/usr.bin/xlint/lint1/init.c Fri Mar 19 00:19:32 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: init.c,v 1.100 2021/03/19 00:08:13 rillig Exp $ */
+/* $NetBSD: init.c,v 1.101 2021/03/19 00:19:32 rillig Exp $ */
/*
* Copyright (c) 1994, 1995 Jochen Pohl
@@ -37,7 +37,7 @@
#include <sys/cdefs.h>
#if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: init.c,v 1.100 2021/03/19 00:08:13 rillig Exp $");
+__RCSID("$NetBSD: init.c,v 1.101 2021/03/19 00:19:32 rillig Exp $");
#endif
#include <stdlib.h>
@@ -410,59 +410,44 @@
}
static void
-initstack_pop_item(void)
+initstack_pop_item_named_member(void)
{
- initstack_element *istk;
- sym_t *m;
+ initstack_element *istk = initstk;
+ sym_t *m;
- debug_enter();
-
- istk = initstk;
- debug_step("popping:");
- debug_initstack_element(istk);
+ debug_step("initializing named member '%s'", namedmem->n_name);
- initstk = istk->i_enclosing;
- free(istk);
- istk = initstk;
- lint_assert(istk != NULL);
+ lint_assert(istk->i_type->t_tspec == STRUCT ||
+ istk->i_type->t_tspec == UNION);
+ for (m = istk->i_type->t_str->sou_first_member;
+ m != NULL; m = m->s_next) {
- istk->i_remaining--;
- lint_assert(istk->i_remaining >= 0);
- debug_step("%d elements remaining", istk->i_remaining);
-
- if (namedmem != NULL) {
- debug_step("initializing named member '%s'", namedmem->n_name);
+ if (m->s_bitfield && m->s_name == unnamed)
+ continue;
- lint_assert(istk->i_type->t_tspec == STRUCT ||
- istk->i_type->t_tspec == UNION);
- for (m = istk->i_type->t_str->sou_first_member;
- m != NULL; m = m->s_next) {
-
- if (m->s_bitfield && m->s_name == unnamed)
- continue;
+ if (strcmp(m->s_name, namedmem->n_name) == 0) {
+ debug_step("found matching member");
+ istk->i_subt = m->s_type;
+ /* XXX: why ++? */
+ istk->i_remaining++;
+ /* XXX: why is i_seen_named_member not set? */
+ pop_member();
+ return;
+ }
+ }
- if (strcmp(m->s_name, namedmem->n_name) == 0) {
- debug_step("found matching member");
- istk->i_subt = m->s_type;
- /* XXX: why ++? */
- istk->i_remaining++;
- /* XXX: why is i_seen_named_member not set? */
- pop_member();
- debug_initstack();
- debug_leave();
- return;
- }
- }
+ /* undefined struct/union member: %s */
+ error(101, namedmem->n_name);
- /* undefined struct/union member: %s */
- error(101, namedmem->n_name);
+ pop_member();
+ istk->i_seen_named_member = true;
+}
- pop_member();
- istk->i_seen_named_member = true;
- debug_initstack();
- debug_leave();
- return;
- }
+static void
+initstack_pop_item_unnamed(void)
+{
+ initstack_element *istk = initstk;
+ sym_t *m;
/*
* If the removed element was a structure member, we must go
@@ -480,6 +465,33 @@
/* XXX: duplicate code for skipping unnamed bit-fields */
istk->i_subt = m->s_type;
}
+}
+
+static void
+initstack_pop_item(void)
+{
+ initstack_element *istk;
+
+ debug_enter();
+
+ istk = initstk;
+ debug_step("popping:");
+ debug_initstack_element(istk);
+
+ initstk = istk->i_enclosing;
+ free(istk);
+ istk = initstk;
+ lint_assert(istk != NULL);
+
+ istk->i_remaining--;
+ lint_assert(istk->i_remaining >= 0);
+ debug_step("%d elements remaining", istk->i_remaining);
+
+ if (namedmem != NULL)
+ initstack_pop_item_named_member();
+ else
+ initstack_pop_item_unnamed();
+
debug_initstack();
debug_leave();
}
Home |
Main Index |
Thread Index |
Old Index