DBInIgnoreCaseOperator.java

/*
 * Copyright 2013 Gregory Graham.
 *
 * 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 nz.co.gregs.dbvolution.operators;

import java.util.ArrayList;
import java.util.List;

import nz.co.gregs.dbvolution.databases.definitions.DBDefinition;
import nz.co.gregs.dbvolution.datatypes.QueryableDatatypeSyncer.DBSafeInternalQDTAdaptor;
import nz.co.gregs.dbvolution.expressions.BooleanExpression;
import nz.co.gregs.dbvolution.expressions.DBExpression;
import nz.co.gregs.dbvolution.expressions.InExpression;
import nz.co.gregs.dbvolution.expressions.StringExpression;
import nz.co.gregs.dbvolution.results.StringResult;

/**
 * Implements a case-insensitive version of IN for Strings.
 *
 *
 * @author gregorygraham
 */
public class DBInIgnoreCaseOperator extends DBInOperator {

	private static final long serialVersionUID = 1L;

	/**
	 * Implements a case-insensitive version of IN for Strings.
	 *
	 * @param listOfPossibleValues the values that all the database values are to
	 * compared with
	 */
	public DBInIgnoreCaseOperator(List<DBExpression> listOfPossibleValues) {
		super(listOfPossibleValues);
	}

	/**
	 * Default constructor
	 */
	public DBInIgnoreCaseOperator() {
		super();
	}

	@Override
	public DBInIgnoreCaseOperator copyAndAdapt(DBSafeInternalQDTAdaptor typeAdaptor) {
		ArrayList<DBExpression> list = new ArrayList<DBExpression>();
		for (DBExpression item : listOfPossibleValues) {
			list.add(typeAdaptor.convert(item));
		}
		DBInIgnoreCaseOperator op = new DBInIgnoreCaseOperator(list);
		op.invertOperator = this.invertOperator;
		op.includeNulls = this.includeNulls;
		return op;
	}

	@Override
	public BooleanExpression generateWhereExpression(DBDefinition db, DBExpression column) {
		DBExpression genericExpression = column;
		BooleanExpression op = BooleanExpression.trueExpression();
		if (genericExpression instanceof StringExpression) {
			StringExpression stringExpression = (StringExpression) genericExpression;
			op = stringExpression.bracket().isInIgnoreCase(listOfPossibleStrings.toArray(new StringResult[]{}));
		} else if (genericExpression instanceof InExpression) {
			InExpression expr = (InExpression) genericExpression;
			op = expr.isIn(getFirstValue());
		}
		return this.invertOperator ? op.not() : op;
	}
}