Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.sharksharding.sql.visitor.SQLEvalVisitorUtils Maven / Gradle / Ivy
package com.sharksharding.sql.visitor;
///*
// * Copyright 1999-2101 Alibaba Group Holding Ltd.
// *
// * Licensed under the Apache License, Version 2.0 (the "License");
// * you may not use this file except in compliance with the License.
// * You may obtain a copy of the License at
// *
// * http://www.apache.org/licenses/LICENSE-2.0
// *
// * Unless required by applicable law or agreed to in writing, software
// * distributed under the License is distributed on an "AS IS" BASIS,
// * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// * See the License for the specific language governing permissions and
// * limitations under the License.
// */
//package com.alibaba.druid.sql.visitor;
//
//import com.alibaba.druid.DruidRuntimeException;
//import com.alibaba.druid.sql.SQLUtils;
//import com.alibaba.druid.sql.ast.SQLExpr;
//import com.alibaba.druid.sql.ast.SQLObject;
//import com.alibaba.druid.sql.ast.expr.SQLBinaryExpr;
//import com.alibaba.druid.sql.ast.expr.SQLBetweenExpr;
//import com.alibaba.druid.sql.ast.expr.SQLBinaryOpExpr;
//import com.alibaba.druid.sql.ast.expr.SQLBinaryOperator;
//import com.alibaba.druid.sql.ast.expr.SQLCaseExpr;
//import com.alibaba.druid.sql.ast.expr.SQLCharExpr;
//import com.alibaba.druid.sql.ast.expr.SQLHexExpr;
//import com.alibaba.druid.sql.ast.expr.SQLIdentifierExpr;
//import com.alibaba.druid.sql.ast.expr.SQLInListExpr;
//import com.alibaba.druid.sql.ast.expr.SQLMethodInvokeExpr;
//import com.alibaba.druid.sql.ast.expr.SQLNullExpr;
//import com.alibaba.druid.sql.ast.expr.SQLNumericLiteralExpr;
//import com.alibaba.druid.sql.ast.expr.SQLQueryExpr;
//import com.alibaba.druid.sql.ast.expr.SQLUnaryExpr;
//import com.alibaba.druid.sql.ast.expr.SQLUnaryOperator;
//import com.alibaba.druid.sql.ast.expr.SQLVariantRefExpr;
//import com.alibaba.druid.sql.ast.statement.SQLExprTableSource;
//import com.alibaba.druid.sql.ast.statement.SQLSelect;
//import com.alibaba.druid.sql.ast.statement.SQLSelectItem;
//import com.alibaba.druid.sql.ast.statement.SQLSelectQueryBlock;
//import com.alibaba.druid.sql.dialect.db2.visitor.DB2EvalVisitor;
//import com.alibaba.druid.sql.dialect.mysql.visitor.MySqlEvalVisitorImpl;
//import com.alibaba.druid.sql.dialect.oracle.visitor.OracleEvalVisitor;
//import com.alibaba.druid.sql.dialect.postgresql.visitor.PGEvalVisitor;
//import com.alibaba.druid.sql.dialect.sqlserver.visitor.SQLServerEvalVisitor;
//import com.alibaba.druid.sql.visitor.functions.Ascii;
//import com.alibaba.druid.sql.visitor.functions.Bin;
//import com.alibaba.druid.sql.visitor.functions.BitLength;
//import com.alibaba.druid.sql.visitor.functions.Char;
//import com.alibaba.druid.sql.visitor.functions.Concat;
//import com.alibaba.druid.sql.visitor.functions.Elt;
//import com.alibaba.druid.sql.visitor.functions.Function;
//import com.alibaba.druid.sql.visitor.functions.Greatest;
//import com.alibaba.druid.sql.visitor.functions.Hex;
//import com.alibaba.druid.sql.visitor.functions.If;
//import com.alibaba.druid.sql.visitor.functions.Insert;
//import com.alibaba.druid.sql.visitor.functions.Instr;
//import com.alibaba.druid.sql.visitor.functions.Isnull;
//import com.alibaba.druid.sql.visitor.functions.Lcase;
//import com.alibaba.druid.sql.visitor.functions.Least;
//import com.alibaba.druid.sql.visitor.functions.Left;
//import com.alibaba.druid.sql.visitor.functions.Length;
//import com.alibaba.druid.sql.visitor.functions.Locate;
//import com.alibaba.druid.sql.visitor.functions.Lpad;
//import com.alibaba.druid.sql.visitor.functions.Ltrim;
//import com.alibaba.druid.sql.visitor.functions.Now;
//import com.alibaba.druid.sql.visitor.functions.OneParamFunctions;
//import com.alibaba.druid.sql.visitor.functions.Reverse;
//import com.alibaba.druid.sql.visitor.functions.Right;
//import com.alibaba.druid.sql.visitor.functions.Substring;
//import com.alibaba.druid.sql.visitor.functions.Trim;
//import com.alibaba.druid.sql.visitor.functions.Ucase;
//import com.alibaba.druid.sql.visitor.functions.Unhex;
//import com.alibaba.druid.util.HexBin;
//import com.alibaba.druid.util.JdbcUtils;
//import com.alibaba.druid.util.Utils;
//import com.alibaba.druid.wall.spi.WallVisitorUtils;
//import com.alibaba.druid.wall.spi.WallVisitorUtils.WallConditionContext;
//
//import java.math.BigDecimal;
//import java.math.BigInteger;
//import java.text.ParseException;
//import java.text.SimpleDateFormat;
//import java.util.ArrayList;
//import java.util.Arrays;
//import java.util.Date;
//import java.util.HashMap;
//import java.util.List;
//import java.util.Map;
//import java.util.regex.Pattern;
//
//import static com.alibaba.druid.sql.visitor.SQLEvalVisitor.EVAL_ERROR;
//import static com.alibaba.druid.sql.visitor.SQLEvalVisitor.EVAL_EXPR;
//import static com.alibaba.druid.sql.visitor.SQLEvalVisitor.EVAL_VALUE;
//import static com.alibaba.druid.sql.visitor.SQLEvalVisitor.EVAL_VALUE_NULL;
//
//public class SQLEvalVisitorUtils {
//
// private static Map functions = new HashMap();
//
// static {
// registerBaseFunctions();
// }
//
// public static Object evalExpr(String dbType, String expr, Object... parameters) {
// SQLExpr sqlExpr = SQLUtils.toSQLExpr(expr, dbType);
// return eval(dbType, sqlExpr, parameters);
// }
//
// public static Object evalExpr(String dbType, String expr, List parameters) {
// SQLExpr sqlExpr = SQLUtils.toSQLExpr(expr);
// return eval(dbType, sqlExpr, parameters);
// }
//
// public static Object eval(String dbType, SQLObject sqlObject, Object... parameters) {
// Object value = eval(dbType, sqlObject, Arrays.asList(parameters));
//
// if (value == EVAL_VALUE_NULL) {
// value = null;
// }
//
// return value;
// }
//
// public static Object getValue(SQLObject sqlObject) {
// if (sqlObject instanceof SQLNumericLiteralExpr) {
// return ((SQLNumericLiteralExpr) sqlObject).getNumber();
// }
//
// return sqlObject.getAttributes().get(EVAL_VALUE);
// }
//
// public static Object eval(String dbType, SQLObject sqlObject, List parameters) {
// return eval(dbType, sqlObject, parameters, true);
// }
//
// public static Object eval(String dbType, SQLObject sqlObject, List parameters, boolean throwError) {
// SQLEvalVisitor visitor = createEvalVisitor(dbType);
// visitor.setParameters(parameters);
// sqlObject.accept(visitor);
//
// Object value = getValue(sqlObject);
// if (value == null) {
// if (throwError && !sqlObject.getAttributes().containsKey(EVAL_VALUE)) {
// throw new DruidRuntimeException("eval error : " + SQLUtils.toSQLString(sqlObject, dbType));
// }
// }
//
// return value;
// }
//
// public static SQLEvalVisitor createEvalVisitor(String dbType) {
// if (JdbcUtils.MYSQL.equals(dbType)) {
// return new MySqlEvalVisitorImpl();
// }
//
// if (JdbcUtils.MARIADB.equals(dbType)) {
// return new MySqlEvalVisitorImpl();
// }
//
// if (JdbcUtils.H2.equals(dbType)) {
// return new MySqlEvalVisitorImpl();
// }
//
// if (JdbcUtils.ORACLE.equals(dbType) || JdbcUtils.ALI_ORACLE.equals(dbType)) {
// return new OracleEvalVisitor();
// }
//
// if (JdbcUtils.POSTGRESQL.equals(dbType)) {
// return new PGEvalVisitor();
// }
//
// if (JdbcUtils.SQL_SERVER.equals(dbType) || JdbcUtils.JTDS.equals(dbType)) {
// return new SQLServerEvalVisitor();
// }
//
// if (JdbcUtils.DB2.equals(dbType)) {
// return new DB2EvalVisitor();
// }
//
// return new SQLEvalVisitorImpl();
// }
//
// static void registerBaseFunctions() {
// functions.put("now", Now.instance);
// functions.put("concat", Concat.instance);
// functions.put("concat_ws", Concat.instance);
// functions.put("ascii", Ascii.instance);
// functions.put("bin", Bin.instance);
// functions.put("bit_length", BitLength.instance);
// functions.put("insert", Insert.instance);
// functions.put("instr", Instr.instance);
// functions.put("char", Char.instance);
// functions.put("elt", Elt.instance);
// functions.put("left", Left.instance);
// functions.put("locate", Locate.instance);
// functions.put("lpad", Lpad.instance);
// functions.put("ltrim", Ltrim.instance);
// functions.put("mid", Substring.instance);
// functions.put("substr", Substring.instance);
// functions.put("substring", Substring.instance);
// functions.put("right", Right.instance);
// functions.put("reverse", Reverse.instance);
// functions.put("len", Length.instance);
// functions.put("length", Length.instance);
// functions.put("char_length", Length.instance);
// functions.put("character_length", Length.instance);
// functions.put("trim", Trim.instance);
// functions.put("ucase", Ucase.instance);
// functions.put("upper", Ucase.instance);
// functions.put("lcase", Lcase.instance);
// functions.put("lower", Lcase.instance);
// functions.put("hex", Hex.instance);
// functions.put("unhex", Unhex.instance);
// functions.put("greatest", Greatest.instance);
// functions.put("least", Least.instance);
// functions.put("isnull", Isnull.instance);
// functions.put("if", If.instance);
//
// functions.put("md5", OneParamFunctions.instance);
// functions.put("bit_count", OneParamFunctions.instance);
// functions.put("soundex", OneParamFunctions.instance);
// functions.put("space", OneParamFunctions.instance);
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLMethodInvokeExpr x) {
// String methodName = x.getMethodName().toLowerCase();
//
// Function function = visitor.getFunction(methodName);
//
// if (function == null) {
// function = functions.get(methodName);
// }
//
// if (function != null) {
// Object result = function.eval(visitor, x);
//
// if (result != SQLEvalVisitor.EVAL_ERROR) {
// x.getAttributes().put(EVAL_VALUE, result);
// }
// return false;
// }
//
// if ("mod".equals(methodName)) {
// if (x.getParameters().size() != 2) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// SQLExpr param1 = x.getParameters().get(1);
// param0.accept(visitor);
// param1.accept(visitor);
//
// Object param0Value = param0.getAttributes().get(EVAL_VALUE);
// Object param1Value = param1.getAttributes().get(EVAL_VALUE);
// if (param0Value == null || param1Value == null) {
// return false;
// }
//
// int intValue0 = castToInteger(param0Value);
// int intValue1 = castToInteger(param1Value);
//
// int result = intValue0 % intValue1;
//
// x.putAttribute(EVAL_VALUE, result);
// } else if ("abs".equals(methodName)) {
// if (x.getParameters().size() != 1) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// param0.accept(visitor);
//
// Object paramValue = param0.getAttributes().get(EVAL_VALUE);
// if (paramValue == null) {
// return false;
// }
//
// Object result;
// if (paramValue instanceof Integer) {
// result = Math.abs(((Integer) paramValue).intValue());
// } else if (paramValue instanceof Long) {
// result = Math.abs(((Long) paramValue).longValue());
// } else {
// result = castToDecimal(paramValue).abs();
// }
//
// x.putAttribute(EVAL_VALUE, result);
// } else if ("acos".equals(methodName)) {
// if (x.getParameters().size() != 1) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// param0.accept(visitor);
//
// Object paramValue = param0.getAttributes().get(EVAL_VALUE);
// if (paramValue == null) {
// return false;
// }
//
// double doubleValue = castToDouble(paramValue);
// double result = Math.acos(doubleValue);
//
// if (Double.isNaN(result)) {
// x.putAttribute(EVAL_VALUE, null);
// } else {
// x.putAttribute(EVAL_VALUE, result);
// }
// } else if ("asin".equals(methodName)) {
// if (x.getParameters().size() != 1) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// param0.accept(visitor);
//
// Object paramValue = param0.getAttributes().get(EVAL_VALUE);
// if (paramValue == null) {
// return false;
// }
//
// double doubleValue = castToDouble(paramValue);
// double result = Math.asin(doubleValue);
//
// if (Double.isNaN(result)) {
// x.putAttribute(EVAL_VALUE, null);
// } else {
// x.putAttribute(EVAL_VALUE, result);
// }
// } else if ("atan".equals(methodName)) {
// if (x.getParameters().size() != 1) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// param0.accept(visitor);
//
// Object paramValue = param0.getAttributes().get(EVAL_VALUE);
// if (paramValue == null) {
// return false;
// }
//
// double doubleValue = castToDouble(paramValue);
// double result = Math.atan(doubleValue);
//
// if (Double.isNaN(result)) {
// x.putAttribute(EVAL_VALUE, null);
// } else {
// x.putAttribute(EVAL_VALUE, result);
// }
// } else if ("atan2".equals(methodName)) {
// if (x.getParameters().size() != 2) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// SQLExpr param1 = x.getParameters().get(1);
// param0.accept(visitor);
// param1.accept(visitor);
//
// Object param0Value = param0.getAttributes().get(EVAL_VALUE);
// Object param1Value = param1.getAttributes().get(EVAL_VALUE);
// if (param0Value == null || param1Value == null) {
// return false;
// }
//
// double doubleValue0 = castToDouble(param0Value);
// double doubleValue1 = castToDouble(param1Value);
// double result = Math.atan2(doubleValue0, doubleValue1);
//
// if (Double.isNaN(result)) {
// x.putAttribute(EVAL_VALUE, null);
// } else {
// x.putAttribute(EVAL_VALUE, result);
// }
// } else if ("ceil".equals(methodName) || "ceiling".equals(methodName)) {
// if (x.getParameters().size() != 1) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// param0.accept(visitor);
//
// Object paramValue = param0.getAttributes().get(EVAL_VALUE);
// if (paramValue == null) {
// return false;
// }
//
// double doubleValue = castToDouble(paramValue);
// int result = (int) Math.ceil(doubleValue);
//
// if (Double.isNaN(result)) {
// x.putAttribute(EVAL_VALUE, null);
// } else {
// x.putAttribute(EVAL_VALUE, result);
// }
// } else if ("cos".equals(methodName)) {
// if (x.getParameters().size() != 1) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// param0.accept(visitor);
//
// Object paramValue = param0.getAttributes().get(EVAL_VALUE);
// if (paramValue == null) {
// return false;
// }
//
// double doubleValue = castToDouble(paramValue);
// double result = Math.cos(doubleValue);
//
// if (Double.isNaN(result)) {
// x.putAttribute(EVAL_VALUE, null);
// } else {
// x.putAttribute(EVAL_VALUE, result);
// }
// } else if ("sin".equals(methodName)) {
// if (x.getParameters().size() != 1) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// param0.accept(visitor);
//
// Object paramValue = param0.getAttributes().get(EVAL_VALUE);
// if (paramValue == null) {
// return false;
// }
//
// double doubleValue = castToDouble(paramValue);
// double result = Math.sin(doubleValue);
//
// if (Double.isNaN(result)) {
// x.putAttribute(EVAL_VALUE, null);
// } else {
// x.putAttribute(EVAL_VALUE, result);
// }
// } else if ("log".equals(methodName)) {
// if (x.getParameters().size() != 1) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// param0.accept(visitor);
//
// Object paramValue = param0.getAttributes().get(EVAL_VALUE);
// if (paramValue == null) {
// return false;
// }
//
// double doubleValue = castToDouble(paramValue);
// double result = Math.log(doubleValue);
//
// if (Double.isNaN(result)) {
// x.putAttribute(EVAL_VALUE, null);
// } else {
// x.putAttribute(EVAL_VALUE, result);
// }
// } else if ("log10".equals(methodName)) {
// if (x.getParameters().size() != 1) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// param0.accept(visitor);
//
// Object paramValue = param0.getAttributes().get(EVAL_VALUE);
// if (paramValue == null) {
// return false;
// }
//
// double doubleValue = castToDouble(paramValue);
// double result = Math.log10(doubleValue);
//
// if (Double.isNaN(result)) {
// x.putAttribute(EVAL_VALUE, null);
// } else {
// x.putAttribute(EVAL_VALUE, result);
// }
// } else if ("tan".equals(methodName)) {
// if (x.getParameters().size() != 1) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// param0.accept(visitor);
//
// Object paramValue = param0.getAttributes().get(EVAL_VALUE);
// if (paramValue == null) {
// return false;
// }
//
// double doubleValue = castToDouble(paramValue);
// double result = Math.tan(doubleValue);
//
// if (Double.isNaN(result)) {
// x.putAttribute(EVAL_VALUE, null);
// } else {
// x.putAttribute(EVAL_VALUE, result);
// }
// } else if ("sqrt".equals(methodName)) {
// if (x.getParameters().size() != 1) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// param0.accept(visitor);
//
// Object paramValue = param0.getAttributes().get(EVAL_VALUE);
// if (paramValue == null) {
// return false;
// }
//
// double doubleValue = castToDouble(paramValue);
// double result = Math.sqrt(doubleValue);
//
// if (Double.isNaN(result)) {
// x.putAttribute(EVAL_VALUE, null);
// } else {
// x.putAttribute(EVAL_VALUE, result);
// }
// } else if ("power".equals(methodName) || "pow".equals(methodName)) {
// if (x.getParameters().size() != 2) {
// return false;
// }
//
// SQLExpr param0 = x.getParameters().get(0);
// SQLExpr param1 = x.getParameters().get(1);
// param0.accept(visitor);
// param1.accept(visitor);
//
// Object param0Value = param0.getAttributes().get(EVAL_VALUE);
// Object param1Value = param1.getAttributes().get(EVAL_VALUE);
// if (param0Value == null || param1Value == null) {
// return false;
// }
//
// double doubleValue0 = castToDouble(param0Value);
// double doubleValue1 = castToDouble(param1Value);
// double result = Math.pow(doubleValue0, doubleValue1);
//
// if (Double.isNaN(result)) {
// x.putAttribute(EVAL_VALUE, null);
// } else {
// x.putAttribute(EVAL_VALUE, result);
// }
// } else if ("pi".equals(methodName)) {
// x.putAttribute(EVAL_VALUE, Math.PI);
// } else if ("rand".equals(methodName)) {
// x.putAttribute(EVAL_VALUE, Math.random());
// } else if ("chr".equals(methodName) && x.getParameters().size() == 1) {
// SQLExpr first = x.getParameters().get(0);
// Object firstResult = getValue(first);
// if (firstResult instanceof Number) {
// int intValue = ((Number) firstResult).intValue();
// char ch = (char) intValue;
// x.putAttribute(EVAL_VALUE, Character.toString(ch));
// }
// } else if ("current_user".equals(methodName)) {
// x.putAttribute(EVAL_VALUE, "CURRENT_USER");
// }
// return false;
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLCharExpr x) {
// x.putAttribute(EVAL_VALUE, x.getText());
// return true;
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLHexExpr x) {
// String hex = x.getHex();
// byte[] bytes = HexBin.decode(hex);
// if (bytes == null) {
// x.putAttribute(EVAL_VALUE, EVAL_ERROR);
// } else {
// String val = new String(bytes);
// x.putAttribute(EVAL_VALUE, val);
// }
// return true;
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLBinaryExpr x) {
// String text = x.getValue();
//
// long[] words = new long[text.length() / 64 + 1];
// for (int i = 0; i < text.length(); ++i) {
// char ch = text.charAt(i);
// if (ch == '1') {
// int wordIndex = i >> 6;
// words[wordIndex] |= (1L << i);
// }
// }
//
// Object val;
//
// if (words.length == 1) {
// val = words[0];
// } else {
// byte[] bytes = new byte[words.length * 8];
//
// for (int i = 0; i < words.length; ++i) {
// Utils.putLong(bytes, i * 8, words[i]);
// }
//
// val = new BigInteger(bytes);
// }
//
// x.putAttribute(EVAL_VALUE, val);
//
// return false;
// }
//
// public static SQLExpr unwrap(SQLExpr expr) {
// if (expr == null) {
// return null;
// }
//
// if (expr instanceof SQLQueryExpr) {
// SQLSelect select = ((SQLQueryExpr) expr).getSubQuery();
// if (select == null) {
// return null;
// }
// if (select.getQuery() instanceof SQLSelectQueryBlock) {
// SQLSelectQueryBlock queryBlock = (SQLSelectQueryBlock) select.getQuery();
// if (queryBlock.getFrom() == null) {
// if (queryBlock.getSelectList().size() == 1) {
// return queryBlock.getSelectList().get(0).getExpr();
// }
// }
// }
// }
//
// return expr;
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLBetweenExpr x) {
// SQLExpr testExpr = unwrap(x.getTestExpr());
// testExpr.accept(visitor);
//
// if (!testExpr.getAttributes().containsKey(EVAL_VALUE)) {
// return false;
// }
//
// Object value = testExpr.getAttribute(EVAL_VALUE);
//
// SQLExpr beginExpr = unwrap(x.getBeginExpr());
// beginExpr.accept(visitor);
// if (!beginExpr.getAttributes().containsKey(EVAL_VALUE)) {
// return false;
// }
//
// Object begin = beginExpr.getAttribute(EVAL_VALUE);
//
// if (lt(value, begin)) {
// x.getAttributes().put(EVAL_VALUE, x.isNot() ? true : false);
// return false;
// }
//
// SQLExpr endExpr = unwrap(x.getEndExpr());
// endExpr.accept(visitor);
// if (!endExpr.getAttributes().containsKey(EVAL_VALUE)) {
// return false;
// }
//
// Object end = endExpr.getAttribute(EVAL_VALUE);
//
// if (gt(value, end)) {
// x.getAttributes().put(EVAL_VALUE, x.isNot() ? true : false);
// return false;
// }
//
// x.getAttributes().put(EVAL_VALUE, x.isNot() ? false : true);
// return false;
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLNullExpr x) {
// x.getAttributes().put(EVAL_VALUE, EVAL_VALUE_NULL);
// return false;
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLCaseExpr x) {
// Object value;
// if (x.getValueExpr() != null) {
// x.getValueExpr().accept(visitor);
//
// if (!x.getValueExpr().getAttributes().containsKey(EVAL_VALUE)) {
// return false;
// }
//
// value = x.getValueExpr().getAttribute(EVAL_VALUE);
// } else {
// value = null;
// }
//
// for (SQLCaseExpr.Item item : x.getItems()) {
// item.getConditionExpr().accept(visitor);
//
// if (!item.getConditionExpr().getAttributes().containsKey(EVAL_VALUE)) {
// return false;
// }
//
// Object conditionValue = item.getConditionExpr().getAttribute(EVAL_VALUE);
//
// if ((x.getValueExpr() != null && eq(value, conditionValue))
// || (x.getValueExpr() == null && conditionValue instanceof Boolean && (Boolean) conditionValue == Boolean.TRUE)) {
// item.getValueExpr().accept(visitor);
//
// if (item.getValueExpr().getAttributes().containsKey(EVAL_VALUE)) {
// x.getAttributes().put(EVAL_VALUE, item.getValueExpr().getAttribute(EVAL_VALUE));
// }
//
// return false;
// }
// }
//
// if (x.getElseExpr() != null) {
// x.getElseExpr().accept(visitor);
//
// if (x.getElseExpr().getAttributes().containsKey(EVAL_VALUE)) {
// x.getAttributes().put(EVAL_VALUE, x.getElseExpr().getAttribute(EVAL_VALUE));
// }
// }
//
// return false;
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLInListExpr x) {
// SQLExpr valueExpr = x.getExpr();
// valueExpr.accept(visitor);
// if (!valueExpr.getAttributes().containsKey(EVAL_VALUE)) {
// return false;
// }
// Object value = valueExpr.getAttribute(EVAL_VALUE);
//
// for (SQLExpr item : x.getTargetList()) {
// item.accept(visitor);
// if (!item.getAttributes().containsKey(EVAL_VALUE)) {
// return false;
// }
// Object itemValue = item.getAttribute(EVAL_VALUE);
// if (eq(value, itemValue)) {
// x.getAttributes().put(EVAL_VALUE, x.isNot() ? false : true);
// return false;
// }
// }
//
// x.getAttributes().put(EVAL_VALUE, x.isNot() ? true : false);
// return false;
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLQueryExpr x) {
// if (WallVisitorUtils.isSimpleCountTableSource(null, ((SQLQueryExpr) x).getSubQuery())) {
// x.putAttribute(EVAL_VALUE, 1);
// return false;
// }
//
// if (x.getSubQuery().getQuery() instanceof SQLSelectQueryBlock) {
// SQLSelectQueryBlock queryBlock = (SQLSelectQueryBlock) x.getSubQuery().getQuery();
//
// boolean nullFrom = false;
// if (queryBlock.getFrom() == null) {
// nullFrom = true;
// } else if (queryBlock.getFrom() instanceof SQLExprTableSource) {
// SQLExpr expr = ((SQLExprTableSource) queryBlock.getFrom()).getExpr();
// if (expr instanceof SQLIdentifierExpr) {
// if ("dual".equalsIgnoreCase(((SQLIdentifierExpr) expr).getName())) {
// nullFrom = true;
// }
// }
// }
//
// if (nullFrom) {
// List row = new ArrayList(queryBlock.getSelectList().size());
// for (int i = 0; i < queryBlock.getSelectList().size(); ++i) {
// SQLSelectItem item = queryBlock.getSelectList().get(i);
// item.getExpr().accept(visitor);
// Object cell = item.getExpr().getAttribute(EVAL_VALUE);
// row.add(cell);
// }
// List> rows = new ArrayList>(1);
// rows.add(row);
//
// Object result = rows;
// queryBlock.putAttribute(EVAL_VALUE, result);
// x.getSubQuery().putAttribute(EVAL_VALUE, result);
// x.putAttribute(EVAL_VALUE, result);
//
// return false;
// }
// }
//
// return false;
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLUnaryExpr x) {
// final WallConditionContext wallConditionContext = WallVisitorUtils.getWallConditionContext();
// if (x.getOperator() == SQLUnaryOperator.Compl && wallConditionContext != null) {
// wallConditionContext.setBitwise(true);
// }
//
// x.getExpr().accept(visitor);
//
// Object val = x.getExpr().getAttribute(EVAL_VALUE);
// if (val == EVAL_ERROR) {
// x.putAttribute(EVAL_VALUE, EVAL_ERROR);
// return false;
// }
//
// if (val == null) {
// x.putAttribute(EVAL_VALUE, EVAL_VALUE_NULL);
// return false;
// }
//
// switch (x.getOperator()) {
// case BINARY:
// case RAW:
// x.putAttribute(EVAL_VALUE, val);
// break;
// case NOT:
// case Not: {
// Boolean booleanVal = castToBoolean(val);
// if (booleanVal != null) {
// x.putAttribute(EVAL_VALUE, !booleanVal);
// }
// break;
// }
// case Plus:
// x.putAttribute(EVAL_VALUE, val);
// break;
// case Negative:
// x.putAttribute(EVAL_VALUE, multi(val, -1));
// break;
// case Compl:
// x.putAttribute(EVAL_VALUE, ~castToInteger(val));
// break;
// default:
// break;
// }
//
// return false;
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLBinaryOpExpr x) {
// SQLExpr left = unwrap(x.getLeft());
// SQLExpr right = unwrap(x.getRight());
//
// // final WallConditionContext old = wallConditionContextLocal.get();
//
// left.accept(visitor);
// right.accept(visitor);
//
// final WallConditionContext wallConditionContext = WallVisitorUtils.getWallConditionContext();
// if (x.getOperator() == SQLBinaryOperator.BooleanOr) {
// if (wallConditionContext != null) {
// if (left.getAttribute(EVAL_VALUE) == Boolean.TRUE || right.getAttribute(EVAL_VALUE) == Boolean.TRUE) {
// wallConditionContext.setPartAlwayTrue(true);
// }
// }
// } else if (x.getOperator() == SQLBinaryOperator.BooleanAnd) {
// if (wallConditionContext != null) {
// if (left.getAttribute(EVAL_VALUE) == Boolean.FALSE || right.getAttribute(EVAL_VALUE) == Boolean.FALSE) {
// wallConditionContext.setPartAlwayFalse(true);
// }
// }
// } else if (x.getOperator() == SQLBinaryOperator.BooleanXor) {
// if (wallConditionContext != null) {
// wallConditionContext.setXor(true);
// }
// } else if (x.getOperator() == SQLBinaryOperator.BitwiseAnd //
// || x.getOperator() == SQLBinaryOperator.BitwiseNot //
// || x.getOperator() == SQLBinaryOperator.BitwiseOr //
// || x.getOperator() == SQLBinaryOperator.BitwiseXor) {
// if (wallConditionContext != null) {
// wallConditionContext.setBitwise(true);
// }
// }
//
// Object leftValue = left.getAttribute(EVAL_VALUE);
// Object rightValue = right.getAttributes().get(EVAL_VALUE);
//
// if (x.getOperator() == SQLBinaryOperator.Like) {
// if (isAlwayTrueLikePattern(x.getRight())) {
// x.putAttribute(WallVisitorUtils.HAS_TRUE_LIKE, Boolean.TRUE);
// x.putAttribute(EVAL_VALUE, Boolean.TRUE);
// return false;
// }
// }
//
// if (x.getOperator() == SQLBinaryOperator.NotLike) {
// if (isAlwayTrueLikePattern(x.getRight())) {
// x.putAttribute(EVAL_VALUE, Boolean.FALSE);
// return false;
// }
// }
//
// boolean leftHasValue = left.getAttributes().containsKey(EVAL_VALUE);
// boolean rightHasValue = right.getAttributes().containsKey(EVAL_VALUE);
//
// if ((!leftHasValue) && !rightHasValue) {
// SQLExpr leftEvalExpr = (SQLExpr) left.getAttribute(EVAL_EXPR);
// SQLExpr rightEvalExpr = (SQLExpr) right.getAttribute(EVAL_EXPR);
//
// if (leftEvalExpr != null && leftEvalExpr.equals(rightEvalExpr)) {
// switch (x.getOperator()) {
// case Like:
// case Equality:
// case GreaterThanOrEqual:
// case LessThanOrEqual:
// case NotLessThan:
// case NotGreaterThan:
// x.putAttribute(EVAL_VALUE, Boolean.TRUE);
// return false;
// case NotEqual:
// case NotLike:
// case GreaterThan:
// case LessThan:
// x.putAttribute(EVAL_VALUE, Boolean.FALSE);
// return false;
// default:
// break;
// }
// }
// }
//
// if (!leftHasValue) {
// return false;
// }
//
// if (!rightHasValue) {
// return false;
// }
//
// if (wallConditionContext != null) {
// wallConditionContext.setConstArithmetic(true);
// }
//
// leftValue = processValue(leftValue);
// rightValue = processValue(rightValue);
//
// if (leftValue == null || rightValue == null) {
// return false;
// }
//
// Object value = null;
// switch (x.getOperator()) {
// case Add:
// value = add(leftValue, rightValue);
// x.putAttribute(EVAL_VALUE, value);
// break;
// case Subtract:
// value = sub(leftValue, rightValue);
// x.putAttribute(EVAL_VALUE, value);
// break;
// case Multiply:
// value = multi(leftValue, rightValue);
// x.putAttribute(EVAL_VALUE, value);
// break;
// case Divide:
// value = div(leftValue, rightValue);
// x.putAttribute(EVAL_VALUE, value);
// break;
// case RightShift:
// value = rightShift(leftValue, rightValue);
// x.putAttribute(EVAL_VALUE, value);
// break;
// case BitwiseAnd:
// value = bitAnd(leftValue, rightValue);
// x.putAttribute(EVAL_VALUE, value);
// break;
// case BitwiseOr:
// value = bitOr(leftValue, rightValue);
// x.putAttribute(EVAL_VALUE, value);
// break;
// case GreaterThan:
// value = gt(leftValue, rightValue);
// x.putAttribute(EVAL_VALUE, value);
// break;
// case GreaterThanOrEqual:
// value = gteq(leftValue, rightValue);
// x.putAttribute(EVAL_VALUE, value);
// break;
// case LessThan:
// value = lt(leftValue, rightValue);
// x.putAttribute(EVAL_VALUE, value);
// break;
// case LessThanOrEqual:
// value = lteq(leftValue, rightValue);
// x.putAttribute(EVAL_VALUE, value);
// break;
// case Is:
// if (rightValue == EVAL_VALUE_NULL) {
// if (leftValue != null) {
// value = (leftValue == EVAL_VALUE_NULL);
// x.putAttribute(EVAL_VALUE, value);
// break;
// }
// }
// break;
// case Equality:
// value = eq(leftValue, rightValue);
// x.putAttribute(EVAL_VALUE, value);
// break;
// case NotEqual:
// value = !eq(leftValue, rightValue);
// x.putAttribute(EVAL_VALUE, value);
// break;
// case IsNot:
// if (leftValue == EVAL_VALUE_NULL) {
// x.putAttribute(EVAL_VALUE, false);
// } else if (leftValue != null) {
// x.putAttribute(EVAL_VALUE, true);
// }
// break;
// case RegExp:
// case RLike: {
// String pattern = castToString(rightValue);
// String input = castToString(left.getAttributes().get(EVAL_VALUE));
// boolean matchResult = Pattern.matches(pattern, input);
// x.putAttribute(EVAL_VALUE, matchResult);
// break;
// }
// case NotRegExp:
// case NotRLike: {
// String pattern = castToString(rightValue);
// String input = castToString(left.getAttributes().get(EVAL_VALUE));
// boolean matchResult = !Pattern.matches(pattern, input);
// x.putAttribute(EVAL_VALUE, matchResult);
// break;
// }
// case Like: {
// String pattern = castToString(rightValue);
// String input = castToString(left.getAttributes().get(EVAL_VALUE));
// boolean matchResult = like(input, pattern);
// x.putAttribute(EVAL_VALUE, matchResult);
// break;
// }
// case NotLike: {
// String pattern = castToString(rightValue);
// String input = castToString(left.getAttributes().get(EVAL_VALUE));
// boolean matchResult = !like(input, pattern);
// x.putAttribute(EVAL_VALUE, matchResult);
// break;
// }
// case Concat: {
// String result = leftValue.toString() + rightValue.toString();
// x.putAttribute(EVAL_VALUE, result);
// break;
// }
// default:
// break;
// }
//
// return false;
// }
//
// @SuppressWarnings("rawtypes")
// private static Object processValue(Object value) {
// if (value instanceof List) {
// List list = (List) value;
// if (list.size() == 1) {
// return processValue(list.get(0));
// }
// } else if (value instanceof Date) {
// return ((Date) value).getTime();
// }
// return value;
// }
//
// private static boolean isAlwayTrueLikePattern(SQLExpr x) {
// if (x instanceof SQLCharExpr) {
// String text = ((SQLCharExpr) x).getText();
//
// if (text.length() > 0) {
// for (char ch : text.toCharArray()) {
// if (ch != '%') {
// return false;
// }
// }
// return true;
// }
// }
// return false;
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLNumericLiteralExpr x) {
// x.getAttributes().put(EVAL_VALUE, x.getNumber());
// return false;
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLVariantRefExpr x) {
// if (!"?".equals(x.getName())) {
// return false;
// }
//
// Map attributes = x.getAttributes();
//
// int varIndex = x.getIndex();
//
// if (varIndex != -1 && visitor.getParameters().size() > varIndex) {
// boolean containsValue = attributes.containsKey(EVAL_VALUE);
// if (!containsValue) {
// Object value = visitor.getParameters().get(varIndex);
// if (value == null) {
// value = EVAL_VALUE_NULL;
// }
// attributes.put(EVAL_VALUE, value);
// }
// }
//
// return false;
// }
//
// public static Boolean castToBoolean(Object val) {
// if (val == null) {
// return null;
// }
//
// if (val == EVAL_VALUE_NULL) {
// return null;
// }
//
// if (val instanceof Boolean) {
// return (Boolean) val;
// }
//
// if (val instanceof Number) {
// return ((Number) val).intValue() > 0;
// }
//
// if (val instanceof String) {
// if ("1".equals(val) || "true".equalsIgnoreCase((String) val)) {
// return true;
// }
//
// return false;
// }
//
// throw new IllegalArgumentException(val.getClass() + " not supported.");
// }
//
// public static String castToString(Object val) {
// Object value = val;
//
// if (value == null) {
// return null;
// }
//
// return value.toString();
// }
//
// public static Byte castToByte(Object val) {
// if (val == null) {
// return null;
// }
//
// if (val instanceof Byte) {
// return (Byte) val;
// }
//
// if (val instanceof String) {
// return Byte.parseByte((String) val);
// }
//
// return ((Number) val).byteValue();
// }
//
// public static Short castToShort(Object val) {
// if (val == null || val == EVAL_VALUE_NULL) {
// return null;
// }
//
// if (val instanceof Short) {
// return (Short) val;
// }
//
// if (val instanceof String) {
// return Short.parseShort((String) val);
// }
//
// return ((Number) val).shortValue();
// }
//
// @SuppressWarnings("rawtypes")
// public static Integer castToInteger(Object val) {
// if (val == null) {
// return null;
// }
//
// if (val instanceof Integer) {
// return (Integer) val;
// }
//
// if (val instanceof String) {
// return Integer.parseInt((String) val);
// }
//
// if (val instanceof List) {
// List list = (List) val;
// if (list.size() == 1) {
// return castToInteger(list.get(0));
// }
// }
//
// if (val instanceof Boolean) {
// if (((Boolean) val).booleanValue()) {
// return 1;
// } else {
// return 0;
// }
// }
//
// if (val instanceof Number) {
// return ((Number) val).intValue();
// }
//
// throw new DruidRuntimeException("cast error");
// }
//
// @SuppressWarnings("rawtypes")
// public static Long castToLong(Object val) {
// if (val == null) {
// return null;
// }
//
// if (val instanceof Long) {
// return (Long) val;
// }
//
// if (val instanceof String) {
// return Long.parseLong((String) val);
// }
//
// if (val instanceof List) {
// List list = (List) val;
// if (list.size() == 1) {
// return castToLong(list.get(0));
// }
// }
//
// if (val instanceof Boolean) {
// if (((Boolean) val).booleanValue()) {
// return 1l;
// } else {
// return 0l;
// }
// }
//
// return ((Number) val).longValue();
// }
//
// public static Float castToFloat(Object val) {
// if (val == null || val == EVAL_VALUE_NULL) {
// return null;
// }
//
// if (val instanceof Float) {
// return (Float) val;
// }
//
// return ((Number) val).floatValue();
// }
//
// public static Double castToDouble(Object val) {
// if (val == null || val == EVAL_VALUE_NULL) {
// return null;
// }
//
// if (val instanceof Double) {
// return (Double) val;
// }
//
// return ((Number) val).doubleValue();
// }
//
// public static BigInteger castToBigInteger(Object val) {
// if (val == null) {
// return null;
// }
//
// if (val instanceof BigInteger) {
// return (BigInteger) val;
// }
//
// if (val instanceof String) {
// return new BigInteger((String) val);
// }
//
// return BigInteger.valueOf(((Number) val).longValue());
// }
//
// public static Number castToNumber(String val) {
// if (val == null) {
// return null;
// }
//
// try {
// return Byte.parseByte(val);
// } catch (NumberFormatException e) {
// }
//
// try {
// return Short.parseShort(val);
// } catch (NumberFormatException e) {
// }
//
// try {
// return Integer.parseInt(val);
// } catch (NumberFormatException e) {
// }
//
// try {
// return Long.parseLong(val);
// } catch (NumberFormatException e) {
// }
//
// try {
// return Float.parseFloat(val);
// } catch (NumberFormatException e) {
// }
//
// try {
// return Double.parseDouble(val);
// } catch (NumberFormatException e) {
// }
//
// try {
// return new BigInteger(val);
// } catch (NumberFormatException e) {
// }
//
// try {
// return new BigDecimal(val);
// } catch (NumberFormatException e) {
// return 0;
// }
// }
//
// public static Date castToDate(Object val) {
// if (val == null) {
// return null;
// }
//
// if (val instanceof Date) {
// return (Date) val;
// }
//
// if (val instanceof Number) {
// return new Date(((Number) val).longValue());
// }
//
// if (val instanceof String) {
// return castToDate((String) val);
// }
//
// throw new DruidRuntimeException("can cast to date");
// }
//
// public static Date castToDate(String text) {
// if (text == null || text.length() == 0) {
// return null;
// }
//
// String format;
//
// if (text.length() == "yyyy-MM-dd".length()) {
// format = "yyyy-MM-dd";
// } else {
// format = "yyyy-MM-dd HH:mm:ss";
// }
//
// try {
// return new SimpleDateFormat(format).parse(text);
// } catch (ParseException e) {
// throw new DruidRuntimeException("format : " + format + ", value : " + text, e);
// }
// }
//
// public static BigDecimal castToDecimal(Object val) {
// if (val == null) {
// return null;
// }
//
// if (val instanceof BigDecimal) {
// return (BigDecimal) val;
// }
//
// if (val instanceof String) {
// return new BigDecimal((String) val);
// }
//
// if (val instanceof Float) {
// return new BigDecimal((Float) val);
// }
//
// if (val instanceof Double) {
// return new BigDecimal((Double) val);
// }
//
// return BigDecimal.valueOf(((Number) val).longValue());
// }
//
// public static Object rightShift(Object a, Object b) {
// if (a == null || b == null) {
// return null;
// }
//
// if (a instanceof Long || b instanceof Long) {
// return castToLong(a).longValue() >> castToLong(b).longValue();
// }
//
// return castToInteger(a).intValue() >> castToInteger(b).intValue();
// }
//
// public static Object bitAnd(Object a, Object b) {
// if (a == null || b == null) {
// return null;
// }
//
// if(a == EVAL_VALUE_NULL || b == EVAL_VALUE_NULL) {
// return null;
// }
//
// if (a instanceof String) {
// a = castToNumber((String) a);
// }
//
// if (b instanceof String) {
// b = castToNumber((String) b);
// }
//
// if (a instanceof Long || b instanceof Long) {
// return castToLong(a).longValue() & castToLong(b).longValue();
// }
//
// return castToInteger(a).intValue() & castToInteger(b).intValue();
// }
//
// public static Object bitOr(Object a, Object b) {
// if (a == null || b == null) {
// return null;
// }
//
// if(a == EVAL_VALUE_NULL || b == EVAL_VALUE_NULL) {
// return null;
// }
//
// if (a instanceof String) {
// a = castToNumber((String) a);
// }
//
// if (b instanceof String) {
// b = castToNumber((String) b);
// }
//
// if (a instanceof Long || b instanceof Long) {
// return castToLong(a).longValue() | castToLong(b).longValue();
// }
//
// return castToInteger(a).intValue() | castToInteger(b).intValue();
// }
//
// public static Object div(Object a, Object b) {
// if (a == null || b == null) {
// return null;
// }
//
// if(a == EVAL_VALUE_NULL || b == EVAL_VALUE_NULL) {
// return null;
// }
//
// if (a instanceof String) {
// a = castToNumber((String) a);
// }
//
// if (b instanceof String) {
// b = castToNumber((String) b);
// }
//
// if (a instanceof BigDecimal || b instanceof BigDecimal) {
// BigDecimal decimalA = castToDecimal(a);
// BigDecimal decimalB = castToDecimal(b);
// if (decimalB.scale() < decimalA.scale()) {
// decimalB = decimalB.setScale(decimalA.scale());
// }
// try {
// return decimalA.divide(decimalB);
// } catch (ArithmeticException ex) {
// return decimalA.divide(decimalB, BigDecimal.ROUND_HALF_UP);
// }
// }
//
// if (a instanceof Double || b instanceof Double) {
// Double doubleA = castToDouble(a);
// Double doubleB = castToDouble(b);
// if (doubleA == null || doubleB == null) {
// return null;
// }
// return doubleA / doubleB;
// }
//
// if (a instanceof Float || b instanceof Float) {
// Float floatA = castToFloat(a);
// Float floatB = castToFloat(b);
// if (floatA == null || floatB == null) {
// return null;
// }
// return floatA / floatB;
// }
//
// if (a instanceof BigInteger || b instanceof BigInteger) {
// return castToBigInteger(a).divide(castToBigInteger(b));
// }
//
// if (a instanceof Long || b instanceof Long) {
// Long longA = castToLong(a);
// Long longB = castToLong(b);
// if (longB == 0) {
// if (longA > 0) {
// return Double.POSITIVE_INFINITY;
// } else if (longA < 0) {
// return Double.NEGATIVE_INFINITY;
// } else {
// return Double.NaN;
// }
// }
// return longA / longB;
// }
//
// if (a instanceof Integer || b instanceof Integer) {
// Integer intA = castToInteger(a);
// Integer intB = castToInteger(b);
// if (intB == 0) {
// if (intA > 0) {
// return Double.POSITIVE_INFINITY;
// } else if (intA < 0) {
// return Double.NEGATIVE_INFINITY;
// } else {
// return Double.NaN;
// }
// }
// return intA / intB;
// }
//
// if (a instanceof Short || b instanceof Short) {
// return castToShort(a) / castToShort(b);
// }
//
// if (a instanceof Byte || b instanceof Byte) {
// return castToByte(a) / castToByte(b);
// }
//
// throw new IllegalArgumentException(a.getClass() + " and " + b.getClass() + " not supported.");
// }
//
// public static boolean gt(Object a, Object b) {
// if (a == null || a == EVAL_VALUE_NULL) {
// return false;
// }
//
// if (b == null || a == EVAL_VALUE_NULL) {
// return true;
// }
//
// if (a instanceof String || b instanceof String) {
// return castToString(a).compareTo(castToString(b)) > 0;
// }
//
// if (a instanceof BigDecimal || b instanceof BigDecimal) {
// return castToDecimal(a).compareTo(castToDecimal(b)) > 0;
// }
//
// if (a instanceof BigInteger || b instanceof BigInteger) {
// return castToBigInteger(a).compareTo(castToBigInteger(b)) > 0;
// }
//
// if (a instanceof Long || b instanceof Long) {
// return castToLong(a) > castToLong(b);
// }
//
// if (a instanceof Integer || b instanceof Integer) {
// return castToInteger(a) > castToInteger(b);
// }
//
// if (a instanceof Short || b instanceof Short) {
// return castToShort(a) > castToShort(b);
// }
//
// if (a instanceof Byte || b instanceof Byte) {
// return castToByte(a) > castToByte(b);
// }
//
// if (a instanceof Date || b instanceof Date) {
// Date d1 = castToDate(a);
// Date d2 = castToDate(b);
//
// if (d1 == d2) {
// return false;
// }
//
// if (d1 == null) {
// return false;
// }
//
// if (d2 == null) {
// return true;
// }
//
// return d1.compareTo(d2) > 0;
// }
//
// throw new IllegalArgumentException(a.getClass() + " and " + b.getClass() + " not supported.");
// }
//
// public static boolean gteq(Object a, Object b) {
// if (eq(a, b)) {
// return true;
// }
//
// return gt(a, b);
// }
//
// public static boolean lt(Object a, Object b) {
// if (a == null) {
// return true;
// }
//
// if (b == null) {
// return false;
// }
//
// if (a instanceof String || b instanceof String) {
// return (castToString(a)).compareTo(castToString(b)) < 0;
// }
//
// if (a instanceof BigDecimal || b instanceof BigDecimal) {
// return castToDecimal(a).compareTo(castToDecimal(b)) < 0;
// }
//
// if (a instanceof BigInteger || b instanceof BigInteger) {
// return castToBigInteger(a).compareTo(castToBigInteger(b)) < 0;
// }
//
// if (a instanceof Long || b instanceof Long) {
// return castToLong(a) < castToLong(b);
// }
//
// if (a instanceof Integer || b instanceof Integer) {
// Integer intA = castToInteger(a);
// Integer intB = castToInteger(b);
// return intA < intB;
// }
//
// if (a instanceof Short || b instanceof Short) {
// return castToShort(a) < castToShort(b);
// }
//
// if (a instanceof Byte || b instanceof Byte) {
// return castToByte(a) < castToByte(b);
// }
//
// if (a instanceof Date || b instanceof Date) {
// Date d1 = castToDate(a);
// Date d2 = castToDate(b);
//
// if (d1 == d2) {
// return false;
// }
//
// if (d1 == null) {
// return true;
// }
//
// if (d2 == null) {
// return false;
// }
//
// return d1.compareTo(d2) < 0;
// }
//
// throw new IllegalArgumentException(a.getClass() + " and " + b.getClass() + " not supported.");
// }
//
// public static boolean lteq(Object a, Object b) {
// if (eq(a, b)) {
// return true;
// }
//
// return lt(a, b);
// }
//
// public static boolean eq(Object a, Object b) {
// if (a == b) {
// return true;
// }
//
// if (a == null || b == null) {
// return false;
// }
//
// if (a == EVAL_VALUE_NULL || b == EVAL_VALUE_NULL) {
// return false;
// }
//
// if (a.equals(b)) {
// return true;
// }
//
// if (a instanceof String || b instanceof String) {
// return castToString(a).equals(castToString(b));
// }
//
// if (a instanceof BigDecimal || b instanceof BigDecimal) {
// return castToDecimal(a).compareTo(castToDecimal(b)) == 0;
// }
//
// if (a instanceof BigInteger || b instanceof BigInteger) {
// return castToBigInteger(a).compareTo(castToBigInteger(b)) == 0;
// }
//
// if (a instanceof Long || b instanceof Long) {
// return castToLong(a).equals(castToLong(b));
// }
//
// if (a instanceof Integer || b instanceof Integer) {
// Integer inta = castToInteger(a);
// Integer intb = castToInteger(b);
// if (inta == null || intb == null) {
// return false;
// }
// return inta.equals(intb);
// }
//
// if (a instanceof Short || b instanceof Short) {
// return castToShort(a).equals(castToShort(b));
// }
//
// if (a instanceof Boolean || b instanceof Boolean) {
// return castToBoolean(a).equals(castToBoolean(b));
// }
//
// if (a instanceof Byte || b instanceof Byte) {
// return castToByte(a).equals(castToByte(b));
// }
//
// if (a instanceof Date || b instanceof Date) {
// Date d1 = castToDate(a);
// Date d2 = castToDate(b);
//
// if (d1 == d2) {
// return true;
// }
//
// if (d1 == null || d2 == null) {
// return false;
// }
//
// return d1.equals(d2);
// }
//
// throw new IllegalArgumentException(a.getClass() + " and " + b.getClass() + " not supported.");
// }
//
// public static Object add(Object a, Object b) {
// if (a == null) {
// return b;
// }
//
// if (b == null) {
// return a;
// }
//
// if (a == EVAL_VALUE_NULL || b == EVAL_VALUE_NULL) {
// return EVAL_VALUE_NULL;
// }
//
// if (a instanceof String && !(b instanceof String)) {
// a = castToNumber((String) a);
// }
//
// if (b instanceof String && !(a instanceof String)) {
// b = castToNumber((String) b);
// }
//
// if (a instanceof BigDecimal || b instanceof BigDecimal) {
// return castToDecimal(a).add(castToDecimal(b));
// }
//
// if (a instanceof BigInteger || b instanceof BigInteger) {
// return castToBigInteger(a).add(castToBigInteger(b));
// }
//
// if (a instanceof Double || b instanceof Double) {
// return castToDouble(a) + castToDouble(b);
// }
//
// if (a instanceof Float || b instanceof Float) {
// return castToFloat(a) + castToFloat(b);
// }
//
// if (a instanceof Long || b instanceof Long) {
// return castToLong(a) + castToLong(b);
// }
//
// if (a instanceof Integer || b instanceof Integer) {
// return castToInteger(a) + castToInteger(b);
// }
//
// if (a instanceof Short || b instanceof Short) {
// return castToShort(a) + castToShort(b);
// }
//
// if (a instanceof Boolean || b instanceof Boolean) {
// int aI = 0, bI = 0;
// if (castToBoolean(a)) aI = 1;
// if (castToBoolean(b)) bI = 1;
// return aI + bI;
// }
//
// if (a instanceof Byte || b instanceof Byte) {
// return castToByte(a) + castToByte(b);
// }
//
// if (a instanceof String && b instanceof String) {
// return castToString(a) + castToString(b);
// }
//
// throw new IllegalArgumentException(a.getClass() + " and " + b.getClass() + " not supported.");
// }
//
// public static Object sub(Object a, Object b) {
// if (a == null) {
// return null;
// }
//
// if (b == null) {
// return a;
// }
//
// if (a == EVAL_VALUE_NULL || b == EVAL_VALUE_NULL) {
// return EVAL_VALUE_NULL;
// }
//
// if (a instanceof Date || b instanceof Date) {
// return SQLEvalVisitor.EVAL_ERROR;
// }
//
// if (a instanceof String) {
// a = castToNumber((String) a);
// }
//
// if (b instanceof String) {
// b = castToNumber((String) b);
// }
//
// if (a instanceof BigDecimal || b instanceof BigDecimal) {
// return castToDecimal(a).subtract(castToDecimal(b));
// }
//
// if (a instanceof BigInteger || b instanceof BigInteger) {
// return castToBigInteger(a).subtract(castToBigInteger(b));
// }
//
// if (a instanceof Double || b instanceof Double) {
// return castToDouble(a) - castToDouble(b);
// }
//
// if (a instanceof Float || b instanceof Float) {
// return castToFloat(a) - castToFloat(b);
// }
//
// if (a instanceof Long || b instanceof Long) {
// return castToLong(a) - castToLong(b);
// }
//
// if (a instanceof Integer || b instanceof Integer) {
// return castToInteger(a) - castToInteger(b);
// }
//
// if (a instanceof Short || b instanceof Short) {
// return castToShort(a) - castToShort(b);
// }
//
// if (a instanceof Boolean || b instanceof Boolean) {
// int aI = 0, bI = 0;
// if (castToBoolean(a)) aI = 1;
// if (castToBoolean(b)) bI = 1;
// return aI - bI;
// }
//
// if (a instanceof Byte || b instanceof Byte) {
// return castToByte(a) - castToByte(b);
// }
//
// // return SQLEvalVisitor.EVAL_ERROR;
// throw new IllegalArgumentException(a.getClass() + " and " + b.getClass() + " not supported.");
// }
//
// public static Object multi(Object a, Object b) {
// if (a == null || b == null) {
// return null;
// }
//
// if (a instanceof String) {
// a = castToNumber((String) a);
// }
//
// if (b instanceof String) {
// b = castToNumber((String) b);
// }
//
// if (a instanceof BigDecimal || b instanceof BigDecimal) {
// return castToDecimal(a).multiply(castToDecimal(b));
// }
//
// if (a instanceof BigInteger || b instanceof BigInteger) {
// return castToBigInteger(a).multiply(castToBigInteger(b));
// }
//
// if (a instanceof Double || b instanceof Double) {
// return castToDouble(a) * castToDouble(b);
// }
//
// if (a instanceof Float || b instanceof Float) {
// return castToFloat(a) * castToFloat(b);
// }
//
// if (a instanceof Long || b instanceof Long) {
// return castToLong(a) * castToLong(b);
// }
//
// if (a instanceof Integer || b instanceof Integer) {
// return castToInteger(a) * castToInteger(b);
// }
//
// if (a instanceof Short || b instanceof Short) {
// Short shortA = castToShort(a);
// Short shortB = castToShort(b);
//
// if (shortA == null || shortB == null) {
// return null;
// }
//
// return shortA * shortB;
// }
//
// if (a instanceof Byte || b instanceof Byte) {
// return castToByte(a) * castToByte(b);
// }
//
// throw new IllegalArgumentException(a.getClass() + " and " + b.getClass() + " not supported.");
// }
//
// public static boolean like(String input, String pattern) {
// if (pattern == null) {
// throw new IllegalArgumentException("pattern is null");
// }
//
// StringBuilder regexprBuilder = new StringBuilder(pattern.length() + 4);
//
// final int STAT_NOTSET = 0;
// final int STAT_RANGE = 1;
// final int STAT_LITERAL = 2;
//
// int stat = STAT_NOTSET;
//
// int blockStart = -1;
// for (int i = 0; i < pattern.length(); ++i) {
// char ch = pattern.charAt(i);
//
// if (stat == STAT_LITERAL //
// && (ch == '%' || ch == '_' || ch == '[')) {
// String block = pattern.substring(blockStart, i);
// regexprBuilder.append("\\Q");
// regexprBuilder.append(block);
// regexprBuilder.append("\\E");
// blockStart = -1;
// stat = STAT_NOTSET;
// }
//
// if (ch == '%') {
// regexprBuilder.append(".*");
// } else if (ch == '_') {
// regexprBuilder.append('.');
// } else if (ch == '[') {
// if (stat == STAT_RANGE) {
// throw new IllegalArgumentException("illegal pattern : " + pattern);
// }
// stat = STAT_RANGE;
// blockStart = i;
// } else if (ch == ']') {
// if (stat != STAT_RANGE) {
// throw new IllegalArgumentException("illegal pattern : " + pattern);
// }
// String block = pattern.substring(blockStart, i + 1);
// regexprBuilder.append(block);
//
// blockStart = -1;
// } else {
// if (stat == STAT_NOTSET) {
// stat = STAT_LITERAL;
// blockStart = i;
// }
//
// if (stat == STAT_LITERAL && i == pattern.length() - 1) {
// String block = pattern.substring(blockStart, i + 1);
// regexprBuilder.append("\\Q");
// regexprBuilder.append(block);
// regexprBuilder.append("\\E");
// }
// }
// }
// if ("%".equals(pattern) || "%%".equals(pattern)) {
// return true;
// }
//
// String regexpr = regexprBuilder.toString();
// return Pattern.matches(regexpr, input);
// }
//
// public static boolean visit(SQLEvalVisitor visitor, SQLIdentifierExpr x) {
// x.putAttribute(EVAL_EXPR, x);
// return false;
// }
//}