Use sv_t instead of raw char*

We're storing them as sv_t's anyway, we're fucked with regards to
indirection.  Thus, let's be nice to ourselves, and deal with the
structures.  We get the size of the structure for free anyway!
This commit is contained in:
2025-08-20 21:50:58 +01:00
parent 643896e2c8
commit df558da7e1
4 changed files with 11 additions and 11 deletions

View File

@@ -32,9 +32,9 @@ void sym_table_init(sym_table_t *table)
vec_make((void **)&table->entries, table->capacity * sizeof(*table->entries));
}
char *sym_table_find(sym_table_t *table, sv_t sv)
sv_t *sym_table_find(sym_table_t *table, sv_t sv)
{
// TODO: Deal with resizing this when table->count > table->size / 2
// WIP: Deal with resizing this when table->count > table->size / 2
u64 index = djb2(sv) & (table->capacity - 1);
for (sv_t comp = table->entries[index]; comp.data; index += 1,
@@ -51,7 +51,7 @@ char *sym_table_find(sym_table_t *table, sv_t sv)
++table->count;
}
return table->entries[index].data;
return table->entries + index;
}
void sym_table_cleanup(sym_table_t *table)