File: SymTab.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 (62 lines) | stat: -rw-r--r-- 1,930 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
56
57
58
59
60
61
62
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 * Copyright (C) 2001       Gerwin Klein <lsf@jflex.de>                    *
 * Copyright (C) 2001       Bernhard Rumpe <rumpe@in.tum.de>               *
 * All rights reserved.                                                    *
 *                                                                         *
 * License: BSD                                                            *
 *                                                                         *
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */


import java.util.*;

/**
 * Symbol table for the interpreter, contains information about
 * variables and functions.
 * 
 * For every binding location of a name a symbol will be created.
 * The symbol tables are connected hierarchically by pointers to
 * the predecessor. Lookup takes predecessors into account.
 */ 
public class SymTab {
  Map<String,SymtabEntry> m;   // contains the list of words
  SymTab pred;  // predecessor symbol table (if exists)

  public SymTab() {
    this(null); 
  }

  public SymTab(SymTab p) {
    m = new HashMap<String,SymtabEntry>();
    pred = p;
  }

  public boolean enter(String s, SymtabEntry e) {
    Object value = lookup(s);
    m.put(s, e);
    return(value==null);
  }

  public SymtabEntry lookup(String s) {
    SymtabEntry value = m.get(s);
    if (value==null && pred!=null)
      value = pred.lookup(s);
    return value;
  }

  public String toString() {    // for output with print
    StringBuilder res = new StringBuilder("symbol table\n=============\n");
    
    for (Map.Entry<String,SymtabEntry> entry : m.entrySet())
      res.append(entry.getKey()).append("   \t").append(entry.getValue()).append("\n");

    if (pred != null)
      res.append("++ predecessor!\n");

    return res.toString();
  }

  public int size() {
    return(m.size()); 
  }
}