eu.lunisolar.magma.func.build.PerCaseBuilderWithLongProduct Maven / Gradle / Ivy
The newest version!
/*
* This file is part of "lunisolar-magma".
*
* (C) Copyright 2014-2019 Lunisolar (http://lunisolar.eu/).
*
* 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 eu.lunisolar.magma.func.build;
import eu.lunisolar.magma.basics.fluent.Fluent;
import eu.lunisolar.magma.basics.fluent.FluentSubcontext;
import javax.annotation.Nonnull;
import javax.annotation.concurrent.Immutable;
import javax.annotation.concurrent.ThreadSafe;
import java.util.*;
import java.util.function.*;
import eu.lunisolar.magma.basics.builder.*;
import eu.lunisolar.magma.func.action.*; // NOSONAR
import eu.lunisolar.magma.func.consumer.*; // NOSONAR
import eu.lunisolar.magma.func.consumer.primitives.*; // NOSONAR
import eu.lunisolar.magma.func.consumer.primitives.bi.*; // NOSONAR
import eu.lunisolar.magma.func.consumer.primitives.obj.*; // NOSONAR
import eu.lunisolar.magma.func.consumer.primitives.tri.*; // NOSONAR
import eu.lunisolar.magma.func.function.*; // NOSONAR
import eu.lunisolar.magma.func.function.conversion.*; // NOSONAR
import eu.lunisolar.magma.func.function.from.*; // NOSONAR
import eu.lunisolar.magma.func.function.to.*; // NOSONAR
import eu.lunisolar.magma.func.operator.binary.*; // NOSONAR
import eu.lunisolar.magma.func.operator.ternary.*; // NOSONAR
import eu.lunisolar.magma.func.operator.unary.*; // NOSONAR
import eu.lunisolar.magma.func.predicate.*; // NOSONAR
import eu.lunisolar.magma.func.supplier.*; // NOSONAR
/**
* Abstract implementation of a per case builder of a complex implementation of a functional interface.
*
* Each case consist of a appropriate condition - predicate, supplier, or operator depending on the functional interface type - and a evaluating function
* (same type as overall function) that will be called when condition expression evaluates to **true**.
*
* Cases are evaluated in a order one by one. First condition that returns **true** will decide what function will be called. Eventually if no condition is
* evaluating to **true** a last resort function _otherwise_ is called. By default _otherwise_ will throw an exception that there is no case that will cover
* the input data. This default _otherwise_ behavior can be overridden.
*/
@SuppressWarnings("unchecked")
public abstract class PerCaseBuilderWithLongProduct, P, F, PC extends PartialCaseWithLongProduct> extends PerCaseBuilder {
protected @Nonnull final LLongFunction directToFunction;
protected PerCaseBuilderWithLongProduct(@Nonnull F otherwise, @Nonnull LLongFunction directToFunction, @Nonnull Supplier subCasesFactory) {
super(otherwise, subCasesFactory);
this.directToFunction = directToFunction;
}
//
/** Sets the function to evaluate _otherwise_ when input data do not match any case. */
public final PCB otherwiseProduce(long directValue) {
otherwise = directToFunction.apply(directValue);
return self();
}
//
protected PC partialCaseFactoryMethod(P casePredicate) {
return (PC) new PartialCaseWithLongProduct(self(), casePredicate, subCasesFactory);
}
public static abstract class Base, P, F> extends PerCaseBuilderWithLongProduct> {
protected Base(@Nonnull F otherwise, @Nonnull LLongFunction directToFunction, @Nonnull Supplier subCasesFactory) {
super(otherwise, directToFunction, subCasesFactory);
}
@Override
protected PartialCaseWithLongProduct.The partialCaseFactoryMethod(P casePredicate) {
return new PartialCaseWithLongProduct.The(this, casePredicate, subCasesFactory);
}
}
}