// $ANTLR start "logicalORExpression" // AS3_ex.g3:2259:1: logicalORExpression : logicalANDExpression (L= LOR logicalANDExpression )* ; public AS3_exParser.logicalORExpression_return logicalORExpression() // throws RecognitionException [1] { AS3_exParser.logicalORExpression_return retval = new AS3_exParser.logicalORExpression_return(); retval.Start = input.LT(1); int logicalORExpression_StartIndex = input.Index(); object root_0 = null; IToken L = null; AS3_exParser.logicalANDExpression_return logicalANDExpression261 = null; AS3_exParser.logicalANDExpression_return logicalANDExpression262 = null; object L_tree=null; try { if ( (state.backtracking > 0) && AlreadyParsedRule(input, 108) ) { return retval; } // AS3_ex.g3:2260:5: ( logicalANDExpression (L= LOR logicalANDExpression )* ) // AS3_ex.g3:2260:9: logicalANDExpression (L= LOR logicalANDExpression )* { root_0 = (object)adaptor.GetNilNode(); PushFollow(FOLLOW_logicalANDExpression_in_logicalORExpression10654); logicalANDExpression261 = logicalANDExpression(); state.followingStackPointer--; if (state.failed) return retval; if ( state.backtracking == 0 ) adaptor.AddChild(root_0, logicalANDExpression261.Tree); // AS3_ex.g3:2260:30: (L= LOR logicalANDExpression )* do { int alt119 = 2; int LA119_0 = input.LA(1); if ( (LA119_0 == LOR) ) { alt119 = 1; } switch (alt119) { case 1 : // AS3_ex.g3:2260:32: L= LOR logicalANDExpression { L=(IToken)Match(input,LOR,FOLLOW_LOR_in_logicalORExpression10660); 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 ) { IndentEmit((CommonToken)L); } PushFollow(FOLLOW_logicalANDExpression_in_logicalORExpression10664); logicalANDExpression262 = logicalANDExpression(); state.followingStackPointer--; if (state.failed) return retval; if ( state.backtracking == 0 ) adaptor.AddChild(root_0, logicalANDExpression262.Tree); if ( state.backtracking == 0 ) { PopIndent(); } } break; default: goto loop119; } } while (true); loop119: ; // Stops C# compiler whining that label 'loop119' has no statements } 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, 108, logicalORExpression_StartIndex); } } return retval; }
// $ANTLR start "logicalORExpression" // AS3_ex.g3:3113:1: logicalORExpression : logicalANDExpression (L= LOR logicalANDExpression )* ; public AS3_exParser.logicalORExpression_return logicalORExpression() // throws RecognitionException [1] { AS3_exParser.logicalORExpression_return retval = new AS3_exParser.logicalORExpression_return(); retval.Start = input.LT(1); int logicalORExpression_StartIndex = input.Index(); object root_0 = null; IToken L = null; AS3_exParser.logicalANDExpression_return logicalANDExpression272 = null; AS3_exParser.logicalANDExpression_return logicalANDExpression273 = null; object L_tree=null; WrapOptions options=mPrinter.getExpressionWrapOptions(); bool pushedWrapInfo=false; try { if ( (state.backtracking > 0) && AlreadyParsedRule(input, 108) ) { return retval; } // AS3_ex.g3:3118:5: ( logicalANDExpression (L= LOR logicalANDExpression )* ) // AS3_ex.g3:3118:9: logicalANDExpression (L= LOR logicalANDExpression )* { root_0 = (object)adaptor.GetNilNode(); if ( state.backtracking == 0 ) { pushedWrapInfo=pushWrapInfo(options, true); } PushFollow(FOLLOW_logicalANDExpression_in_logicalORExpression12006); logicalANDExpression272 = logicalANDExpression(); state.followingStackPointer--; if (state.failed) return retval; if ( state.backtracking == 0 ) adaptor.AddChild(root_0, logicalANDExpression272.Tree); // AS3_ex.g3:3119:30: (L= LOR logicalANDExpression )* do { int alt126 = 2; int LA126_0 = input.LA(1); if ( (LA126_0 == LOR) ) { int LA126_2 = input.LA(2); if ( (synpred257_AS3_ex()) ) { alt126 = 1; } } switch (alt126) { case 1 : // AS3_ex.g3:3119:32: L= LOR logicalANDExpression { L=(IToken)Match(input,LOR,FOLLOW_LOR_in_logicalORExpression12012); 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 ) { indentEmit(L, ASPrettyPrinter.Break_Logical_Ops_code); } PushFollow(FOLLOW_logicalANDExpression_in_logicalORExpression12016); logicalANDExpression273 = logicalANDExpression(); state.followingStackPointer--; if (state.failed) return retval; if ( state.backtracking == 0 ) adaptor.AddChild(root_0, logicalANDExpression273.Tree); if ( state.backtracking == 0 ) { popIndent(); } } break; default: goto loop126; } } while (true); loop126: ; // Stops C# compiler whining that label 'loop126' has no statements if ( state.backtracking == 0 ) { if (pushedWrapInfo) mPrinter.popWrapContext(); } } 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, 108, logicalORExpression_StartIndex); } } return retval; }