All Downloads are FREE. Search and download functionalities are using the official Maven repository.

webit.script.core.Parser Maven / Gradle / Ivy


//----------------------------------------------------
// The following code was generated by CUP v0.12for-WebitScript-only
//----------------------------------------------------

package webit.script.core;

import java.util.ArrayList;
import java.util.List;
import webit.script.core.ast.*;
import webit.script.core.ast.expressions.*;
import webit.script.core.ast.operators.*;
import webit.script.core.ast.statements.*;
import webit.script.exceptions.ParseException;
import webit.script.util.ALU;
import webit.script.util.ClassNameBand;
import webit.script.util.Stack;
import webit.script.util.StatementUtil;

/**
 * 
 * @version Tue Sep 02 12:00:47 CST 2014
 */
public class Parser extends AbstractParser {

    @SuppressWarnings("unchecked")
    final Object doAction(int actionId) throws ParseException {
        final Stack myStack = this.symbolStack;

        switch (actionId){
            case 1: // $START ::= templateAST EOF 
            {
                /* ACCEPT */
                this.goonParse = false;
                return myStack.peek(1).value;
            }
            case 163: // funcExecuteExpr ::= expression AT contextValueExpr LPAREN expressionList RPAREN 
            {
                Symbol funcExprSymbol = myStack.peek(3);
                return new MethodExecute((Expression) funcExprSymbol.value, ((ExpressionList) myStack.peek(1).value).addFirst((Expression) myStack.peek(5).value).toArray(), funcExprSymbol.line, funcExprSymbol.column);
            }
            case 162: // funcExecuteExpr ::= expression LPAREN expressionList RPAREN 
            {
                Symbol funcExprSymbol = myStack.peek(3);
                return new MethodExecute((Expression) funcExprSymbol.value, ((ExpressionList) myStack.peek(1).value).toArray(), funcExprSymbol.line, funcExprSymbol.column);
            }
            case 9: // identiferList ::= identiferList COMMA IDENTIFIER 
            {
                Symbol identSymbol = myStack.peek(0);
                return ((IdentiferList) myStack.peek(2).value).add((String) identSymbol.value, identSymbol.line, identSymbol.column);
            }
            case 51: // importPart2 ::= importPart1 IDENTIFIER 
            {
                Symbol identSymbol = myStack.peek(0);
                return ((ImportPart) myStack.peek(1).value).append((String) identSymbol.value, createContextValue(0, (String) identSymbol.value, identSymbol.line, identSymbol.column));
            }
            case 53: // importPart2 ::= importPart2 COMMA IDENTIFIER 
            {
                Symbol identSymbol = myStack.peek(0);
                return ((ImportPart) myStack.peek(2).value).append((String) identSymbol.value, createContextValue(0, (String) identSymbol.value, identSymbol.line, identSymbol.column));
            }
            case 46: // varPart ::= varPart COMMA IDENTIFIER 
            {
                Symbol identSymbol = myStack.peek(0);
                return ((StatementList) myStack.peek(2).value).add(declearVar((String) identSymbol.value,identSymbol.line,identSymbol.column));
            }
            case 143: // contextValueExpr ::= superCount IDENTIFIER 
            {
                Symbol identSymbol = myStack.peek(0);
                return createContextValue((Integer) myStack.peek(1).value, (String) identSymbol.value, identSymbol.line, identSymbol.column);
            }
            case 146: // contextValueExpr ::= superCount FOR DOT IDENTIFIER 
            {
                Symbol identSymbol = myStack.peek(0);
                return createContextValue((Integer) myStack.peek(3).value, ("for." + (String) identSymbol.value), identSymbol.line, identSymbol.column);
            }
            case 145: // contextValueExpr ::= FOR DOT IDENTIFIER 
            {
                Symbol identSymbol = myStack.peek(0);
                return createContextValue(0, ("for." + (String) identSymbol.value), identSymbol.line, identSymbol.column);
            }
            case 141: // contextValueExpr ::= IDENTIFIER 
            {
                Symbol identSymbol = myStack.peek(0);
                return createContextValue(0, (String) identSymbol.value, identSymbol.line, identSymbol.column);
            }
            case 144: // contextValueExpr ::= superCount THIS DOT IDENTIFIER 
            {
                Symbol identSymbol = myStack.peek(0);
                return createContextValueAtUpstair((Integer) myStack.peek(3).value, (String) identSymbol.value, identSymbol.line, identSymbol.column);
            }
            case 142: // contextValueExpr ::= THIS DOT IDENTIFIER 
            {
                Symbol identSymbol = myStack.peek(0);
                return createContextValueAtUpstair(0, (String) identSymbol.value, identSymbol.line, identSymbol.column);
            }
            case 8: // identiferList ::= IDENTIFIER 
            {
                Symbol identSymbol = myStack.peek(0);
                return new IdentiferList().add((String) identSymbol.value, identSymbol.line, identSymbol.column);
            }
            case 44: // varPart ::= VAR IDENTIFIER 
            {
                Symbol identSymbol = myStack.peek(0);
                return new StatementList().add(declearVar((String) identSymbol.value,identSymbol.line,identSymbol.column));
            }
            case 65: // lambdaForHead1 ::= FOR LPAREN IDENTIFIER MINUSGT 
            case 168: // lambdaExprHead ::= IDENTIFIER MINUSGT 
            {
                Symbol identSymbol = myStack.peek(1);
                Symbol symSymbol = myStack.peek(0);
                return new LambdaPart(this.varmgr, symSymbol.line, symSymbol.column).appendArg((String) identSymbol.value, identSymbol.line, identSymbol.column);
            }
            case 42: // varAssign ::= IDENTIFIER EQ expression 
            case 43: // varAssign ::= IDENTIFIER EQ varAssign 
            {
                Symbol identSymbol = myStack.peek(2);
                Symbol symSymbol = myStack.peek(1);
                return new Assign(createContextValue((String) identSymbol.value, identSymbol.line, identSymbol.column), (Expression) myStack.peek(0).value, symSymbol.line, symSymbol.column);
            }
            case 157: // funcStatementHead ::= FUNCTION IDENTIFIER LPAREN RPAREN 
            {
                Symbol identSymbol = myStack.peek(2);
                return new FunctionDeclarePart((String) identSymbol.value, this.varmgr, identSymbol.line, identSymbol.column);
            }
            case 25: // statement ::= CONST IDENTIFIER EQ expression SEMICOLON 
            {
                Symbol identSymbol = myStack.peek(3);
                assignConst((String) identSymbol.value, (Expression) myStack.peek(1).value, identSymbol.line, identSymbol.column); return NoneStatement.INSTANCE;
            }
            case 158: // funcStatementHead ::= FUNCTION IDENTIFIER LPAREN identiferList RPAREN 
            {
                Symbol identSymbol = myStack.peek(3);
                return new FunctionDeclarePart((String) identSymbol.value, this.varmgr, identSymbol.line, identSymbol.column).appendArgs((IdentiferList) myStack.peek(1).value);
            }
            case 169: // lambdaExprHead ::= LPAREN IDENTIFIER COMMA identiferList RPAREN MINUSGT 
            {
                Symbol identSymbol = myStack.peek(4);
                Symbol symSymbol = myStack.peek(0);
                return new LambdaPart(this.varmgr, symSymbol.line, symSymbol.column).appendArg((String) identSymbol.value, identSymbol.line, identSymbol.column).appendArgs((IdentiferList) myStack.peek(2).value);
            }
            case 66: // lambdaForMapHead1 ::= FOR LPAREN IDENTIFIER COMMA IDENTIFIER MINUSGT 
            {
                Symbol keySymbol = myStack.peek(3);
                Symbol valueSymbol = myStack.peek(1);
                Symbol symSymbol = myStack.peek(0);
                return new LambdaPart(this.varmgr, symSymbol.line, symSymbol.column).appendArg((String) keySymbol.value, keySymbol.line, keySymbol.column).appendArg((String) valueSymbol.value, valueSymbol.line, valueSymbol.column);
            }
            case 165: // classNameList1 ::= classNameList1 COMMA className 
            {
                Symbol listSymbol = myStack.peek(2);
                Symbol nameBandSymbol = myStack.peek(0);
                ((List) listSymbol.value).add(toClass((ClassNameBand) nameBandSymbol.value, nameBandSymbol.line, nameBandSymbol.column)); return (List) listSymbol.value;
            }
            case 164: // classNameList1 ::= className 
            {
                Symbol nameBandSymbol = myStack.peek(0);
                List list = new ArrayList(); list.add(toClass((ClassNameBand) nameBandSymbol.value, nameBandSymbol.line, nameBandSymbol.column)); return list;
            }
            case 134: // expression ::= NATIVE classPureName 
            {
                Symbol nameBandSymbol = myStack.peek(0);
                return createNativeStaticValue((ClassNameBand) nameBandSymbol.value, nameBandSymbol.line, nameBandSymbol.column);
            }
            case 26: // statement ::= varPart SEMICOLON 
            {
                Symbol partSymbol = myStack.peek(1);
                return ((StatementList) partSymbol.value).popStatementGroup(partSymbol.line, partSymbol.column);
            }
            case 67: // lambdaForHead2 ::= lambdaForHead1 expression COLON 
            {
                Symbol partSymbol = myStack.peek(2);
                return new ForInPart(((LambdaPart) partSymbol.value).getArg(0), ((LambdaPart) partSymbol.value).popFunctionDeclare((Expression) myStack.peek(1).value), this.varmgr, partSymbol.line, partSymbol.column);
            }
            case 69: // lambdaForHead2 ::= lambdaForMapHead1 expression COLON 
            {
                Symbol partSymbol = myStack.peek(2);
                return new ForMapPart(((LambdaPart) partSymbol.value).getArg(0), ((LambdaPart) partSymbol.value).getArg(1), ((LambdaPart) partSymbol.value).popFunctionDeclare((Expression) myStack.peek(1).value), this.varmgr, partSymbol.line, partSymbol.column);
            }
            case 68: // lambdaForHead2 ::= lambdaForHead1 LBRACE statementList RBRACE COLON 
            {
                Symbol partSymbol = myStack.peek(4);
                return new ForInPart(((LambdaPart) partSymbol.value).getArg(0), ((LambdaPart) partSymbol.value).popFunctionDeclare((StatementList) myStack.peek(2).value), this.varmgr, partSymbol.line, partSymbol.column);
            }
            case 70: // lambdaForHead2 ::= lambdaForMapHead1 LBRACE statementList RBRACE COLON 
            {
                Symbol partSymbol = myStack.peek(4);
                return new ForMapPart(((LambdaPart) partSymbol.value).getArg(0), ((LambdaPart) partSymbol.value).getArg(1), ((LambdaPart) partSymbol.value).popFunctionDeclare((StatementList) myStack.peek(2).value), this.varmgr, partSymbol.line, partSymbol.column);
            }
            case 81: // caseBlockStat ::= blockPrepare 
            {
                Symbol prepareSymbol = myStack.peek(0);
                return new StatementList().popIBlock(varmgr.pop(), prepareSymbol.line, prepareSymbol.column);
            }
            case 80: // caseBlockStat ::= blockPrepare statementList 
            {
                Symbol prepareSymbol = myStack.peek(1);
                return ((StatementList) myStack.peek(0).value).popIBlock(varmgr.pop(), prepareSymbol.line, prepareSymbol.column);
            }
            case 58: // block ::= blockPrepare2 RBRACE 
            {
                Symbol prepareSymbol = myStack.peek(1);
                return new StatementList().popIBlock(varmgr.pop(), prepareSymbol.line, prepareSymbol.column);
            }
            case 57: // block ::= blockPrepare2 statementList RBRACE 
            {
                Symbol prepareSymbol = myStack.peek(2);
                return ((StatementList) myStack.peek(1).value).popIBlock(varmgr.pop(), prepareSymbol.line, prepareSymbol.column);
            }
            case 12: // statement ::= LRDEBUG 
            {
                Symbol symSymbol = myStack.peek(0);
                return createBreakPointStatement(null, null, symSymbol.line, symSymbol.column);
            }
            case 24: // statement ::= TEXT_STATEMENT 
            {
                Symbol symSymbol = myStack.peek(0);
                return createTextStatement((char[]) symSymbol.value, symSymbol.line, symSymbol.column);
            }
            case 126: // expression ::= DIRECT_VALUE 
            {
                Symbol symSymbol = myStack.peek(0);
                return new DirectValue((Object) symSymbol.value, symSymbol.line, symSymbol.column);
            }
            case 159: // funcHead ::= FUNCTION 
            {
                Symbol symSymbol = myStack.peek(0);
                return new FunctionDeclarePart(this.varmgr, symSymbol.line, symSymbol.column);
            }
            case 92: // expression_statementable ::= expression MINUSMINUS 
            {
                Symbol symSymbol = myStack.peek(0);
                return new MinusMinusAfter(castToResetableValueExpression((Expression) myStack.peek(1).value), symSymbol.line, symSymbol.column);
            }
            case 90: // expression_statementable ::= expression PLUSPLUS 
            {
                Symbol symSymbol = myStack.peek(0);
                return new PlusPlusAfter(castToResetableValueExpression((Expression) myStack.peek(1).value), symSymbol.line, symSymbol.column);
            }
            case 99: // expression ::= COMP expression 
            {
                Symbol symSymbol = myStack.peek(1);
                return StatementUtil.optimize(new BitNot((Expression) myStack.peek(0).value, symSymbol.line, symSymbol.column));
            }
            case 100: // expression ::= MINUS expression 
            {
                Symbol symSymbol = myStack.peek(1);
                return StatementUtil.optimize(new Negative((Expression) myStack.peek(0).value, symSymbol.line, symSymbol.column));
            }
            case 101: // expression ::= NOT expression 
            {
                Symbol symSymbol = myStack.peek(1);
                return StatementUtil.optimize(new Not((Expression) myStack.peek(0).value, symSymbol.line, symSymbol.column));
            }
            case 104: // expression ::= expression MULT expression 
            case 105: // expression ::= expression DIV expression 
            case 106: // expression ::= expression MOD expression 
            case 107: // expression ::= expression PLUS expression 
            case 108: // expression ::= expression MINUS expression 
            case 109: // expression ::= expression LSHIFT expression 
            case 110: // expression ::= expression RSHIFT expression 
            case 111: // expression ::= expression URSHIFT expression 
            case 112: // expression ::= expression LT expression 
            case 113: // expression ::= expression LTEQ expression 
            case 114: // expression ::= expression GT expression 
            case 115: // expression ::= expression GTEQ expression 
            case 116: // expression ::= expression EQEQ expression 
            case 117: // expression ::= expression NOTEQ expression 
            case 118: // expression ::= expression AND expression 
            case 119: // expression ::= expression OR expression 
            case 120: // expression ::= expression XOR expression 
            case 121: // expression ::= expression ANDAND expression 
            case 122: // expression ::= expression DOTDOT expression 
            case 123: // expression ::= expression OROR expression 
            case 124: // expression ::= expression QUESTION_COLON expression 
            {
                Symbol symSymbol = myStack.peek(1);
                return createBinaryOperator((Expression) myStack.peek(2).value, (Integer) symSymbol.value, (Expression) myStack.peek(0).value, symSymbol.line, symSymbol.column);
            }
            case 93: // expression_statementable ::= expression SELFEQ expression 
            {
                Symbol symSymbol = myStack.peek(1);
                return createSelfOperator((Expression) myStack.peek(2).value, (Integer) symSymbol.value, (Expression) myStack.peek(0).value, symSymbol.line, symSymbol.column);
            }
            case 88: // expression_statementable ::= expression EQ expression 
            {
                Symbol symSymbol = myStack.peek(1);
                return new Assign(castToResetableValueExpression((Expression) myStack.peek(2).value), (Expression) myStack.peek(0).value, symSymbol.line, symSymbol.column);
            }
            case 29: // statement ::= BREAK SEMICOLON 
            {
                Symbol symSymbol = myStack.peek(1);
                return new Break(0, symSymbol.line, symSymbol.column);
            }
            case 31: // statement ::= CONTINUE SEMICOLON 
            {
                Symbol symSymbol = myStack.peek(1);
                return new Continue(0, symSymbol.line, symSymbol.column);
            }
            case 48: // importPart1 ::= IMPORT expression 
            {
                Symbol symSymbol = myStack.peek(1);
                return new ImportPart((Expression) myStack.peek(0).value, symSymbol.line, symSymbol.column);
            }
            case 156: // mapValue ::= LBRACE RBRACE 
            {
                Symbol symSymbol = myStack.peek(1);
                return new MapValue(new Object[0], new Expression[0], symSymbol.line,symSymbol.column);
            }
            case 91: // expression_statementable ::= MINUSMINUS expression 
            {
                Symbol symSymbol = myStack.peek(1);
                return new MinusMinusBefore(castToResetableValueExpression((Expression) myStack.peek(0).value), symSymbol.line, symSymbol.column);
            }
            case 89: // expression_statementable ::= PLUSPLUS expression 
            {
                Symbol symSymbol = myStack.peek(1);
                return new PlusPlusBefore(castToResetableValueExpression((Expression) myStack.peek(0).value), symSymbol.line, symSymbol.column);
            }
            case 102: // expression ::= expression DOT IDENTIFIER 
            {
                Symbol symSymbol = myStack.peek(1);
                return new PropertyOperator((Expression) myStack.peek(2).value, (String) myStack.peek(0).value, symSymbol.line, symSymbol.column);
            }
            case 94: // expression_statementable ::= funcExecuteExpr EQGT expression 
            {
                Symbol symSymbol = myStack.peek(1);
                return new RedirectOutExpression((Expression) myStack.peek(2).value, castToResetableValueExpression((Expression) myStack.peek(0).value), symSymbol.line, symSymbol.column);
            }
            case 33: // statement ::= RETURN SEMICOLON 
            {
                Symbol symSymbol = myStack.peek(1);
                return new Return(null, symSymbol.line, symSymbol.column);
            }
            case 28: // statement ::= NATIVE_IMPORT classPureName SEMICOLON 
            {
                Symbol symSymbol = myStack.peek(2);
                registClass((ClassNameBand) myStack.peek(1).value, symSymbol.line, symSymbol.column); return NoneStatement.INSTANCE;
            }
            case 155: // mapValue ::= LBRACE mapValuePart RBRACE 
            {
                Symbol symSymbol = myStack.peek(2);
                return ((MapValuePart) myStack.peek(1).value).pop(symSymbol.line, symSymbol.column);
            }
            case 97: // expression ::= LDEBUG expression RDEBUG 
            {
                Symbol symSymbol = myStack.peek(2);
                return createBreakPointExpression(null, (Expression) myStack.peek(1).value, symSymbol.line, symSymbol.column);
            }
            case 130: // expression ::= LBRACK expressionList RBRACK 
            {
                Symbol symSymbol = myStack.peek(2);
                return new ArrayValue(((ExpressionList) myStack.peek(1).value).toArray(), symSymbol.line, symSymbol.column);
            }
            case 30: // statement ::= BREAK IDENTIFIER SEMICOLON 
            {
                Symbol symSymbol = myStack.peek(2);
                return new Break(getLabelIndex((String) myStack.peek(1).value), symSymbol.line, symSymbol.column);
            }
            case 32: // statement ::= CONTINUE IDENTIFIER SEMICOLON 
            {
                Symbol symSymbol = myStack.peek(2);
                return new Continue(getLabelIndex((String) myStack.peek(1).value), symSymbol.line, symSymbol.column);
            }
            case 27: // statement ::= ECHO expression SEMICOLON 
            {
                Symbol symSymbol = myStack.peek(2);
                return new Echo((Expression) myStack.peek(1).value, symSymbol.line, symSymbol.column);
            }
            case 160: // funcHead ::= FUNCTION LPAREN RPAREN 
            {
                Symbol symSymbol = myStack.peek(2);
                return new FunctionDeclarePart(this.varmgr, symSymbol.line, symSymbol.column);
            }
            case 49: // importPart1 ::= IMPORT expression mapValue 
            {
                Symbol symSymbol = myStack.peek(2);
                return new ImportPart((Expression) myStack.peek(1).value, (MapValue) myStack.peek(0).value, symSymbol.line, symSymbol.column);
            }
            case 37: // statement ::= INCLUDE expression SEMICOLON 
            {
                Symbol symSymbol = myStack.peek(2);
                return new Include((Expression) myStack.peek(1).value, null, this.template, symSymbol.line, symSymbol.column);
            }
            case 103: // expression ::= expression LBRACK expression RBRACK 
            {
                Symbol symSymbol = myStack.peek(2);
                return new IndexOperator((Expression) myStack.peek(3).value, (Expression) myStack.peek(1).value, symSymbol.line, symSymbol.column);
            }
            case 23: // statement ::= block EQGT expression SEMICOLON 
            {
                Symbol symSymbol = myStack.peek(2);
                return new RedirectOut((IBlock) myStack.peek(3).value, castToResetableValueExpression((Expression) myStack.peek(1).value), symSymbol.line, symSymbol.column);
            }
            case 34: // statement ::= RETURN expression SEMICOLON 
            {
                Symbol symSymbol = myStack.peek(2);
                return new Return((Expression) myStack.peek(1).value, symSymbol.line, symSymbol.column);
            }
            case 131: // expression ::= NATIVE LBRACK RBRACK className 
            {
                Symbol symSymbol = myStack.peek(3);
                Symbol nameBandSymbol = myStack.peek(0);
                return this.createNativeNewArrayDeclareExpression(toClass((ClassNameBand) nameBandSymbol.value, nameBandSymbol.line, nameBandSymbol.column), symSymbol.line, symSymbol.column);
            }
            case 132: // expression ::= NATIVE LBRACK className RBRACK 
            {
                Symbol symSymbol = myStack.peek(3);
                Symbol nameBandSymbol = myStack.peek(1);
                return this.createNativeNewArrayDeclareExpression(toClass((ClassNameBand) nameBandSymbol.value, nameBandSymbol.line, nameBandSymbol.column), symSymbol.line, symSymbol.column);
            }
            case 85: // switchPart0 ::= DEFAULT COLON caseBlockStat switchPart0 
            {
                Symbol symSymbol = myStack.peek(3);
                return ((SwitchPart) myStack.peek(0).value).appendCase(null, (IBlock) myStack.peek(1).value, symSymbol.line, symSymbol.column);
            }
            case 13: // statement ::= LDEBUG IDENTIFIER COLON RDEBUG 
            {
                Symbol symSymbol = myStack.peek(3);
                return createBreakPointStatement((String) myStack.peek(2).value, null, symSymbol.line, symSymbol.column);
            }
            case 161: // funcHead ::= FUNCTION LPAREN identiferList RPAREN 
            {
                Symbol symSymbol = myStack.peek(3);
                return new FunctionDeclarePart(this.varmgr, symSymbol.line, symSymbol.column).appendArgs((IdentiferList) myStack.peek(1).value);
            }
            case 125: // expression ::= expression QUESTION expression COLON expression 
            {
                Symbol symSymbol = myStack.peek(3);
                return new IfOperator((Expression) myStack.peek(4).value, (Expression) myStack.peek(2).value, (Expression) myStack.peek(0).value, symSymbol.line, symSymbol.column);
            }
            case 38: // statement ::= INCLUDE expression mapValue SEMICOLON 
            {
                Symbol symSymbol = myStack.peek(3);
                return new Include((Expression) myStack.peek(2).value, (MapValue) myStack.peek(1).value, this.template, symSymbol.line, symSymbol.column);
            }
            case 83: // switchPart0 ::= CASE DIRECT_VALUE COLON caseBlockStat switchPart0 
            {
                Symbol symSymbol = myStack.peek(4);
                return ((SwitchPart) myStack.peek(0).value).appendCase((Object) myStack.peek(3).value, (IBlock) myStack.peek(1).value, symSymbol.line, symSymbol.column);
            }
            case 98: // expression ::= LDEBUG IDENTIFIER COLON expression RDEBUG 
            {
                Symbol symSymbol = myStack.peek(4);
                return createBreakPointExpression((String) myStack.peek(3).value, (Expression) myStack.peek(1).value, symSymbol.line, symSymbol.column);
            }
            case 59: // ifPart ::= IF LPAREN expression RPAREN block 
            {
                Symbol symSymbol = myStack.peek(4);
                return new IfPart((Expression) myStack.peek(2).value, (IBlock) myStack.peek(0).value, symSymbol.line, symSymbol.column);
            }
            case 50: // importPart1 ::= IMPORT expression LBRACE expression RBRACE 
            {
                Symbol symSymbol = myStack.peek(4);
                return new ImportPart((Expression) myStack.peek(3).value, (Expression) myStack.peek(1).value, symSymbol.line, symSymbol.column);
            }
            case 78: // whilePart ::= WHILE LPAREN expression RPAREN block 
            {
                Symbol symSymbol = myStack.peek(4);
                return new WhilePart((Expression) myStack.peek(2).value, (IBlock) myStack.peek(0).value, true, symSymbol.line, symSymbol.column);
            }
            case 135: // expression ::= NATIVE NEW classPureName LPAREN classNameList RPAREN 
            {
                Symbol symSymbol = myStack.peek(5);
                Symbol nameBandSymbol = myStack.peek(3);
                return this.createNativeConstructorDeclareExpression(toClass((ClassNameBand) nameBandSymbol.value, nameBandSymbol.line, nameBandSymbol.column), (List) myStack.peek(1).value, symSymbol.line, symSymbol.column);
            }
            case 84: // switchPart0 ::= CASE MINUS DIRECT_VALUE COLON caseBlockStat switchPart0 
            {
                Symbol symSymbol = myStack.peek(5);
                return ((SwitchPart) myStack.peek(0).value).appendCase(ALU.negative((Object) myStack.peek(3).value), (IBlock) myStack.peek(1).value, symSymbol.line, symSymbol.column);
            }
            case 63: // forInHead ::= FOR LPAREN IDENTIFIER COLON expression RPAREN 
            {
                Symbol symSymbol = myStack.peek(5);
                return new ForInPart((String) myStack.peek(3).value, (Expression) myStack.peek(1).value, this.varmgr, symSymbol.line, symSymbol.column);
            }
            case 39: // statement ::= INCLUDE expression LBRACE expression RBRACE SEMICOLON 
            {
                Symbol symSymbol = myStack.peek(5);
                return new Include((Expression) myStack.peek(4).value, (Expression) myStack.peek(2).value, this.template, symSymbol.line, symSymbol.column);
            }
            case 133: // expression ::= NATIVE classPureName DOT IDENTIFIER LPAREN classNameList RPAREN 
            {
                Symbol symSymbol = myStack.peek(6);
                Symbol nameBandSymbol = myStack.peek(5);
                return this.createNativeMethodDeclareExpression(toClass((ClassNameBand) nameBandSymbol.value, nameBandSymbol.line, nameBandSymbol.column), (String) myStack.peek(3).value, (List) myStack.peek(1).value, symSymbol.line, symSymbol.column);
            }
            case 86: // switchPart ::= SWITCH LPAREN expression RPAREN LBRACE switchPart0 RBRACE 
            {
                Symbol symSymbol = myStack.peek(6);
                return ((SwitchPart) myStack.peek(1).value).setSwitchExpr((Expression) myStack.peek(4).value, symSymbol.line, symSymbol.column);
            }
            case 79: // whilePart ::= DO block WHILE LPAREN expression RPAREN SEMICOLON 
            {
                Symbol symSymbol = myStack.peek(6);
                return new WhilePart((Expression) myStack.peek(2).value, (IBlock) myStack.peek(5).value, false, symSymbol.line, symSymbol.column);
            }
            case 87: // switchPart ::= SWITCH LPAREN expression RPAREN LBRACE TEXT_STATEMENT switchPart0 RBRACE 
            {
                Symbol symSymbol = myStack.peek(7);
                return ((SwitchPart) myStack.peek(1).value).setSwitchExpr((Expression) myStack.peek(5).value, symSymbol.line, symSymbol.column);
            }
            case 64: // forInHead ::= FOR LPAREN IDENTIFIER COMMA IDENTIFIER COLON expression RPAREN 
            {
                Symbol symSymbol = myStack.peek(7);
                return new ForMapPart((String) myStack.peek(5).value, (String) myStack.peek(3).value, (Expression) myStack.peek(1).value, this.varmgr, symSymbol.line, symSymbol.column);
            }
            case 21: // statement ::= forInPart 
                return ((AbstractForInPart) myStack.peek(0).value).pop();
            case 22: // statement ::= IDENTIFIER COLON forInPart 
                return ((AbstractForInPart) myStack.peek(0).value).pop(getLabelIndex((String) myStack.peek(2).value));
            case 71: // lambdaForHead ::= lambdaForHead2 expression RPAREN 
                return ((AbstractForInPart) myStack.peek(2).value).setCollectionExpr((Expression) myStack.peek(1).value);
            case 77: // forInPart ::= forInBody ELSE block 
                return ((AbstractForInPart) myStack.peek(2).value).setElse((IBlock) myStack.peek(0).value);
            case 73: // forInBody ::= forInHead LBRACE RBRACE 
            case 75: // forInBody ::= lambdaForHead LBRACE RBRACE 
                return ((AbstractForInPart) myStack.peek(2).value).setStatementList(new StatementList());
            case 72: // forInBody ::= forInHead LBRACE statementList RBRACE 
            case 74: // forInBody ::= lambdaForHead LBRACE statementList RBRACE 
                return ((AbstractForInPart) myStack.peek(3).value).setStatementList((StatementList) myStack.peek(1).value);
            case 5: // classPureName ::= classPureName DOT IDENTIFIER 
                return ((ClassNameBand) myStack.peek(2).value).append((String) myStack.peek(0).value);
            case 7: // className ::= className LBRACK RBRACK 
                return ((ClassNameBand) myStack.peek(2).value).plusArrayDepth();
            case 148: // expressionList1 ::= expressionList1 COMMA expression 
                return ((ExpressionList) myStack.peek(2).value).add((Expression) myStack.peek(0).value);
            case 41: // statement ::= funcStatementHead LBRACE RBRACE 
            case 129: // expression ::= funcHead LBRACE RBRACE 
                return ((FunctionDeclarePart) myStack.peek(2).value).pop(new StatementList());
            case 40: // statement ::= funcStatementHead LBRACE statementList RBRACE 
            case 128: // expression ::= funcHead LBRACE statementList RBRACE 
                return ((FunctionDeclarePart) myStack.peek(3).value).pop((StatementList) myStack.peek(1).value);
            case 60: // ifStat ::= ifPart 
                return ((IfPart) myStack.peek(0).value).pop();
            case 61: // ifStat ::= ifPart ELSE block 
                return ((IfPart) myStack.peek(2).value).pop((IBlock) myStack.peek(0).value);
            case 62: // ifStat ::= ifPart ELSE ifStat 
                return ((IfPart) myStack.peek(2).value).pop((Statement) myStack.peek(0).value);
            case 35: // statement ::= importPart1 SEMICOLON 
            case 36: // statement ::= importPart2 SEMICOLON 
                return ((ImportPart) myStack.peek(1).value).pop(this.template);
            case 52: // importPart2 ::= importPart1 contextValueExpr EQ IDENTIFIER 
                return ((ImportPart) myStack.peek(3).value).append((String) myStack.peek(0).value, (Expression) myStack.peek(2).value);
            case 54: // importPart2 ::= importPart2 COMMA contextValueExpr EQ IDENTIFIER 
                return ((ImportPart) myStack.peek(4).value).append((String) myStack.peek(0).value, (Expression) myStack.peek(2).value);
            case 170: // lambdaExpr ::= lambdaExprHead expression 
                return ((LambdaPart) myStack.peek(1).value).pop((Expression) myStack.peek(0).value);
            case 171: // lambdaExpr ::= lambdaExprHead LBRACE statementList RBRACE 
                return ((LambdaPart) myStack.peek(3).value).pop((StatementList) myStack.peek(1).value);
            case 153: // mapValuePart ::= mapValuePart COMMA DIRECT_VALUE COLON expression 
                return ((MapValuePart) myStack.peek(4).value).add((Object) myStack.peek(2).value, (Expression) myStack.peek(0).value);
            case 154: // mapValuePart ::= mapValuePart COMMA MINUS DIRECT_VALUE COLON expression 
                return ((MapValuePart) myStack.peek(5).value).add(ALU.negative((Object) myStack.peek(2).value), (Expression) myStack.peek(0).value);
            case 0: // templateAST ::= statementList 
                return ((StatementList) myStack.peek(0).value).popTemplateAST(varmgr);
            case 3: // statementList ::= statementList statement 
                return ((StatementList) myStack.peek(1).value).add((Statement) myStack.peek(0).value);
            case 47: // varPart ::= varPart COMMA varAssign 
                return ((StatementList) myStack.peek(2).value).add((Expression) myStack.peek(0).value);
            case 17: // statement ::= switchPart 
                return ((SwitchPart) myStack.peek(0).value).pop();
            case 18: // statement ::= IDENTIFIER COLON switchPart 
                return ((SwitchPart) myStack.peek(0).value).pop(getLabelIndex((String) myStack.peek(2).value));
            case 19: // statement ::= whilePart 
                return ((WhilePart) myStack.peek(0).value).pop();
            case 20: // statement ::= IDENTIFIER COLON whilePart 
                return ((WhilePart) myStack.peek(0).value).pop(getLabelIndex((String) myStack.peek(2).value));
            case 140: // superCount ::= superCount SUPER DOT 
                return (Integer) myStack.peek(2).value + 1;
            case 167: // classNameList ::= classNameList1 
                return (List) myStack.peek(0).value;
            case 139: // superCount ::= SUPER DOT 
                return 1;
            case 11: // statement ::= SEMICOLON 
                return NoneStatement.INSTANCE;
            case 14: // statement ::= expression INTERPOLATION_END 
                return createInterpolation((Expression) myStack.peek(1).value);
            case 6: // className ::= classPureName 
            case 15: // statement ::= block 
            case 16: // statement ::= ifStat 
            case 76: // forInPart ::= forInBody 
            case 95: // expression_statementable ::= funcExecuteExpr 
            case 96: // expression ::= expression_statementable 
            case 136: // expression ::= contextValueExpr 
            case 137: // expression ::= mapValue 
            case 138: // expression ::= lambdaExpr 
            case 150: // expressionList ::= expressionList1 
                return myStack.peek(0).value;
            case 10: // statement ::= expression_statementable SEMICOLON 
            case 127: // expression ::= LPAREN expression RPAREN 
                return myStack.peek(1).value;
            case 166: // classNameList ::= 
                return new ArrayList();
            case 4: // classPureName ::= IDENTIFIER 
                return new ClassNameBand((String) myStack.peek(0).value);
            case 147: // expressionList1 ::= expression 
                return new ExpressionList().add((Expression) myStack.peek(0).value);
            case 149: // expressionList ::= 
                return new ExpressionList();
            case 151: // mapValuePart ::= DIRECT_VALUE COLON expression 
                return new MapValuePart().add((Object) myStack.peek(2).value, (Expression) myStack.peek(0).value);
            case 152: // mapValuePart ::= MINUS DIRECT_VALUE COLON expression 
                return new MapValuePart().add(ALU.negative((Object) myStack.peek(2).value), (Expression) myStack.peek(0).value);
            case 45: // varPart ::= VAR varAssign 
                return new StatementList().add((Expression) myStack.peek(0).value);
            case 2: // statementList ::= statement 
                return new StatementList().add((Statement) myStack.peek(0).value);
            case 82: // switchPart0 ::= 
                return new SwitchPart();
            case 55: // blockPrepare ::= 
            case 56: // blockPrepare2 ::= LBRACE 
            {
                varmgr.push(); return null;
            }
            default:
                throw new ParseException("Invalid action id.");
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy