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

com.github.rutledgepaulv.qbuilders.properties.virtual.InstantLikeProperty Maven / Gradle / Ivy

/*
 *
 *  *  com.github.rutledgepaulv.qbuilders.properties.virtual.InstantLikeProperty
 *  *  *
 *  *  * Copyright (C) 2016 Paul Rutledge 
 *  *  *
 *  *  * This software may be modified and distributed under the terms
 *  *  * of the MIT license.  See the LICENSE file for details.
 *  *
 *
 */

package com.github.rutledgepaulv.qbuilders.properties.virtual;

import com.github.rutledgepaulv.qbuilders.builders.QBuilder;
import com.github.rutledgepaulv.qbuilders.conditions.Condition;

/**
 * For date-like properties
 *
 * @param  The final type of the builder.
 * @param  The type of the date that the property supports.
 */
public interface InstantLikeProperty, S> extends EquitableProperty {

    /**
     * Mandates that the date-like field must be before the provided date
     *
     * @param dateTime The date-like representation that it should occur before.
     * @param exclusive True if the query should not match the provided date, false if it should.
     * @return The logically complete condition.
     */
    Condition before(S dateTime, boolean exclusive);

    /**
     * Mandates that the date-like field must be after the provided date
     *
     * @param dateTime The date-like representation that it should occur after.
     * @param exclusive True if the query should not match the provided date, false if it should.
     * @return The logically complete condition.
     */
    Condition after(S dateTime, boolean exclusive);

    /**
     * Mandates that the date-like field must be within the provided range.
     *
     * @param after The date-like representation that it should occur after.
     * @param exclusiveAfter True if the query should not match the provided date, false if it should.
     * @param before The date-like representation that it should occur before.
     * @param exclusiveBefore True if the query should not match the provided date, false if it should.
     * @return The logically complete condition.
     */
    Condition between(S after, boolean exclusiveAfter, S before, boolean exclusiveBefore);

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy