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

org.dbflute.optional.OptionalThing Maven / Gradle / Ivy

There is a newer version: 1.2.8
Show newest version
/*
 * Copyright 2014-2021 the original author or authors.
 *
 * 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 org.dbflute.optional;

import java.util.Optional;
import java.util.stream.Stream;

import org.dbflute.helper.function.IndependentProcessor;

/**
 * @param  The type of thing.
 * @author jflute
 * @since 1.0.5F (2014/05/05 Monday)
 */
public interface OptionalThing {

    // ===================================================================================
    //                                                                         Constructor
    //                                                                         ===========
    // using as object
    /**
     * @param  The type of empty optional thing.
     * @return The fixed instance as empty. (NotNull)
     */
    public static  OptionalThing empty() {
        return OptionalObject.empty();
    }

    /**
     * @param  The type of thing wrapped in the optional thing.
     * @param object The wrapped thing which is optional. (NotNull)
     * @return The new-created instance as existing optional thing. (NotNull)
     */
    public static  OptionalThing of(THING object) {
        return OptionalObject.of(object);
    }

    /**
     * @param  The type of thing wrapped in the optional thing.
     * @param object The wrapped instance or thing. (NullAllowed)
     * @param noArgLambda The callback for exception when illegal access. (NotNull)
     * @return The new-created instance as existing or empty optional thing. (NotNull)
     */
    public static  OptionalThing ofNullable(THING object, OptionalThingExceptionThrower noArgLambda) {
        return OptionalObject.ofNullable(object, noArgLambda);
    }

    /**
     * @param  The type of thing wrapped in the optional thing.
     * @param java8opt The optional instance as Java8 standard optional. (NotNull)
     * @param noArgLambda The callback for exception when illegal access. (NotNull)
     * @return The new-created instance as existing or empty optional thing. (NotNull)
     */
    public static  OptionalThing migratedFrom(Optional java8opt, OptionalThingExceptionThrower noArgLambda) {
        return OptionalObject.ofNullable(java8opt.orElse(null), noArgLambda);
    }

    /**
     * @param  The type of thing wrapped in the optional thing.
     * @param dfopt The optional instance as optional thing DBFlute provides. (NotNull)
     * @param noArgLambda The callback for exception when illegal access. (NotNull)
     * @return The new-created instance as existing or empty optional thing. (NotNull)
     */
    public static  OptionalThing translatedFrom(OptionalThing dfopt, OptionalThingExceptionThrower noArgLambda) {
        return OptionalObject.ofNullable(dfopt.orElse(null), noArgLambda);
    }

