public ES3Parser.block_return block() // throws RecognitionException [1]
{
ES3Parser.block_return retval = new ES3Parser.block_return();
retval.Start = input.LT(1);
object root_0 = null;
IToken lb = null;
IToken RBRACE103 = null;
ES3Parser.statement_return statement102 = default(ES3Parser.statement_return);
object lb_tree=null;
object RBRACE103_tree=null;
retval.value = new BlockStatement();
try
{
// C:\\Users\\s.ros\\Projets\\Jint\\Jint\\ES3.g:1451:2: (lb= LBRACE ( statement )* RBRACE )
// C:\\Users\\s.ros\\Projets\\Jint\\Jint\\ES3.g:1451:4: lb= LBRACE ( statement )* RBRACE
{
root_0 = (object)adaptor.GetNilNode();
lb=(IToken)Match(input,LBRACE,FOLLOW_LBRACE_in_block5373);
lb_tree = (object)adaptor.Create(lb);
adaptor.AddChild(root_0, lb_tree);
// C:\\Users\\s.ros\\Projets\\Jint\\Jint\\ES3.g:1451:14: ( statement )*
do
{
int alt59 = 2;
int LA59_0 = input.LA(1);
if ( ((LA59_0 >= NULL && LA59_0 <= BREAK) || LA59_0 == CONTINUE || (LA59_0 >= DELETE && LA59_0 <= DO) || (LA59_0 >= FOR && LA59_0 <= IF) || (LA59_0 >= NEW && LA59_0 <= WITH) || LA59_0 == LBRACE || LA59_0 == LPAREN || LA59_0 == LBRACK || LA59_0 == SEMIC || (LA59_0 >= ADD && LA59_0 <= SUB) || (LA59_0 >= INC && LA59_0 <= DEC) || (LA59_0 >= NOT && LA59_0 <= INV) || (LA59_0 >= Identifier && LA59_0 <= StringLiteral) || LA59_0 == RegularExpressionLiteral || (LA59_0 >= DecimalLiteral && LA59_0 <= HexIntegerLiteral)) )
{
alt59 = 1;
}
switch (alt59)
{
case 1 :
// C:\\Users\\s.ros\\Projets\\Jint\\Jint\\ES3.g:1451:15: statement
{
PushFollow(FOLLOW_statement_in_block5376);
statement102 = statement();
state.followingStackPointer--;
adaptor.AddChild(root_0, statement102.Tree);
retval.value.Statements.AddLast(((statement102 != null) ? statement102.value : default(Statement)));
}
break;
default:
goto loop59;
}
} while (true);
loop59:
; // Stops C# compiler whining that label 'loop59' has no statements
RBRACE103=(IToken)Match(input,RBRACE,FOLLOW_RBRACE_in_block5382);
RBRACE103_tree = (object)adaptor.Create(RBRACE103);
adaptor.AddChild(root_0, RBRACE103_tree);
}
retval.Stop = input.LT(-1);
retval.Tree = (object)adaptor.RulePostProcessing(root_0);
adaptor.SetTokenBoundaries(retval.Tree, (IToken) retval.Start, (IToken) retval.Stop);
retval.value.Source = ExtractSourceCode((CommonToken)retval.Start, (CommonToken)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 "block"