Ejemplo n.º 1
0
    // $ANTLR start "forEachInStatement"
    // AS3_ex.g3:1972:1: forEachInStatement : F= FOR E= EACH L= LPAREN forInControl R= RPAREN statement ;
    public AS3_exParser.forEachInStatement_return forEachInStatement() // throws RecognitionException [1]
    {   
        AS3_exParser.forEachInStatement_return retval = new AS3_exParser.forEachInStatement_return();
        retval.Start = input.LT(1);
        int forEachInStatement_StartIndex = input.Index();
        object root_0 = null;

        IToken F = null;
        IToken E = null;
        IToken L = null;
        IToken R = null;
        AS3_exParser.forInControl_return forInControl187 = null;

        AS3_exParser.statement_return statement188 = null;


        object F_tree=null;
        object E_tree=null;
        object L_tree=null;
        object R_tree=null;

        try 
    	{
    	    if ( (state.backtracking > 0) && AlreadyParsedRule(input, 77) ) 
    	    {
    	    	return retval; 
    	    }
            // AS3_ex.g3:1973:5: (F= FOR E= EACH L= LPAREN forInControl R= RPAREN statement )
            // AS3_ex.g3:1973:9: F= FOR E= EACH L= LPAREN forInControl R= RPAREN statement
            {
            	root_0 = (object)adaptor.GetNilNode();

            	F=(IToken)Match(input,FOR,FOLLOW_FOR_in_forEachInStatement8950); if (state.failed) return retval;
            	if ( state.backtracking == 0 )
            	{F_tree = (object)adaptor.Create(F);
            		adaptor.AddChild(root_0, F_tree);
            	}
            	if ( state.backtracking == 0 ) 
            	{
            	  Emit((CommonToken)F);
            	}
            	if ( state.backtracking == 0 ) 
            	{
            	  PushExpressionIndent();
            	}
            	E=(IToken)Match(input,EACH,FOLLOW_EACH_in_forEachInStatement8968); if (state.failed) return retval;
            	if ( state.backtracking == 0 )
            	{E_tree = (object)adaptor.Create(E);
            		adaptor.AddChild(root_0, E_tree);
            	}
            	if ( state.backtracking == 0 ) 
            	{
            	  Emit((CommonToken)E);InsertWS(mPrinter.GetSpacesBetweenControlKeywordsAndParens());
            	}
            	L=(IToken)Match(input,LPAREN,FOLLOW_LPAREN_in_forEachInStatement8979); if (state.failed) return retval;
            	if ( state.backtracking == 0 )
            	{L_tree = (object)adaptor.Create(L);
            		adaptor.AddChild(root_0, L_tree);
            	}
            	if ( state.backtracking == 0 ) 
            	{
            	  Emit((CommonToken)L);InsertWS(mPrinter.GetAdvancedSpacesInsideParens());
            	}
            	PushFollow(FOLLOW_forInControl_in_forEachInStatement8983);
            	forInControl187 = forInControl();
            	state.followingStackPointer--;
            	if (state.failed) return retval;
            	if ( state.backtracking == 0 ) adaptor.AddChild(root_0, forInControl187.Tree);
            	R=(IToken)Match(input,RPAREN,FOLLOW_RPAREN_in_forEachInStatement8987); if (state.failed) return retval;
            	if ( state.backtracking == 0 )
            	{R_tree = (object)adaptor.Create(R);
            		adaptor.AddChild(root_0, R_tree);
            	}
            	if ( state.backtracking == 0 ) 
            	{
            	  InsertWS(mPrinter.GetAdvancedSpacesInsideParens());Emit((CommonToken)R);
            	}
            	if ( state.backtracking == 0 ) 
            	{
            	  PopIndent();
            	}
            	if ( state.backtracking == 0 ) 
            	{
            	  PushIndent(false);
            	}
            	PushFollow(FOLLOW_statement_in_forEachInStatement8993);
            	statement188 = statement();
            	state.followingStackPointer--;
            	if (state.failed) return retval;
            	if ( state.backtracking == 0 ) adaptor.AddChild(root_0, statement188.Tree);
            	if ( state.backtracking == 0 ) 
            	{
            	  PopIndent();
            	}

            }

            retval.Stop = input.LT(-1);

            if ( state.backtracking==0 )
            {	retval.Tree = (object)adaptor.RulePostProcessing(root_0);
            	adaptor.SetTokenBoundaries(retval.Tree, (IToken) retval.Start, (IToken) retval.Stop);}
        }
        catch (RecognitionException re) 
    	{
            ReportError(re);
            Recover(input,re);
    	// Conversion of the second argument necessary, but harmless
    	retval.Tree = (object)adaptor.ErrorNode(input, (IToken) retval.Start, input.LT(-1), re);

        }
        finally 
    	{
            if ( state.backtracking > 0 ) 
            {
            	Memoize(input, 77, forEachInStatement_StartIndex); 
            }
        }
        return retval;
    }
