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: move code for checking init expres...
details: https://anonhg.NetBSD.org/src/rev/6db644b75238
branches: trunk
changeset: 981987:6db644b75238
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Mar 28 10:58:18 2021 +0000
description:
lint: move code for checking init expressions further up
It did not make sense to have this code between the code for the
designation and the brace level. Since it is independent of all these
types, move it to the top.
No functional change.
diffstat:
usr.bin/xlint/lint1/init.c | 150 ++++++++++++++++++++++----------------------
1 files changed, 75 insertions(+), 75 deletions(-)
diffs (178 lines):
diff -r 9cfe445dc862 -r 6db644b75238 usr.bin/xlint/lint1/init.c
--- a/usr.bin/xlint/lint1/init.c Sun Mar 28 10:52:41 2021 +0000
+++ b/usr.bin/xlint/lint1/init.c Sun Mar 28 10:58:18 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: init.c,v 1.158 2021/03/28 10:52:41 rillig Exp $ */
+/* $NetBSD: init.c,v 1.159 2021/03/28 10:58:18 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.158 2021/03/28 10:52:41 rillig Exp $");
+__RCSID("$NetBSD: init.c,v 1.159 2021/03/28 10:58:18 rillig Exp $");
#endif
#include <stdlib.h>
@@ -321,79 +321,6 @@
#endif
-static struct designator *
-designator_new(const char *name)
-{
- struct designator *d = xcalloc(1, sizeof *d);
- d->name = name;
- return d;
-}
-
-static void
-designator_free(struct designator *d)
-{
- free(d);
-}
-
-
-#ifdef DEBUG
-static void
-designation_debug(const struct designation *dn)
-{
- const struct designator *p;
-
- if (dn->head == NULL)
- return;
-
- debug_indent();
- debug_printf("designation: ");
- for (p = dn->head; p != NULL; p = p->next)
- debug_printf(".%s", p->name);
- debug_printf("\n");
-}
-#else
-#define designation_debug(dn) do { } while (false)
-#endif
-
-static void
-designation_add(struct designation *dn, struct designator *dr)
-{
-
- if (dn->head != NULL) {
- dn->tail->next = dr;
- dn->tail = dr;
- } else {
- dn->head = dr;
- dn->tail = dr;
- }
-
- designation_debug(dn);
-}
-
-/* TODO: add support for array subscripts, not only named members */
-/*
- * TODO: This function should not be necessary at all. There is no need to
- * remove the head of the list.
- */
-static void
-designation_shift_level(struct designation *dn)
-{
- lint_assert(dn->head != NULL);
-
- if (dn->head == dn->tail) {
- designator_free(dn->head);
- dn->head = NULL;
- dn->tail = NULL;
- } else {
- struct designator *head = dn->head;
- dn->head = dn->head->next;
- designator_free(head);
- }
-
- designation_debug(dn);
-}
-
-
/* In traditional C, bit-fields can be initialized only by integer constants. */
static void
check_bit_field_init(const tnode_t *ln, tspec_t lt, tspec_t rt)
@@ -473,6 +400,79 @@
}
+static struct designator *
+designator_new(const char *name)
+{
+ struct designator *d = xcalloc(1, sizeof *d);
+ d->name = name;
+ return d;
+}
+
+static void
+designator_free(struct designator *d)
+{
+ free(d);
+}
+
+
+#ifdef DEBUG
+static void
+designation_debug(const struct designation *dn)
+{
+ const struct designator *p;
+
+ if (dn->head == NULL)
+ return;
+
+ debug_indent();
+ debug_printf("designation: ");
+ for (p = dn->head; p != NULL; p = p->next)
+ debug_printf(".%s", p->name);
+ debug_printf("\n");
+}
+#else
+#define designation_debug(dn) do { } while (false)
+#endif
+
+static void
+designation_add(struct designation *dn, struct designator *dr)
+{
+
+ if (dn->head != NULL) {
+ dn->tail->next = dr;
+ dn->tail = dr;
+ } else {
+ dn->head = dr;
+ dn->tail = dr;
+ }
+
+ designation_debug(dn);
+}
+
+/* TODO: add support for array subscripts, not only named members */
+/*
+ * TODO: This function should not be necessary at all. There is no need to
+ * remove the head of the list.
+ */
+static void
+designation_shift_level(struct designation *dn)
+{
+ lint_assert(dn->head != NULL);
+
+ if (dn->head == dn->tail) {
+ designator_free(dn->head);
+ dn->head = NULL;
+ dn->tail = NULL;
+ } else {
+ struct designator *head = dn->head;
+ dn->head = dn->head->next;
+ designator_free(head);
+ }
+
+ designation_debug(dn);
+}
+
+
static struct brace_level *
brace_level_new(type_t *type, type_t *subtype, int remaining)
{
Home |
Main Index |
Thread Index |
Old Index