    // ===================================================================================
    //                                                                   Standard Handling
    //                                                                   =================
    // -----------------------------------------------------
    //                                             ifPresent
    //                                             ---------
    /**
     * Handle the wrapped thing if it is present. 
* You should call this if empty handling is unnecessary (do nothing if not present).
* If exception is preferred when null object, use alwaysPresent(). * @param oneArgLambda The callback interface to consume the optional thing. (NotNull) * @return The handler of after process when if not present. (NotNull) */ OptionalThingIfPresentAfter ifPresent(OptionalThingConsumer oneArgLambda); /** * Handle the wrapped thing if it is both present and empty. * @param oneArgLambda The present-case callback interface to consume the optional thing. (NotNull) * @param noArgLambda The empty-case callback interface to handle or-else. (NotNull) */ void ifPresentOrElse(OptionalThingConsumer oneArgLambda, IndependentProcessor noArgLambda); // as java9 // ----------------------------------------------------- // isPresent/get // ------------- /** * Is the object instance present? (existing?) * @return The determination, true or false. */ boolean isPresent(); /** * Is the object instance empty? (not existing?) * @return The determination, true or false. */ boolean isEmpty(); // as java11 /** * Get the thing or (detail message) exception if not present. * @return The instance of the wrapped thing. (NotNull) * @throws RuntimeException When not present, which means object is already deleted (not found). */ THING get(); // ----------------------------------------------------- // or/orElse // --------- /** * Switch this to other optional if not present. * @param noArgLambda The supplier of other optional if not present. (NotNull) * @return this or optional provided by supplier. (NotNull, EmptyAllowed: provided one may be empty) */ OptionalThing or(OptionalThingSupplier> noArgLambda); // as java9 /** * Get the wrapped instance or returns the specified thing. * @param other The object instance to be returned when the optional is empty. (NullAllowed) * @return The wrapped instance or specified other object. (NullAllowed:) */ THING orElse(THING other); /** * Get the thing or get from the supplier. * @param noArgLambda The supplier of other instance if not present. (NotNull) * @return The object instance wrapped in this optional thing or specified value. (NullAllowed: if null specified) */ THING orElseGet(OptionalThingSupplier noArgLambda); /** * Get the thing or throw the embedded exception.
* Actually same as get(), similar to alwaysPresent(). * @return The object instance wrapped in this optional object. (NotNull: if not present, exception) * @throws RuntimeException When not present, which means object is already deleted (not found). */ THING orElseThrow(); // as java10 /** * Get the thing or throw the exception.
* However the orElseTranslatingThrow() is recommended instead this. * @param The type of cause. * @param noArgLambda The supplier of exception if not present. (NotNull) * @return The object instance wrapped in this optional object. (NotNull: if not present, exception) * @throws CAUSE When the value is null. */ THING orElseThrow(OptionalThingSupplier noArgLambda) throws CAUSE; /** * Get the thing or throw the exception with translating the cause. *
     * OptionalThing<String> optSea = ...
     * String sea = optSea.orElseTranslatingThrow(cause -> {
     *     return new YourBusinessException("...", cause); // you can wrap the detail exception
     * }
     * 
* @param The type of original cause. * @param The type of translated cause. * @param causeLambda The translator function of cause exception if not present, returning your exception. (NotNull) * @return The object instance wrapped in this optional object. (NotNull: if not present, exception) * @throws TRANSLATED When the value is null. */ THING orElseTranslatingThrow( OptionalThingFunction causeLambda) throws TRANSLATED; // ----------------------------------------------------- // filter/map // ---------- /** * Filter the thing by the predicate. * @param oneArgLambda The callback to predicate whether the object is remained. (NotNull) * @return The filtered optional thing, might be empty. (NotNull) */ OptionalThing filter(OptionalThingPredicate oneArgLambda); /** * Apply the mapping of thing to result thing. * @param The type of mapping result. * @param oneArgLambda The callback interface to apply, null return allowed as empty. (NotNull) * @return The optional thing as mapped result. (NotNull, EmptyOptionalAllowed: if not present or callback returns null) */ OptionalThing map(OptionalThingFunction oneArgLambda); /** * Apply the flat-mapping of thing to result thing. * @param The type of mapping result. * @param oneArgLambda The callback interface to apply, cannot return null. (NotNull) * @return The optional thing as mapped result. (NotNull, EmptyOptionalAllowed: if not present or callback returns null) */ OptionalThing flatMap(OptionalThingFunction> oneArgLambda); // ----------------------------------------------------- // stream // ------ /** * Handle the optional thing as stream. * @return The stream for the optional thing, may be empty (if not present). (NotNull, EmptyAllowed: if not present) */ Stream stream(); // as java9 // =================================================================================== // DBFlute Extension // ================= /** * Handle the thing in the optional thing or (detail message) exception if not present. *
     * memberBhv.selectEntity(cb -> {
     *     cb.setupSelect_MemberStatus();
     *     cb.query().setMemberId_Equal(1);
     * }).alwaysPresent(member -> { // called if value exists, or exception
     *     ... = member.getMemberName();
     *     member.getMemberStatus().alwaysPresent(status -> { // also relationship
     *         ... = status.getMemberStatusName();
     *     });
     * });
     * 
* @param oneArgLambda The callback interface to consume the optional thing. (NotNull) * @throws RuntimeException When not present, which means object is already deleted (not found). */ void alwaysPresent(OptionalThingConsumer oneArgLambda); // =================================================================================== // Convert to Optional // =================== /** * Convert to Java standard optional class.
* For only when standard optional handling is needed, so basically you don't use this. * @return The new-created instance or empty. (NotNull) */ Optional toOptional(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy