public ES3Parser.caseClause_return caseClause() // throws RecognitionException [1]
{
ES3Parser.caseClause_return retval = new ES3Parser.caseClause_return();
retval.Start = input.LT(1);
object root_0 = null;
IToken CASE159 = null;
IToken COLON161 = null;
ES3Parser.expression_return expression160 = default(ES3Parser.expression_return);
ES3Parser.statement_return statement162 = default(ES3Parser.statement_return);
object CASE159_tree=null;
object COLON161_tree=null;
retval.value = new CaseClause();
try
{
// C:\\Users\\s.ros\\Projets\\Jint\\Jint\\ES3.g:1725:2: ( CASE expression COLON ( statement )* )
// C:\\Users\\s.ros\\Projets\\Jint\\Jint\\ES3.g:1725:4: CASE expression COLON ( statement )*
{
root_0 = (object)adaptor.GetNilNode();
CASE159=(IToken)Match(input,CASE,FOLLOW_CASE_in_caseClause6316);
CASE159_tree = (object)adaptor.Create(CASE159);
root_0 = (object)adaptor.BecomeRoot(CASE159_tree, root_0);
PushFollow(FOLLOW_expression_in_caseClause6319);
expression160 = expression();
state.followingStackPointer--;
adaptor.AddChild(root_0, expression160.Tree);
retval.value.Expression = ((expression160 != null) ? expression160.value : default(Expression));
COLON161=(IToken)Match(input,COLON,FOLLOW_COLON_in_caseClause6323);
// C:\\Users\\s.ros\\Projets\\Jint\\Jint\\ES3.g:1725:70: ( statement )*
do
{
int alt79 = 2;
int LA79_0 = input.LA(1);
if ( ((LA79_0 >= NULL && LA79_0 <= BREAK) || LA79_0 == CONTINUE || (LA79_0 >= DELETE && LA79_0 <= DO) || (LA79_0 >= FOR && LA79_0 <= IF) || (LA79_0 >= NEW && LA79_0 <= WITH) || LA79_0 == LBRACE || LA79_0 == LPAREN || LA79_0 == LBRACK || LA79_0 == SEMIC || (LA79_0 >= ADD && LA79_0 <= SUB) || (LA79_0 >= INC && LA79_0 <= DEC) || (LA79_0 >= NOT && LA79_0 <= INV) || (LA79_0 >= Identifier && LA79_0 <= StringLiteral) || LA79_0 == RegularExpressionLiteral || (LA79_0 >= DecimalLiteral && LA79_0 <= HexIntegerLiteral)) )
{
alt79 = 1;
}
switch (alt79)
{
case 1 :
// C:\\Users\\s.ros\\Projets\\Jint\\Jint\\ES3.g:1725:72: statement
{
PushFollow(FOLLOW_statement_in_caseClause6327);
statement162 = statement();
state.followingStackPointer--;
adaptor.AddChild(root_0, statement162.Tree);
retval.value.Statements.Statements.AddLast(((statement162 != null) ? statement162.value : default(Statement)));
}
break;
default:
goto loop79;
}
} while (true);
loop79:
; // Stops C# compiler whining that label 'loop79' has no statements
}
retval.Stop = input.LT(-1);
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
{
}
return retval;
}
// $ANTLR end "caseClause"