/* XXL: The eXtensible and fleXible Library for data processing Copyright (C) 2000-2011 Prof. Dr. Bernhard Seeger Head of the Database Research Group Department of Mathematics and Computer Science University of Marburg Germany This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library; If not, see <http://www.gnu.org/licenses/>. http://code.google.com/p/xxl/ */ package xxl.core.comparators; import java.io.Serializable; import java.util.Comparator; /** * The EmbeddingComparator adds a bound to a given comparator. * * @param <T> the type of the objects to be compared with this comparator. * @see java.util.Comparator */ public class EmbeddingComparator<T> implements Comparator<T>, Serializable { /** * The comparator to be wrapped. */ protected Comparator<? super T> comparator; /** * The bound of the comparator. */ protected T bound; /** * Determines whether the bound is the lower bound. */ protected boolean lowerBound; /** * Creates a new EmbeddingComparator. * * @param comparator the comparator to be wrapped. * @param bound the bound of the comparator. * @param lowerBound determines whether the bound is the lower bound. */ public EmbeddingComparator(Comparator<? super T> comparator, T bound, boolean lowerBound) { this.comparator = comparator; this.bound = bound; this.lowerBound = lowerBound; } /** * Creates a new EmbeddingComparator. * * @param comparator the comparator to be wrapped. * @param lowerBound determines whether the bound is the lower bound. */ public EmbeddingComparator(Comparator<? super T> comparator, boolean lowerBound) { this(comparator, null, lowerBound); } /** * Creates a new EmbeddingComparator. * * @param comparator the comparator to be wrapped. * @param bound the bound of the comparator. */ public EmbeddingComparator(Comparator<? super T> comparator, T bound) { this(comparator, bound, true); } /** * Creates a new EmbeddingComparator. * * @param comparator the comparator to be wrapped */ public EmbeddingComparator(Comparator<? super T> comparator) { this(comparator, null); } /** * Compares its two arguments for order. * * @param object1 the first object to be compared. * @param object2 the second object to be compared. * @return a negative integer, zero, or a positive integer as the first * argument is less than, equal to, or greater than the second. */ public int compare(T object1, T object2) { if (bound == object1 || (bound != null ? bound.equals(object1) : object1.equals(bound))) return lowerBound? Integer.MIN_VALUE: Integer.MAX_VALUE; if (bound == object2 || (bound != null ? bound.equals(object2) : object2.equals(bound))) return lowerBound? Integer.MAX_VALUE: Integer.MIN_VALUE; return comparator.compare(object1, object2); } }