1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Copyright (C) 2001 Gerwin Klein <lsf@jflex.de> *
* Copyright (C) 2001 Bernhard Rumpe <rumpe@in.tum.de> *
* All rights reserved. *
* *
* License: BSD *
* *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/**
* AST node for function application.
*
* Also contains pointer to declaration location of the function.
*/
class Tfun extends Texp implements AST {
Tident ident; // name of the function
Texplist explist; // parameter list
public Tfun(Tident i, Texplist e) {
ident=i;
explist=e;
}
public String toString() {
return ident+"("+explist+")";
}
public void checkcontext(SymTab st) { // CoCo (DefFun,Arity)
explist.checkcontext(st);
SymtabEntry ste = st.lookup(ident.toString());
if (ste==null)
Main.error("function not defined: "+ident);
else if (ste.kind() != SymtabEntry.FUN)
Main.error("variable used as funktion: "+ident);
else if (((STEfun)ste).arity() != explist.length())
Main.error("wrong arity at function call: "+ident);
}
Tdekl fundekl; // pointer to location of function declaration
// set pointers and indices
public void prepInterp(SymTab st) {
fundekl = ((STEfun)st.lookup(ident.toString())).getDekl();
explist.prepInterp(st);
}
public int interpret(int[] in, int[] par) {
int[] newparams = new int[fundekl.arity()];
explist.interpret(in,par,newparams,0);
return fundekl.interpret(in,newparams);
}
}
|