All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.speedment.runtime.field.comparator.FieldComparator Maven / Gradle / Ivy

Go to download

A Speedment bundle that shades all dependencies into one jar. This is useful when deploying an application on a server.

The newest version!
/*
 *
 * Copyright (c) 2006-2019, Speedment, Inc. All Rights Reserved.
 *
 * 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.speedment.runtime.field.comparator;

import com.speedment.runtime.field.Field;

import java.util.Comparator;

/**
 * A specialized {@link Comparator} that contains meta data information about 
 * the field that is being compared.
 * 

* Implementations of this interface are immutable. Equality is based upon the * equality of the {@link #getField() field}-identifier, the * {@link #getNullOrder() null strategy} and the {@link #isReversed() order}. * * @param the entity type * * @author Emil Forslund * @since 3.0.2 */ public interface FieldComparator extends Comparator { /** * Returns the field that created this comparator. * * @return the field */ Field getField(); /** * Returns the strategy used when {@code null} values are encountered. If * the order {@link NullOrder#NONE} is specified, then no guarantees will be * made regarding the order of entities where the field value is * {@code null}. * * @return the null order strategy */ NullOrder getNullOrder(); /** * Returns {@code true} if this comparator reverses the natural order of the * values in the current field. A reversed order descends from high values * to low. * * @return {@code true} if reversed (descending), else {@code false} */ boolean isReversed(); /** * Returns a new {@code FieldComparator} that order entities in the opposite * orders compared to this comparator. For an example, if this comparator * orders entities based on a column 'firstname' in descending order, then * the returned {@code FieldComparator} will be ordering entities based on * 'firstname' in ascending order. * * @return a new reverse comparator */ @Override FieldComparator reversed(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy