diff options
author | Michael Forney <mforney@mforney.org> | 2024-04-07 04:55:37 -0700 |
---|---|---|
committer | Michael Forney <mforney@mforney.org> | 2024-04-07 13:29:14 -0700 |
commit | c3ed2be023ac78e94bbcd4b1dd378763f86c6ef9 (patch) | |
tree | a52854a897e9b1f2f4e8a2012639f31c781670c2 | |
parent | 857f0ecdab2cc3337d15540a32f5b25c1424f4de (diff) |
init: Remove use of u.array.length
Instead, keep track of index offset.
-rw-r--r-- | init.c | 46 |
1 files changed, 18 insertions, 28 deletions
@@ -10,7 +10,7 @@ struct object { struct type *type; union { struct member *mem; - size_t idx; + unsigned long long idx; } u; bool iscur; }; @@ -63,17 +63,6 @@ initadd(struct initparser *p, struct init *new) } 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) { off += p->sub->offset; @@ -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: |