ES3Parser.caseClause C# (CSharp) Method

caseClause() public method

public caseClause ( ) : ES3Parser.caseClause_return
return ES3Parser.caseClause_return
    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"
ES3Parser