71 lines
1.3 KiB
C
71 lines
1.3 KiB
C
/*
|
|
* (c) copyright 1987 by the Vrije Universiteit, Amsterdam, The Netherlands.
|
|
* See the copyright notice in the ACK home directory, in the file "Copyright".
|
|
*/
|
|
#ifndef NORCSID
|
|
static char rcsid[]= "$Id$";
|
|
#endif
|
|
|
|
#include "assert.h"
|
|
#include "param.h"
|
|
#include "lookup.h"
|
|
#include "extern.h"
|
|
|
|
char *myalloc();
|
|
char *mystrcpy();
|
|
|
|
symbol dumsym; /* dummy to return in case of error */
|
|
|
|
symbol *lookup(name,type,style)
|
|
char *name;
|
|
symtype type;
|
|
lookupstyle style;
|
|
{
|
|
symbol *sy_p,**sy_pp;
|
|
|
|
for (sy_pp = &symhash[hashvalue(name)];(sy_p= *sy_pp) != 0;sy_pp= &sy_p->sy_next) {
|
|
if (strcmp(sy_p->sy_name,name)!=0)
|
|
continue;
|
|
switch(style) {
|
|
default:
|
|
assert(0);
|
|
case justlooking:
|
|
case mustexist:
|
|
case makeexist:
|
|
if (type==symany || type==sy_p->sy_type)
|
|
return(sy_p);
|
|
continue;
|
|
case newsymbol:
|
|
error("%s already defined",name);
|
|
return(&dumsym);
|
|
}
|
|
}
|
|
switch(style) {
|
|
default:
|
|
assert(0);
|
|
case justlooking:
|
|
return((symbol *) 0);
|
|
case mustexist:
|
|
fatal("%s is unknown symbol",name);
|
|
/* NOTREACHED */
|
|
case newsymbol:
|
|
case makeexist:
|
|
NEW(sy_p,symbol);
|
|
sy_p->sy_next = 0;
|
|
sy_p->sy_name = mystrcpy(name);
|
|
assert(type!=symany);
|
|
sy_p->sy_type = type;
|
|
*sy_pp = sy_p;
|
|
return(sy_p);
|
|
}
|
|
}
|
|
|
|
hashvalue(s) register char *s; {
|
|
register unsigned sum=0;
|
|
register i;
|
|
|
|
for(i=0;*s;s++,i=(i+3)&07)
|
|
sum += *s<<i;
|
|
return(sum%NSYMHASH);
|
|
}
|