File: Tfun.java

package info (click to toggle)
jflex 1.7.0-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 13,944 kB
  • sloc: java: 421,255; xml: 1,130; makefile: 123; lisp: 90; yacc: 65; sh: 13
file content (55 lines) | stat: -rw-r--r-- 1,899 bytes parent folder | download | duplicates (4)
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);
  }
}