public ES3Parser.punctuator_return punctuator() // throws RecognitionException [1]
{
ES3Parser.punctuator_return retval = new ES3Parser.punctuator_return();
retval.Start = input.LT(1);
object root_0 = null;
IToken set12 = null;
object set12_tree=null;
try
{
// C:\\Users\\s.ros\\Projets\\Jint\\Jint\\ES3.g:778:2: ( LBRACE | RBRACE | LPAREN | RPAREN | LBRACK | RBRACK | DOT | SEMIC | COMMA | LT | GT | LTE | GTE | EQ | NEQ | SAME | NSAME | ADD | SUB | MUL | MOD | INC | DEC | SHL | SHR | SHU | AND | OR | XOR | NOT | INV | LAND | LOR | QUE | COLON | ASSIGN | ADDASS | SUBASS | MULASS | MODASS | SHLASS | SHRASS | SHUASS | ANDASS | ORASS | XORASS | DIV | DIVASS )
// C:\\Users\\s.ros\\Projets\\Jint\\Jint\\ES3.g:
{
root_0 = (object)adaptor.GetNilNode();
set12 = (IToken)input.LT(1);
if ( (input.LA(1) >= LBRACE && input.LA(1) <= DIVASS) )
{
input.Consume();
adaptor.AddChild(root_0, (object)adaptor.Create(set12));
state.errorRecovery = false;
}
else
{
MismatchedSetException mse = new MismatchedSetException(null,input);
throw mse;
}
}
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 "punctuator"