From c3ed2be023ac78e94bbcd4b1dd378763f86c6ef9 Mon Sep 17 00:00:00 2001 From: Michael Forney Date: Sun, 7 Apr 2024 04:55:37 -0700 Subject: init: Remove use of u.array.length Instead, keep track of index offset. --- init.c | 46 ++++++++++++++++++---------------------------- 1 file changed, 18 insertions(+), 28 deletions(-) diff --git a/init.c b/init.c index a713933..1a7f5cd 100644 --- a/init.c +++ b/init.c @@ -10,7 +10,7 @@ struct object { struct type *type; union { struct member *mem; - size_t idx; + unsigned long long idx; } u; bool iscur; }; @@ -62,17 +62,6 @@ initadd(struct initparser *p, struct init *new) p->last = &new->next; } -static void -updatearray(struct type *t, unsigned long long i) -{ - if (!t->incomplete) - return; - if (++i > t->u.array.length) { - t->u.array.length = i; - t->size = i * t->base->size; - } -} - static void subobj(struct initparser *p, struct type *t, unsigned long long off) { @@ -121,13 +110,14 @@ designator(struct scope *s, struct initparser *p) if (t->kind != TYPEARRAY) error(&tok.loc, "index designator is only valid for array types"); next(); - p->sub->u.idx = intconstexpr(s, false); - if (t->incomplete) - updatearray(t, p->sub->u.idx); - else if (p->sub->u.idx >= t->u.array.length) - error(&tok.loc, "index designator is larger than array length"); + p->sub->u.idx = intconstexpr(s, false) * t->base->size; + if (p->sub->u.idx >= t->size) { + if (!t->incomplete) + error(&tok.loc, "index designator is larger than array length"); + t->size = p->sub->u.idx + t->base->size; + } expect(TRBRACK, "for index designator"); - subobj(p, t->base, p->sub->u.idx * t->base->size); + subobj(p, t->base, p->sub->u.idx); break; case TPERIOD: if (t->kind != TYPESTRUCT && t->kind != TYPEUNION) @@ -152,10 +142,10 @@ focus(struct initparser *p) switch (p->sub->type->kind) { case TYPEARRAY: + t = p->sub->type->base; p->sub->u.idx = 0; if (p->sub->type->incomplete) - updatearray(p->sub->type, 0); - t = p->sub->type->base; + p->sub->type->size = t->size; break; case TYPESTRUCT: case TYPEUNION: @@ -179,14 +169,14 @@ advance(struct initparser *p) t = p->sub->type; switch (t->kind) { case TYPEARRAY: - ++p->sub->u.idx; - if (t->incomplete) - updatearray(t, p->sub->u.idx); - if (p->sub->u.idx < t->u.array.length) { - subobj(p, t->base, t->base->size * p->sub->u.idx); - return; + p->sub->u.idx += t->base->size; + if (p->sub->u.idx == t->size) { + if (!t->incomplete) + break; + t->size += t->base->size; } - break; + subobj(p, t->base, p->sub->u.idx); + return; case TYPESTRUCT: p->sub->u.mem = p->sub->u.mem->next; if (p->sub->u.mem) { @@ -255,7 +245,7 @@ parseinit(struct scope *s, struct type *t) if (!(base->prop & PROPCHAR && expr->type->base->prop & PROPCHAR) && !typecompatible(base, expr->type->base)) error(&tok.loc, "cannot initialize array with string literal of different width"); if (t->incomplete) - updatearray(t, expr->u.string.size - 1); + t->size = expr->type->size; goto add; case TYPESTRUCT: case TYPEUNION: -- cgit v1.2.3