From 5b09fb3697f4b1cc1f2f3781f10e1334ada69c22 Mon Sep 17 00:00:00 2001 From: bd-912 Date: Mon, 4 Mar 2024 22:57:07 -0700 Subject: Added the main class file --- Typecheck.java | 50 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 Typecheck.java (limited to 'Typecheck.java') diff --git a/Typecheck.java b/Typecheck.java new file mode 100644 index 0000000..039e94d --- /dev/null +++ b/Typecheck.java @@ -0,0 +1,50 @@ +// Helper for HW2/CS453. +import java.io.*; +import visitor.*; +import syntaxtree.*; +import java.util.*; +// Files are stored in the minijava directory/package. +import minijava.*; + +public class Typecheck { + public static void main(String[] args) { + Node root = null; + try { + root = new MiniJavaParser(System.in).Goal(); + + // Pretty-print the tree. PPrinter inherits from + // GJDepthFirst. R=Void, A=String. + // PPrinter pp = new PPrinter(); + // root.accept(pp, ""); + + // // Build the symbol table. Top-down visitor, inherits from + // // GJDepthFirst. R=Void, A=Integer. + // SymTableVis pv = + // new SymTableVis(); + // root.accept(pv, 0); + // HashMap symt = pv.symt; + + // // Do type checking. Bottom-up visitor, also inherits from + // // GJDepthFirst. Visit functions return MyTpe (=R), and + // // take a symbol table (HashMap) as + // // argument (=A). You may implement things differently of + // // course! + // TypeCheckSimp ts = new TypeCheckSimp(); + // MyType res = root.accept(ts, symt); + + // // Ugly code not to be inspired from: "my" way of storing + // // type info / typecheck property: if some of my internal + // // structure is empty, then things don't typecheck for + // // me. This is specific to my own implementation. + // if (res != null && res.type_array.size() > 0) + // System.out.println("Program type checked successfully"); + // else + // System.out.println("Type error"); + System.out.println("Type error"); + } + catch (ParseException e) { + System.out.println(e.toString()); + System.exit(1); + } + } +} -- cgit v1.2.3