// $ANTLR start "conditionalExpressionNoIn" // AS3_ex.g3:2254:1: conditionalExpressionNoIn : logicalORExpressionNoIn (Q= QUE assignmentExpression C= COLON assignmentExpression )? ; public AS3_exParser.conditionalExpressionNoIn_return conditionalExpressionNoIn() // throws RecognitionException [1] { AS3_exParser.conditionalExpressionNoIn_return retval = new AS3_exParser.conditionalExpressionNoIn_return(); retval.Start = input.LT(1); int conditionalExpressionNoIn_StartIndex = input.Index(); object root_0 = null; IToken Q = null; IToken C = null; AS3_exParser.logicalORExpressionNoIn_return logicalORExpressionNoIn258 = null; AS3_exParser.assignmentExpression_return assignmentExpression259 = null; AS3_exParser.assignmentExpression_return assignmentExpression260 = null; object Q_tree=null; object C_tree=null; try { if ( (state.backtracking > 0) && AlreadyParsedRule(input, 107) ) { return retval; } // AS3_ex.g3:2255:5: ( logicalORExpressionNoIn (Q= QUE assignmentExpression C= COLON assignmentExpression )? ) // AS3_ex.g3:2255:9: logicalORExpressionNoIn (Q= QUE assignmentExpression C= COLON assignmentExpression )? { root_0 = (object)adaptor.GetNilNode(); PushFollow(FOLLOW_logicalORExpressionNoIn_in_conditionalExpressionNoIn10600); logicalORExpressionNoIn258 = logicalORExpressionNoIn(); state.followingStackPointer--; if (state.failed) return retval; if ( state.backtracking == 0 ) adaptor.AddChild(root_0, logicalORExpressionNoIn258.Tree); // AS3_ex.g3:2255:33: (Q= QUE assignmentExpression C= COLON assignmentExpression )? int alt118 = 2; int LA118_0 = input.LA(1); if ( (LA118_0 == QUE) ) { alt118 = 1; } switch (alt118) { case 1 : // AS3_ex.g3:2255:35: Q= QUE assignmentExpression C= COLON assignmentExpression { Q=(IToken)Match(input,QUE,FOLLOW_QUE_in_conditionalExpressionNoIn10606); if (state.failed) return retval; if ( state.backtracking == 0 ) {Q_tree = (object)adaptor.Create(Q); adaptor.AddChild(root_0, Q_tree); } if ( state.backtracking == 0 ) { IndentEmit((CommonToken)Q); } PushFollow(FOLLOW_assignmentExpression_in_conditionalExpressionNoIn10610); assignmentExpression259 = assignmentExpression(); state.followingStackPointer--; if (state.failed) return retval; if ( state.backtracking == 0 ) adaptor.AddChild(root_0, assignmentExpression259.Tree); if ( state.backtracking == 0 ) { PopIndent(); } C=(IToken)Match(input,COLON,FOLLOW_COLON_in_conditionalExpressionNoIn10617); if (state.failed) return retval; if ( state.backtracking == 0 ) {C_tree = (object)adaptor.Create(C); adaptor.AddChild(root_0, C_tree); } if ( state.backtracking == 0 ) { IndentEmit((CommonToken)C); } PushFollow(FOLLOW_assignmentExpression_in_conditionalExpressionNoIn10622); assignmentExpression260 = assignmentExpression(); state.followingStackPointer--; if (state.failed) return retval; if ( state.backtracking == 0 ) adaptor.AddChild(root_0, assignmentExpression260.Tree); if ( state.backtracking == 0 ) { PopIndent(); } } break; } } 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, 107, conditionalExpressionNoIn_StartIndex); } } return retval; }
// $ANTLR start "conditionalExpressionNoIn" // AS3_ex.g3:3102:1: conditionalExpressionNoIn : logicalORExpressionNoIn (Q= QUE assignmentExpression C= COLON assignmentExpression )? ; public AS3_exParser.conditionalExpressionNoIn_return conditionalExpressionNoIn() // throws RecognitionException [1] { AS3_exParser.conditionalExpressionNoIn_return retval = new AS3_exParser.conditionalExpressionNoIn_return(); retval.Start = input.LT(1); int conditionalExpressionNoIn_StartIndex = input.Index(); object root_0 = null; IToken Q = null; IToken C = null; AS3_exParser.logicalORExpressionNoIn_return logicalORExpressionNoIn269 = null; AS3_exParser.assignmentExpression_return assignmentExpression270 = null; AS3_exParser.assignmentExpression_return assignmentExpression271 = null; object Q_tree=null; object C_tree=null; WrapOptions options=mPrinter.getExpressionWrapOptions(); bool pushedWrapInfo=false; try { if ( (state.backtracking > 0) && AlreadyParsedRule(input, 107) ) { return retval; } // AS3_ex.g3:3107:5: ( logicalORExpressionNoIn (Q= QUE assignmentExpression C= COLON assignmentExpression )? ) // AS3_ex.g3:3107:9: logicalORExpressionNoIn (Q= QUE assignmentExpression C= COLON assignmentExpression )? { root_0 = (object)adaptor.GetNilNode(); if ( state.backtracking == 0 ) { pushedWrapInfo=pushWrapInfo(options, true); } PushFollow(FOLLOW_logicalORExpressionNoIn_in_conditionalExpressionNoIn11927); logicalORExpressionNoIn269 = logicalORExpressionNoIn(); state.followingStackPointer--; if (state.failed) return retval; if ( state.backtracking == 0 ) adaptor.AddChild(root_0, logicalORExpressionNoIn269.Tree); // AS3_ex.g3:3108:33: (Q= QUE assignmentExpression C= COLON assignmentExpression )? int alt125 = 2; int LA125_0 = input.LA(1); if ( (LA125_0 == QUE) ) { alt125 = 1; } switch (alt125) { case 1 : // AS3_ex.g3:3108:35: Q= QUE assignmentExpression C= COLON assignmentExpression { Q=(IToken)Match(input,QUE,FOLLOW_QUE_in_conditionalExpressionNoIn11933); if (state.failed) return retval; if ( state.backtracking == 0 ) {Q_tree = (object)adaptor.Create(Q); adaptor.AddChild(root_0, Q_tree); } if ( state.backtracking == 0 ) { indentEmit(Q, ASPrettyPrinter.Break_Ternary_code); } PushFollow(FOLLOW_assignmentExpression_in_conditionalExpressionNoIn11937); assignmentExpression270 = assignmentExpression(); state.followingStackPointer--; if (state.failed) return retval; if ( state.backtracking == 0 ) adaptor.AddChild(root_0, assignmentExpression270.Tree); if ( state.backtracking == 0 ) { popIndent(); } C=(IToken)Match(input,COLON,FOLLOW_COLON_in_conditionalExpressionNoIn11944); if (state.failed) return retval; if ( state.backtracking == 0 ) {C_tree = (object)adaptor.Create(C); adaptor.AddChild(root_0, C_tree); } if ( state.backtracking == 0 ) { indentEmit(C, ASPrettyPrinter.Break_Ternary_code); } PushFollow(FOLLOW_assignmentExpression_in_conditionalExpressionNoIn11949); assignmentExpression271 = assignmentExpression(); state.followingStackPointer--; if (state.failed) return retval; if ( state.backtracking == 0 ) adaptor.AddChild(root_0, assignmentExpression271.Tree); if ( state.backtracking == 0 ) { popIndent(); } } break; } 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, 107, conditionalExpressionNoIn_StartIndex); } } return retval; }