Example #1
0
        public override SqlObject VisitInScalarExpression([NotNull] sqlParser.InScalarExpressionContext context)
        {
            Contract.Requires(context != null);
            // scalar_expression K_NOT? K_IN '(' scalar_expression_list ')'

            SqlScalarExpression needle = (SqlScalarExpression)this.Visit(context.scalar_expression());
            bool not = context.K_NOT() != null;
            List <SqlScalarExpression> searchList = new List <SqlScalarExpression>();

            foreach (sqlParser.Scalar_expressionContext scalarExpressionContext in context.scalar_expression_list().scalar_expression())
            {
                searchList.Add((SqlScalarExpression)this.Visit(scalarExpressionContext));
            }

            return(SqlInScalarExpression.Create(needle, not, searchList));
        }
Example #2
0
 /// <summary>
 /// Visit a parse tree produced by the <c>InScalarExpression</c>
 /// labeled alternative in <see cref="sqlParser.scalar_expression"/>.
 /// <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 VisitInScalarExpression([NotNull] sqlParser.InScalarExpressionContext context)
 {
     return(VisitChildren(context));
 }