ref: adc45909f04c3cd3c7ee4e3e1e62ce5d67eaef7d
dir: /symbol.c/
#include <stdlib.h> #include <string.h> #include "cc.h" #include "symbol.h" #define NR_SYM_HASH 32 unsigned char curctx; static struct symbol *htab[NR_SYM_HASH]; static struct symbol *head, *headfun; static inline unsigned char hash(register const char *s) { register unsigned char h, ch; for (h = 0; ch = *s++; h += ch) /* nothing */; return h & NR_SYM_HASH - 1; } void new_ctx(void) { ++curctx; } void del_ctx(void) { register struct symbol *sym, *next; static char *s; --curctx; for (sym = head; sym; sym = next) { if (sym->ctx <= curctx) break; if ((s = sym->name) != NULL) htab[hash(s)] = sym->hash; next = sym->next; sym->next = headfun; headfun = sym; } } void freesyms(void) { register struct symbol *sym, *next; if (curctx == CTX_OUTER) { for (sym = headfun; sym; sym = next) { next = sym->next; free(sym->name); free(sym); } } } struct symbol * lookup(register const char *s, unsigned char ns, unsigned char ctx) { register struct symbol *sym; static unsigned char l, key; l = strlen(s); for (sym = htab[hash(s)]; sym; sym = sym->hash) { if (!memcmp(sym->name, s, l) && (ns == NS_ANY || ns == sym->ns) && (sym->ctx == ctx || ctx == CTX_ANY)) { return sym; } } sym = xmalloc(sizeof(*sym)); sym->name = xstrdup(s); sym->ns = ns; sym->ctx = CTX_ANY; sym->next = head; head = sym; key = hash(s); sym->hash = htab[key]; htab[key] = sym; return sym; }