gno/usr.bin/cpp/nlist.c

108 lines
2.1 KiB
C

#if defined(__ORCAC__) && defined(DO_SEGMENTS)
segment "cpp_3_____";
#endif
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#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; cp<cpe; )
h += *cp++;
h %= NLSIZE;
np = nlist[h];
while (np) {
if (*tp->t==*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;
}