Ejemplo n.º 2
0
    // $ANTLR start "forEachInStatement"
    // AS3_ex.g3:2599:1: forEachInStatement : F= FOR E= EACH L= LPAREN forInControl R= RPAREN statement ;
    public AS3_exParser.forEachInStatement_return forEachInStatement() // throws RecognitionException [1]
    {   
        AS3_exParser.forEachInStatement_return retval = new AS3_exParser.forEachInStatement_return();
        retval.Start = input.LT(1);
        int forEachInStatement_StartIndex = input.Index();
        object root_0 = null;

        IToken F = null;
        IToken E = null;
        IToken L = null;
        IToken R = null;
        AS3_exParser.forInControl_return forInControl198 = null;

        AS3_exParser.statement_return statement199 = null;


        object F_tree=null;
        object E_tree=null;
        object L_tree=null;
        object R_tree=null;


            int statementStartInOutput=(-1);
            int statementEndInOutput=(-1);
            int statementCount=0;

        try 
        {
            if ( (state.backtracking > 0) && AlreadyParsedRule(input, 77) ) 
            {
                return retval; 
            }
            // AS3_ex.g3:2606:5: (F= FOR E= EACH L= LPAREN forInControl R= RPAREN statement )
            // AS3_ex.g3:2607:5: F= FOR E= EACH L= LPAREN forInControl R= RPAREN statement
            {
                root_0 = (object)adaptor.GetNilNode();

                if ( state.backtracking == 0 ) 
                {
                  mPrinter.markDeclEqualsContextChange();
                }
                F=(IToken)Match(input,FOR,FOLLOW_FOR_in_forEachInStatement9755); if (state.failed) return retval;
                if ( state.backtracking == 0 )
                {F_tree = (object)adaptor.Create(F);
                    adaptor.AddChild(root_0, F_tree);
                }
                if ( state.backtracking == 0 ) 
                {
                  emit(F);statementStartInOutput=mPrinter.getCurrentOutputLength();
                }
                if ( state.backtracking == 0 ) 
                {
                  pushExpressionIndent();
                }
                E=(IToken)Match(input,EACH,FOLLOW_EACH_in_forEachInStatement9773); if (state.failed) return retval;
                if ( state.backtracking == 0 )
                {E_tree = (object)adaptor.Create(E);
                    adaptor.AddChild(root_0, E_tree);
                }
                if ( state.backtracking == 0 ) 
                {
                  emit(E);insertWS(mPrinter.getSpacesBetweenControlKeywordsAndParens());
                }
                L=(IToken)Match(input,LPAREN,FOLLOW_LPAREN_in_forEachInStatement9781); if (state.failed) return retval;
                if ( state.backtracking == 0 )
                {L_tree = (object)adaptor.Create(L);
                    adaptor.AddChild(root_0, L_tree);
                }
                if ( state.backtracking == 0 ) 
                {
                  emit(L);insertWS(mPrinter.getAdvancedSpacesInsideParensInOtherPlaces());
                }
                PushFollow(FOLLOW_forInControl_in_forEachInStatement9785);
                forInControl198 = forInControl();
                state.followingStackPointer--;
                if (state.failed) return retval;
                if ( state.backtracking == 0 ) adaptor.AddChild(root_0, forInControl198.Tree);
                R=(IToken)Match(input,RPAREN,FOLLOW_RPAREN_in_forEachInStatement9789); if (state.failed) return retval;
                if ( state.backtracking == 0 )
                {R_tree = (object)adaptor.Create(R);
                    adaptor.AddChild(root_0, R_tree);
                }
                if ( state.backtracking == 0 ) 
                {
                  insertWS(mPrinter.getAdvancedSpacesInsideParensInOtherPlaces());emit(R);statementEndInOutput=mPrinter.getCurrentOutputLength();
                }
                if ( state.backtracking == 0 ) 
                {
                  popIndent();
                }
                if ( state.backtracking == 0 ) 
                {
                  pushIndent(false);
                }
                if ( state.backtracking == 0 ) 
                {
                  mPrinter.addOpenBrace(input, ASPrettyPrinter.BraceAdd_Loop);
                       mPrinter.captureStatementStart(F, statementStartInOutput);
                       mPrinter.captureStatementEnd(R, statementEndInOutput);
                       statementCount=mStatementCount;
                        
                }
                PushFollow(FOLLOW_statement_in_forEachInStatement9806);
                statement199 = statement();
                state.followingStackPointer--;
                if (state.failed) return retval;
                if ( state.backtracking == 0 ) adaptor.AddChild(root_0, statement199.Tree);
                if ( state.backtracking == 0 ) 
                {
                  mPrinter.addCloseBrace(input.LT(1), ASPrettyPrinter.BraceAdd_Loop, mStatementCount-statementCount);
                }
                if ( state.backtracking == 0 ) 
                {
                  popIndent();
                }

            }

            retval.Stop = input.LT(-1);

            if ( state.backtracking==0 )
            {   retval.Tree = (object)adaptor.RulePostProcessing(root_0);
                adaptor.SetTokenBoundaries(retval.Tree, (IToken) retval.Start, (IToken) retval.Stop);}
        }
        catch (RecognitionException re) 
        {
            ReportError(re);
            Recover(input,re);
        // Conversion of the second argument necessary, but harmless
        retval.Tree = (object)adaptor.ErrorNode(input, (IToken) retval.Start, input.LT(-1), re);

        }
        finally 
        {
            if ( state.backtracking > 0 ) 
            {
                Memoize(input, 77, forEachInStatement_StartIndex); 
            }
        }
        return retval;
    }