summaryrefslogtreecommitdiff
path: root/src/minijava/minijava2piglet/Main.java
blob: 3af3e26fd2dfebd5a82a9012a8380e4383e20b51 (plain)
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
package minijava.minijava2piglet;

import minijava.MiniJavaParser;
import minijava.ParseException;
import minijava.TokenMgrError;
import minijava.symboltable.MClasses;
import minijava.syntaxtree.Node;
import minijava.typecheck.PrintError;
import minijava.visitor.BuildSymbolTableVisitor;
import minijava.visitor.GJDepthFirst;
import minijava.visitor.GenPigletVisitor;


public class Main { 
 
    public static void main(String[] args) {
    	try {
			new MiniJavaParser(System.in);
			Node root = MiniJavaParser.Goal();

			// 初始化符号表中最大的类
			MClasses my_classes = new MClasses();

			// 遍历抽象语法树,建立符号表,检查是否重复定义
			root.accept(new BuildSymbolTableVisitor(), my_classes);
			
			// 建立类的继承关系,寻找循环继承
			my_classes.buildClassRelation();
			
			// 对每个类,建立其可用方法列表
			for (int i=0; i<my_classes.mj_classes.size(); i++) {
				my_classes.mj_classes.elementAt(i).buildMethodRef();
			}
			
    		/*
    		 * TODO: Implement your own Visitors and other classes.
    		 * 
    		 */
    		GJDepthFirst v = new GenPigletVisitor();
    		root.accept(v, my_classes);
    	}
    	catch(TokenMgrError e){
    		//Handle Lexical Errors
    		e.printStackTrace();
    	}
    	catch (ParseException e){
    		//Handle Grammar Errors
    		e.printStackTrace();
    	}
    	catch(Exception e){
    		e.printStackTrace();
    	}
    	
    }
}