NCalcParser.booleanAndExpression C# (CSharp) Method

booleanAndExpression() public method

public booleanAndExpression ( ) : NCalcParser.booleanAndExpression_return,
return NCalcParser.booleanAndExpression_return,
    public NCalcParser.booleanAndExpression_return booleanAndExpression()
    {
        NCalcParser.booleanAndExpression_return retval = new NCalcParser.booleanAndExpression_return();
        retval.Start = input.LT(1);

        CommonTree root_0 = null;

        IToken set6 = null;
        NCalcParser.bitwiseOrExpression_return left = null;

        NCalcParser.bitwiseOrExpression_return right = null;

        CommonTree set6_tree=null;

        BinaryExpressionType type = BinaryExpressionType.Unknown;

        try
        {
            // C:\\Users\\s.ros\\Documents\\Développement\\NCalc\\Grammar\\NCalc.g:99:2: (left= bitwiseOrExpression ( ( '&&' | 'and' ) right= bitwiseOrExpression )* )
            // C:\\Users\\s.ros\\Documents\\Développement\\NCalc\\Grammar\\NCalc.g:99:4: left= bitwiseOrExpression ( ( '&&' | 'and' ) right= bitwiseOrExpression )*
            {
                root_0 = (CommonTree)adaptor.GetNilNode();

                PushFollow(FOLLOW_bitwiseOrExpression_in_booleanAndExpression180);
                left = bitwiseOrExpression();
                state.followingStackPointer--;

                adaptor.AddChild(root_0, left.Tree);
                 retval.value =  ((left != null) ? left.value : null);
                // C:\\Users\\s.ros\\Documents\\Développement\\NCalc\\Grammar\\NCalc.g:99:55: ( ( '&&' | 'and' ) right= bitwiseOrExpression )*
                do
                {
                    int alt3 = 2;
                    int LA3_0 = input.LA(1);

                    if ( ((LA3_0 >= 23 && LA3_0 <= 24)) )
                    {
                        alt3 = 1;
                    }

                    switch (alt3)
                    {
                        case 1 :
                            // C:\\Users\\s.ros\\Documents\\Développement\\NCalc\\Grammar\\NCalc.g:100:4: ( '&&' | 'and' ) right= bitwiseOrExpression
                            {
                                set6 = (IToken)input.LT(1);
                                if ( (input.LA(1) >= 23 && input.LA(1) <= 24) )
                                {
                                    input.Consume();
                                    adaptor.AddChild(root_0, (CommonTree)adaptor.Create(set6));
                                    state.errorRecovery = false;
                                }
                                else
                                {
                                    MismatchedSetException mse = new MismatchedSetException(null,input);
                                    throw mse;
                                }

                                 type = BinaryExpressionType.And;
                                PushFollow(FOLLOW_bitwiseOrExpression_in_booleanAndExpression205);
                                right = bitwiseOrExpression();
                                state.followingStackPointer--;

                                adaptor.AddChild(root_0, right.Tree);
                                 retval.value =  new BinaryExpression(type, retval.value, ((right != null) ? right.value : null));

                            }
                            break;

                        default:
                            goto loop3;
                    }
                } while (true);

                loop3:
                    ;	// Stops C# compiler whining that label 'loop3' has no statements

            }

            retval.Stop = input.LT(-1);

                retval.Tree = (CommonTree)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 = (CommonTree)adaptor.ErrorNode(input, (IToken) retval.Start, input.LT(-1), re);

        }
        finally
        {
        }
        return retval;
    }