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_push into smaller ...
details: https://anonhg.NetBSD.org/src/rev/856e08c898eb
branches: trunk
changeset: 981646:856e08c898eb
user: rillig <rillig%NetBSD.org@localhost>
date: Thu Mar 18 23:45:20 2021 +0000
description:
lint: split initstack_push into smaller functions
No functional change.
diffstat:
usr.bin/xlint/lint1/init.c | 172 ++++++++++++++++++++++++--------------------
1 files changed, 95 insertions(+), 77 deletions(-)
diffs (210 lines):
diff -r 6ad9a29a4e74 -r 856e08c898eb usr.bin/xlint/lint1/init.c
--- a/usr.bin/xlint/lint1/init.c Thu Mar 18 23:37:31 2021 +0000
+++ b/usr.bin/xlint/lint1/init.c Thu Mar 18 23:45:20 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: init.c,v 1.98 2021/03/18 23:37:31 rillig Exp $ */
+/* $NetBSD: init.c,v 1.99 2021/03/18 23:45:20 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.98 2021/03/18 23:37:31 rillig Exp $");
+__RCSID("$NetBSD: init.c,v 1.99 2021/03/18 23:45:20 rillig Exp $");
#endif
#include <stdlib.h>
@@ -545,11 +545,98 @@
}
static void
+initstack_push_array(void)
+{
+ initstack_element *const istk = initstk;
+
+ if (istk->i_enclosing->i_seen_named_member) {
+ istk->i_brace = true;
+ debug_step("ARRAY brace=%d, namedmem=%d",
+ istk->i_brace, istk->i_enclosing->i_seen_named_member);
+ }
+
+ if (is_incomplete(istk->i_type) &&
+ istk->i_enclosing->i_enclosing != NULL) {
+ /* initialization of an incomplete type */
+ error(175);
+ initerr = true;
+ return;
+ }
+
+ istk->i_subt = istk->i_type->t_subt;
+ istk->i_array_of_unknown_size = is_incomplete(istk->i_type);
+ istk->i_remaining = istk->i_type->t_dim;
+ debug_named_member();
+ debug_step("type '%s' remaining %d",
+ type_name(istk->i_type), istk->i_remaining);
+}
+
+static bool
+initstack_push_struct_or_union(void)
+{
+ initstack_element *const istk = initstk;
+ int cnt;
+ sym_t *m;
+
+ if (is_incomplete(istk->i_type)) {
+ /* initialization of an incomplete type */
+ error(175);
+ initerr = true;
+ return false;
+ }
+ cnt = 0;
+ debug_named_member();
+ debug_step("lookup for '%s'%s",
+ type_name(istk->i_type),
+ istk->i_seen_named_member ? ", seen named member" : "");
+ 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 (namedmem != NULL) {
+ debug_step("named lhs.member=%s, rhs.member=%s",
+ m->s_name, namedmem->n_name);
+ if (strcmp(m->s_name, namedmem->n_name) == 0) {
+ cnt++;
+ break;
+ } else
+ continue;
+ }
+ if (++cnt == 1) {
+ istk->i_current_object = m;
+ istk->i_subt = m->s_type;
+ }
+ }
+ if (namedmem != NULL) {
+ if (m == NULL) {
+ debug_step("pop struct");
+ return true;
+ }
+ istk->i_current_object = m;
+ istk->i_subt = m->s_type;
+ istk->i_seen_named_member = true;
+ debug_step("named member '%s'", namedmem->n_name);
+ pop_member();
+ cnt = istk->i_type->t_tspec == STRUCT ? 2 : 1;
+ }
+ istk->i_brace = true;
+ debug_step("unnamed element with type '%s'%s",
+ type_name(istk->i_type != NULL ? istk->i_type : istk->i_subt),
+ istk->i_brace ? ", needs closing brace" : "");
+ if (cnt == 0) {
+ /* cannot init. struct/union with no named member */
+ error(179);
+ initerr = true;
+ return false;
+ }
+ istk->i_remaining = istk->i_type->t_tspec == STRUCT ? cnt : 1;
+ return false;
+}
+
+static void
initstack_push(void)
{
initstack_element *istk, *inxt;
- int cnt;
- sym_t *m;
debug_enter();
@@ -576,86 +663,17 @@
goto pop;
}
- if (istk->i_enclosing->i_seen_named_member) {
- istk->i_brace = true;
- debug_step("ARRAY brace=%d, namedmem=%d",
- istk->i_brace,
- istk->i_enclosing->i_seen_named_member);
- }
+ initstack_push_array();
+ break;
- if (is_incomplete(istk->i_type) &&
- istk->i_enclosing->i_enclosing != NULL) {
- /* initialization of an incomplete type */
- error(175);
- initerr = true;
- break;
- }
- istk->i_subt = istk->i_type->t_subt;
- istk->i_array_of_unknown_size = is_incomplete(istk->i_type);
- istk->i_remaining = istk->i_type->t_dim;
- debug_named_member();
- debug_step("type '%s' remaining %d",
- type_name(istk->i_type), istk->i_remaining);
- break;
case UNION:
if (tflag)
/* initialization of union is illegal in trad. C */
warning(238);
/* FALLTHROUGH */
case STRUCT:
- if (is_incomplete(istk->i_type)) {
- /* initialization of an incomplete type */
- error(175);
- initerr = true;
- break;
- }
- cnt = 0;
- debug_named_member();
- debug_step("lookup for '%s'%s",
- type_name(istk->i_type),
- istk->i_seen_named_member ? ", seen named member" : "");
- 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 (namedmem != NULL) {
- debug_step("named lhs.member=%s, rhs.member=%s",
- m->s_name, namedmem->n_name);
- if (strcmp(m->s_name, namedmem->n_name) == 0) {
- cnt++;
- break;
- } else
- continue;
- }
- if (++cnt == 1) {
- istk->i_current_object = m;
- istk->i_subt = m->s_type;
- }
- }
- if (namedmem != NULL) {
- if (m == NULL) {
- debug_step("pop struct");
- goto pop;
- }
- istk->i_current_object = m;
- istk->i_subt = m->s_type;
- istk->i_seen_named_member = true;
- debug_step("named member '%s'", namedmem->n_name);
- pop_member();
- cnt = istk->i_type->t_tspec == STRUCT ? 2 : 1;
- }
- istk->i_brace = true;
- debug_step("unnamed element with type '%s'%s",
- type_name(
- istk->i_type != NULL ? istk->i_type : istk->i_subt),
- istk->i_brace ? ", needs closing brace" : "");
- if (cnt == 0) {
- /* cannot init. struct/union with no named member */
- error(179);
- initerr = true;
- break;
- }
- istk->i_remaining = istk->i_type->t_tspec == STRUCT ? cnt : 1;
+ if (initstack_push_struct_or_union())
+ goto pop;
break;
default:
if (namedmem != NULL) {
Home |
Main Index |
Thread Index |
Old Index