ack/lang/m2/comp/lookup.c

89 lines
1.8 KiB
C
Raw Normal View History

/*
* (c) copyright 1987 by the Vrije Universiteit, Amsterdam, The Netherlands.
* See the copyright notice in the ACK home directory, in the file "Copyright".
*
* Author: Ceriel J.H. Jacobs
*/
1986-06-10 13:18:52 +00:00
/* L O O K U P R O U T I N E S */
/* $Header$ */
1986-06-10 13:18:52 +00:00
#include "debug.h"
#include <em_arith.h>
#include <em_label.h>
#include <assert.h>
#include "LLlex.h"
1986-06-10 13:18:52 +00:00
#include "def.h"
#include "idf.h"
#include "scope.h"
#include "node.h"
1986-09-25 19:39:06 +00:00
#include "type.h"
1986-10-22 15:38:24 +00:00
#include "misc.h"
1986-06-10 13:18:52 +00:00
struct def *
lookup(id, scope, import)
1986-06-10 13:18:52 +00:00
register struct idf *id;
struct scope *scope;
{
/* Look up a definition of an identifier in scope "scope".
Make the "def" list self-organizing.
Return a pointer to its "def" structure if it exists,
otherwise return 0.
*/
1986-06-20 14:36:49 +00:00
register struct def *df, *df1;
/* Look in the chain of definitions of this "id" for one with scope
"scope".
*/
for (df = id->id_def, df1 = 0;
df && df->df_scope != scope;
1987-07-16 19:51:40 +00:00
df1 = df, df = df->df_next) { /* nothing */ }
1986-06-10 13:18:52 +00:00
1986-06-20 14:36:49 +00:00
if (df) {
/* Found it
*/
if (df1) {
/* Put the definition in front
*/
1987-07-16 19:51:40 +00:00
df1->df_next = df->df_next;
df->df_next = id->id_def;
1986-06-20 14:36:49 +00:00
id->id_def = df;
}
if (import) {
while (df->df_kind == D_IMPORT) {
assert(df->imp_def != 0);
df = df->imp_def;
}
1986-06-10 13:18:52 +00:00
}
}
1986-06-20 14:36:49 +00:00
return df;
1986-06-10 13:18:52 +00:00
}
struct def *
lookfor(id, vis, give_error)
register struct node *id;
struct scopelist *vis;
{
/* Look for an identifier in the visibility range started by "vis".
If it is not defined create a dummy definition and,
if "give_error" is set, give an error message.
*/
1986-06-20 14:36:49 +00:00
register struct def *df;
1986-06-10 13:18:52 +00:00
register struct scopelist *sc = vis;
while (sc) {
df = lookup(id->nd_IDF, sc->sc_scope, 1);
1986-06-10 13:18:52 +00:00
if (df) return df;
sc = nextvisible(sc);
}
if (give_error) id_not_declared(id);
1986-09-25 19:39:06 +00:00
df = MkDef(id->nd_IDF, vis->sc_scope, D_ERROR);
df->df_type = error_type;
return df;
1986-06-10 13:18:52 +00:00
}