// // Generated by JTB 1.3.2 // package minijava.visitor; import java.util.Enumeration; import minijava.syntaxtree.AllocationExpression; import minijava.syntaxtree.AndExpression; import minijava.syntaxtree.ArrayAllocationExpression; import minijava.syntaxtree.ArrayAssignmentStatement; import minijava.syntaxtree.ArrayLength; import minijava.syntaxtree.ArrayLookup; import minijava.syntaxtree.ArrayType; import minijava.syntaxtree.AssignmentStatement; import minijava.syntaxtree.Block; import minijava.syntaxtree.BooleanType; import minijava.syntaxtree.BracketExpression; import minijava.syntaxtree.ClassDeclaration; import minijava.syntaxtree.ClassExtendsDeclaration; import minijava.syntaxtree.CompareExpression; import minijava.syntaxtree.Expression; import minijava.syntaxtree.ExpressionList; import minijava.syntaxtree.ExpressionRest; import minijava.syntaxtree.FalseLiteral; import minijava.syntaxtree.FormalParameter; import minijava.syntaxtree.FormalParameterList; import minijava.syntaxtree.FormalParameterRest; import minijava.syntaxtree.Goal; import minijava.syntaxtree.Identifier; import minijava.syntaxtree.IfStatement; import minijava.syntaxtree.IntegerLiteral; import minijava.syntaxtree.IntegerType; import minijava.syntaxtree.MainClass; import minijava.syntaxtree.MessageSend; import minijava.syntaxtree.MethodDeclaration; import minijava.syntaxtree.MinusExpression; import minijava.syntaxtree.Node; import minijava.syntaxtree.NodeList; import minijava.syntaxtree.NodeListOptional; import minijava.syntaxtree.NodeOptional; import minijava.syntaxtree.NodeSequence; import minijava.syntaxtree.NodeToken; import minijava.syntaxtree.NotExpression; import minijava.syntaxtree.PlusExpression; import minijava.syntaxtree.PrimaryExpression; import minijava.syntaxtree.PrintStatement; import minijava.syntaxtree.Statement; import minijava.syntaxtree.ThisExpression; import minijava.syntaxtree.TimesExpression; import minijava.syntaxtree.TrueLiteral; import minijava.syntaxtree.Type; import minijava.syntaxtree.TypeDeclaration; import minijava.syntaxtree.VarDeclaration; import minijava.syntaxtree.WhileStatement; /** * Provides default methods which visit each node in the tree in depth-first * order. Your visitors may extend this class. */ public class GJVoidDepthFirst implements GJVoidVisitor { // // Auto class visitors--probably don't need to be overridden. // public void visit(NodeList n, A argu) { int _count=0; for ( Enumeration e = n.elements(); e.hasMoreElements(); ) { e.nextElement().accept(this,argu); _count++; } } public void visit(NodeListOptional n, A argu) { if ( n.present() ) { int _count=0; for ( Enumeration e = n.elements(); e.hasMoreElements(); ) { e.nextElement().accept(this,argu); _count++; } } } public void visit(NodeOptional n, A argu) { if ( n.present() ) n.node.accept(this,argu); } public void visit(NodeSequence n, A argu) { int _count=0; for ( Enumeration e = n.elements(); e.hasMoreElements(); ) { e.nextElement().accept(this,argu); _count++; } } public void visit(NodeToken n, A argu) {} // // User-generated visitor methods below // /** * f0 -> MainClass() * f1 -> ( TypeDeclaration() )* * f2 -> */ public void visit(Goal n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); } /** * f0 -> "class" * f1 -> Identifier() * f2 -> "{" * f3 -> "public" * f4 -> "static" * f5 -> "void" * f6 -> "main" * f7 -> "(" * f8 -> "String" * f9 -> "[" * f10 -> "]" * f11 -> Identifier() * f12 -> ")" * f13 -> "{" * f14 -> PrintStatement() * f15 -> "}" * f16 -> "}" */ public void visit(MainClass n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); n.f3.accept(this, argu); n.f4.accept(this, argu); n.f5.accept(this, argu); n.f6.accept(this, argu); n.f7.accept(this, argu); n.f8.accept(this, argu); n.f9.accept(this, argu); n.f10.accept(this, argu); n.f11.accept(this, argu); n.f12.accept(this, argu); n.f13.accept(this, argu); n.f14.accept(this, argu); n.f15.accept(this, argu); n.f16.accept(this, argu); } /** * f0 -> ClassDeclaration() * | ClassExtendsDeclaration() */ public void visit(TypeDeclaration n, A argu) { n.f0.accept(this, argu); } /** * f0 -> "class" * f1 -> Identifier() * f2 -> "{" * f3 -> ( VarDeclaration() )* * f4 -> ( MethodDeclaration() )* * f5 -> "}" */ public void visit(ClassDeclaration n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); n.f3.accept(this, argu); n.f4.accept(this, argu); n.f5.accept(this, argu); } /** * f0 -> "class" * f1 -> Identifier() * f2 -> "extends" * f3 -> Identifier() * f4 -> "{" * f5 -> ( VarDeclaration() )* * f6 -> ( MethodDeclaration() )* * f7 -> "}" */ public void visit(ClassExtendsDeclaration n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); n.f3.accept(this, argu); n.f4.accept(this, argu); n.f5.accept(this, argu); n.f6.accept(this, argu); n.f7.accept(this, argu); } /** * f0 -> Type() * f1 -> Identifier() * f2 -> ";" */ public void visit(VarDeclaration n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); } /** * f0 -> "public" * f1 -> Type() * f2 -> Identifier() * f3 -> "(" * f4 -> ( FormalParameterList() )? * f5 -> ")" * f6 -> "{" * f7 -> ( VarDeclaration() )* * f8 -> ( Statement() )* * f9 -> "return" * f10 -> Expression() * f11 -> ";" * f12 -> "}" */ public void visit(MethodDeclaration n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); n.f3.accept(this, argu); n.f4.accept(this, argu); n.f5.accept(this, argu); n.f6.accept(this, argu); n.f7.accept(this, argu); n.f8.accept(this, argu); n.f9.accept(this, argu); n.f10.accept(this, argu); n.f11.accept(this, argu); n.f12.accept(this, argu); } /** * f0 -> FormalParameter() * f1 -> ( FormalParameterRest() )* */ public void visit(FormalParameterList n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); } /** * f0 -> Type() * f1 -> Identifier() */ public void visit(FormalParameter n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); } /** * f0 -> "," * f1 -> FormalParameter() */ public void visit(FormalParameterRest n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); } /** * f0 -> ArrayType() * | BooleanType() * | IntegerType() * | Identifier() */ public void visit(Type n, A argu) { n.f0.accept(this, argu); } /** * f0 -> "int" * f1 -> "[" * f2 -> "]" */ public void visit(ArrayType n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); } /** * f0 -> "boolean" */ public void visit(BooleanType n, A argu) { n.f0.accept(this, argu); } /** * f0 -> "int" */ public void visit(IntegerType n, A argu) { n.f0.accept(this, argu); } /** * f0 -> Block() * | AssignmentStatement() * | ArrayAssignmentStatement() * | IfStatement() * | WhileStatement() * | PrintStatement() */ public void visit(Statement n, A argu) { n.f0.accept(this, argu); } /** * f0 -> "{" * f1 -> ( Statement() )* * f2 -> "}" */ public void visit(Block n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); } /** * f0 -> Identifier() * f1 -> "=" * f2 -> Expression() * f3 -> ";" */ public void visit(AssignmentStatement n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); n.f3.accept(this, argu); } /** * f0 -> Identifier() * f1 -> "[" * f2 -> Expression() * f3 -> "]" * f4 -> "=" * f5 -> Expression() * f6 -> ";" */ public void visit(ArrayAssignmentStatement n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); n.f3.accept(this, argu); n.f4.accept(this, argu); n.f5.accept(this, argu); n.f6.accept(this, argu); } /** * f0 -> "if" * f1 -> "(" * f2 -> Expression() * f3 -> ")" * f4 -> Statement() * f5 -> "else" * f6 -> Statement() */ public void visit(IfStatement n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); n.f3.accept(this, argu); n.f4.accept(this, argu); n.f5.accept(this, argu); n.f6.accept(this, argu); } /** * f0 -> "while" * f1 -> "(" * f2 -> Expression() * f3 -> ")" * f4 -> Statement() */ public void visit(WhileStatement n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); n.f3.accept(this, argu); n.f4.accept(this, argu); } /** * f0 -> "System.out.println" * f1 -> "(" * f2 -> Expression() * f3 -> ")" * f4 -> ";" */ public void visit(PrintStatement n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); n.f3.accept(this, argu); n.f4.accept(this, argu); } /** * f0 -> AndExpression() * | CompareExpression() * | PlusExpression() * | MinusExpression() * | TimesExpression() * | ArrayLookup() * | ArrayLength() * | MessageSend() * | PrimaryExpression() */ public void visit(Expression n, A argu) { n.f0.accept(this, argu); } /** * f0 -> PrimaryExpression() * f1 -> "&&" * f2 -> PrimaryExpression() */ public void visit(AndExpression n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); } /** * f0 -> PrimaryExpression() * f1 -> "<" * f2 -> PrimaryExpression() */ public void visit(CompareExpression n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); } /** * f0 -> PrimaryExpression() * f1 -> "+" * f2 -> PrimaryExpression() */ public void visit(PlusExpression n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); } /** * f0 -> PrimaryExpression() * f1 -> "-" * f2 -> PrimaryExpression() */ public void visit(MinusExpression n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); } /** * f0 -> PrimaryExpression() * f1 -> "*" * f2 -> PrimaryExpression() */ public void visit(TimesExpression n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); } /** * f0 -> PrimaryExpression() * f1 -> "[" * f2 -> PrimaryExpression() * f3 -> "]" */ public void visit(ArrayLookup n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); n.f3.accept(this, argu); } /** * f0 -> PrimaryExpression() * f1 -> "." * f2 -> "length" */ public void visit(ArrayLength n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); } /** * f0 -> PrimaryExpression() * f1 -> "." * f2 -> Identifier() * f3 -> "(" * f4 -> ( ExpressionList() )? * f5 -> ")" */ public void visit(MessageSend n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); n.f3.accept(this, argu); n.f4.accept(this, argu); n.f5.accept(this, argu); } /** * f0 -> Expression() * f1 -> ( ExpressionRest() )* */ public void visit(ExpressionList n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); } /** * f0 -> "," * f1 -> Expression() */ public void visit(ExpressionRest n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); } /** * f0 -> IntegerLiteral() * | TrueLiteral() * | FalseLiteral() * | Identifier() * | ThisExpression() * | ArrayAllocationExpression() * | AllocationExpression() * | NotExpression() * | BracketExpression() */ public void visit(PrimaryExpression n, A argu) { n.f0.accept(this, argu); } /** * f0 -> */ public void visit(IntegerLiteral n, A argu) { n.f0.accept(this, argu); } /** * f0 -> "true" */ public void visit(TrueLiteral n, A argu) { n.f0.accept(this, argu); } /** * f0 -> "false" */ public void visit(FalseLiteral n, A argu) { n.f0.accept(this, argu); } /** * f0 -> */ public void visit(Identifier n, A argu) { n.f0.accept(this, argu); } /** * f0 -> "this" */ public void visit(ThisExpression n, A argu) { n.f0.accept(this, argu); } /** * f0 -> "new" * f1 -> "int" * f2 -> "[" * f3 -> Expression() * f4 -> "]" */ public void visit(ArrayAllocationExpression n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); n.f3.accept(this, argu); n.f4.accept(this, argu); } /** * f0 -> "new" * f1 -> Identifier() * f2 -> "(" * f3 -> ")" */ public void visit(AllocationExpression n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); n.f3.accept(this, argu); } /** * f0 -> "!" * f1 -> Expression() */ public void visit(NotExpression n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); } /** * f0 -> "(" * f1 -> Expression() * f2 -> ")" */ public void visit(BracketExpression n, A argu) { n.f0.accept(this, argu); n.f1.accept(this, argu); n.f2.accept(this, argu); } }