Example #1
0
        /// <summary>
        /// Visit a parse tree produced by <see cref="Generated.Z80AsmParser.equExpr"/>.
        /// </summary>
        /// <param name="context">The parse tree.</param>
        /// <return>The visitor result.</return>
        public override object VisitEquExpr(Z80AsmParser.EquExprContext context)
        {
            if (IsInvalidContext(context))
            {
                return(null);
            }

            var expr           = (ExpressionNode)VisitRelExpr(context.GetChild(0) as Z80AsmParser.RelExprContext);
            var nextChildIndex = 2;

            while (nextChildIndex < context.ChildCount)
            {
                var rightExpr = VisitRelExpr(context.GetChild(nextChildIndex)
                                             as Z80AsmParser.RelExprContext);
                var opToken = context.GetChild(nextChildIndex - 1).NormalizeToken();
                var equExpr = opToken == "=="
                    ? new EqualOperationNode()
                    : new NotEqualOperationNode() as BinaryOperationNode;
                equExpr.LeftOperand  = expr;
                equExpr.RightOperand = (ExpressionNode)rightExpr;
                expr            = equExpr;
                nextChildIndex += 2;
            }
            return(expr);
        }
Example #2
0
        public override object VisitEquExpr(Z80AsmParser.EquExprContext context)
        {
            if (context == null)
            {
                return(null);
            }

            var subExprs = context.relExpr();
            var expr     = VisitRelExpr(subExprs[0]);
            var opIndex  = 1;

            for (var i = 1; i < subExprs.Length; i++)
            {
                var rightExpr = VisitRelExpr(subExprs[i]);
                var opToken   = context.GetChild(opIndex).GetText();
                BinaryOperationNode equExpr;
                switch (opToken)
                {
                case "==":
                    equExpr = new EqualOperationNode(expr, rightExpr);
                    break;

                case "===":
                    equExpr = new CaseInsensitiveEqualOperationNode(expr, rightExpr);
                    break;

                case "!=":
                    equExpr = new NotEqualOperationNode(expr, rightExpr);
                    break;

                default:     // !==
                    equExpr = new CaseInsensitiveNotEqualOperationNode(expr, rightExpr);
                    break;
                }
                expr     = equExpr;
                opIndex += 2;
            }
            return(expr);
        }
Example #3
0
 public CaseInsensitiveNotEqualOperationNode(Z80AsmParser.EquExprContext context, Z80AsmVisitor visitor)
     : base(context, visitor)
 {
 }
 /// <summary>
 /// Visit a parse tree produced by <see cref="Z80AsmParser.equExpr"/>.
 /// <para>
 /// The default implementation returns the result of calling <see cref="AbstractParseTreeVisitor{Result}.VisitChildren(IRuleNode)"/>
 /// on <paramref name="context"/>.
 /// </para>
 /// </summary>
 /// <param name="context">The parse tree.</param>
 /// <return>The visitor result.</return>
 public virtual Result VisitEquExpr([NotNull] Z80AsmParser.EquExprContext context)
 {
     return(VisitChildren(context));
 }
Example #5
0
 /// <summary>
 /// Exit a parse tree produced by <see cref="Z80AsmParser.equExpr"/>.
 /// <para>The default implementation does nothing.</para>
 /// </summary>
 /// <param name="context">The parse tree.</param>
 public virtual void ExitEquExpr([NotNull] Z80AsmParser.EquExprContext context)
 {
 }
 public EqualOperationNode(Z80AsmParser.EquExprContext context, Z80AsmVisitor visitor)
     : base(context, context.expr()[0], context.expr()[1], visitor)
 {
 }