ES3Parser.accessor C# (CSharp) Method

accessor() public method

public accessor ( ) : ES3Parser.accessor_return
return ES3Parser.accessor_return
    public ES3Parser.accessor_return accessor() // throws RecognitionException [1]
    {   
        ES3Parser.accessor_return retval = new ES3Parser.accessor_return();
        retval.Start = input.LT(1);

        object root_0 = null;

        IToken ex1 = null;

        object ex1_tree=null;

        try 
    	{
            // C:\\Users\\s.ros\\Projets\\Jint\\Jint\\ES3.g:1015:2: (ex1= Identifier {...}? =>)
            // C:\\Users\\s.ros\\Projets\\Jint\\Jint\\ES3.g:1015:4: ex1= Identifier {...}? =>
            {
            	root_0 = (object)adaptor.GetNilNode();

            	ex1=(IToken)Match(input,Identifier,FOLLOW_Identifier_in_accessor3452); 
            		ex1_tree = (object)adaptor.Create(ex1);
            		adaptor.AddChild(root_0, ex1_tree);

            	if ( !(( ex1.Text=="get" || ex1.Text=="set" )) ) 
            	{
            	    throw new FailedPredicateException(input, "accessor", " ex1.Text==\"get\" || ex1.Text==\"set\" ");
            	}
            	 if(ex1.Text=="get") retval.value =  PropertyExpressionType.Get; if(ex1.Text=="set") retval.value = PropertyExpressionType.Set; 

            }

            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 "accessor"
ES3Parser