#include #include #include #include "cpp.h" extern int getopt(int, char *const *, const char *); extern char *optarg; extern int optind; extern int verbose; extern int Cplusplus; Nlist *kwdefined; char wd[128]; #define NLSIZE 128 static Nlist *nlist[NLSIZE]; struct kwtab { char *kw; int val; int flag; } kwtab[] = { "if", KIF, ISKW, "ifdef", KIFDEF, ISKW, "ifndef", KIFNDEF, ISKW, "elif", KELIF, ISKW, "else", KELSE, ISKW, "endif", KENDIF, ISKW, "include", KINCLUDE, ISKW, "define", KDEFINE, ISKW, "undef", KUNDEF, ISKW, "line", KLINE, ISKW, "error", KERROR, ISKW, "pragma", KPRAGMA, ISKW, "eval", KEVAL, ISKW, "defined", KDEFINED, ISDEFINED+ISUNCHANGE, "__LINE__", KLINENO, ISMAC+ISUNCHANGE, "__FILE__", KFILE, ISMAC+ISUNCHANGE, "__DATE__", KDATE, ISMAC+ISUNCHANGE, "__TIME__", KTIME, ISMAC+ISUNCHANGE, "__STDC__", KSTDC, ISUNCHANGE, NULL }; unsigned long namebit[077+1]; Nlist *np; void setup_kwtab(void) { struct kwtab *kp; Nlist *np; Token t; static Token deftoken[1] = {{ NAME, 0, 0, 0, 7, (uchar*)"defined" }}; static Tokenrow deftr = { deftoken, deftoken, deftoken+1, 1 }; for (kp=kwtab; kp->kw; kp++) { t.t = (uchar*)kp->kw; t.len = strlen(kp->kw); np = lookup(&t, 1); np->flag = kp->flag; np->val = kp->val; if (np->val == KDEFINED) { kwdefined = np; np->val = NAME; np->vp = &deftr; np->ap = 0; } } } Nlist * lookup(Token *tp, int install) { unsigned int h; Nlist *np; uchar *cp, *cpe; h = 0; for (cp=tp->t, cpe=cp+tp->len; cpt==*np->name && tp->len==np->len && strncmp((char*)tp->t, (char*)np->name, tp->len)==0) return np; np = np->next; } if (install) { np = new(Nlist); np->vp = NULL; np->ap = NULL; np->flag = 0; np->val = 0; np->len = tp->len; np->name = newstring(tp->t, tp->len, 0); np->next = nlist[h]; nlist[h] = np; quickset(tp->t[0], tp->len>1? tp->t[1]:0); return np; } return NULL; }