/**
* Copyright (C) 2013 Kametic <epo.jemba@kametic.com>
*
* Licensed under the GNU LESSER GENERAL PUBLIC LICENSE, Version 3, 29 June 2007;
* or any later version
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.gnu.org/licenses/lgpl-3.0.txt
*
* 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 org.nuunframework.kernel.commons.specification;
import org.apache.commons.lang.ObjectUtils;
public abstract class CompareToSpecification<T extends Comparable<T>> extends AbstractSpecification<T> {
private final T value;
/**
* Construct a new {@link CompareToSpecification}.
* @param value the value that our candidate should compared to
*/
public CompareToSpecification(T value) {
this.value = value;
}
/**
* {@inheritDoc}
*/
@Override
public boolean isSatisfiedBy(T candidate) {
int comparison = ObjectUtils.compare(candidate, value);
return this.isSatisfyingComparison(comparison);
}
/**
* See if a comparison satisfies all the requirements expressed in this specification.
* @param comparison the comparison value between our candidate property and the specified value
* @return {@code true} if the comparison has been accepted, otherwise {@code false}
*/
protected abstract boolean isSatisfyingComparison(int comparison);
/**
* Retrieve the value we are comparing our candidates to.
* @return the current value we are comparing to
*/
protected T getValue() {
return value;
}
}