package ast.nodes; import ast.types.*; import java.util.ArrayList; import semanticanalysis.SemanticError; import semanticanalysis.SymbolTable; /** * Node for the `simple_stmts` statement of the grammar. */ public class SimpleStmtsNode implements Node { private final ArrayList stmts; public SimpleStmtsNode(ArrayList stmts) { this.stmts = stmts; } @Override public ArrayList checkSemantics(SymbolTable ST, int _nesting, FunctionType ft) { ArrayList errors = new ArrayList<>(); for (Node stmt : stmts) { errors.addAll(stmt.checkSemantics(ST, _nesting, ft)); } return errors; } @Override public Type typeCheck() { return new VoidType(); } @Override public String codeGeneration() { String str = ""; for (Node stmt : stmts) { str += stmt.codeGeneration(); } return str; } @Override public String printAST(String prefix) { String str = prefix + "SimpleStmts\n"; prefix += " "; for (Node stmt : stmts) { str += stmt.printAST(prefix); } return str; } @Override public String toPrint(String prefix) { String str = ""; for (Node stmt : stmts) { str += stmt.toPrint(prefix) + "\n"; } return str; } public ArrayList getStmts() { return stmts; } }