#if defined(__ORCAC__) && defined(DO_SEGMENTS) segment "cpp_3_____"; #endif #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, 0, 0 } }; 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; }