Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
// ============================================================================
// Copyright (c) 2017-2019 Nawapunth Manusitthipol (NawaMan - http://nawaman.net).
// ----------------------------------------------------------------------------
// MIT License
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in all
// copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
// SOFTWARE.
// ============================================================================
package functionalj.promise;
import static functionalj.function.Func.carelessly;
import static java.util.Objects.requireNonNull;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.atomic.AtomicReference;
import java.util.function.Consumer;
import java.util.function.Function;
import java.util.function.Predicate;
import java.util.function.Supplier;
import functionalj.function.Func0;
import functionalj.function.Func1;
import functionalj.function.Func2;
import functionalj.function.Func3;
import functionalj.function.Func4;
import functionalj.function.Func5;
import functionalj.function.Func6;
import functionalj.function.FuncUnit1;
import functionalj.function.FuncUnit2;
import functionalj.function.NamedExpression;
import functionalj.pipeable.Pipeable;
import functionalj.ref.Ref;
import functionalj.result.HasResult;
import functionalj.result.Result;
import lombok.val;
// TODO - Find a way to make toString more useful ... like giving this a name.
// TODO - Should extract important stuff to PromiseBase ... so it is not flooded with the less important things.
@SuppressWarnings("javadoc")
public class Promise implements HasPromise, HasResult, Pipeable> {
private static final int INITIAL_CAPACITY = 2;
public static final Ref waitTimeout = Ref.ofValue(-1L);
public static Promise ofResult(HasResult asResult) {
if (asResult instanceof HasPromise)
return ((HasPromise)asResult).getPromise();
return DeferActionBuilder
.from(()->asResult.getResult().value())
.build()
.getPromise();
}
public static Promise of(D value) {
return DeferAction.of((Class)null)
.start()
.complete(value)
.getPromise();
}
public static Promise ofException(Exception exception) {
return DeferAction.of((Class)null)
.start()
.fail(exception)
.getPromise();
}
public static Promise ofAborted() {
return DeferAction.of((Class)null)
.start()
.abort()
.getPromise();
}
public static Promise from(
NamedExpression> promise1,
NamedExpression> promise2,
Func2 merger) {
val action = DeferAction.from(promise1, promise2, merger);
val promise = action.getPromise();
return promise;
}
public static Promise from(
NamedExpression> promise1,
NamedExpression> promise2,
NamedExpression> promise3,
Func3 merger) {
val action = DeferAction.from(promise1, promise2, promise3, merger);
val promise = action.getPromise();
return promise;
}
public static Promise from(
NamedExpression> promise1,
NamedExpression> promise2,
NamedExpression> promise3,
NamedExpression> promise4,
Func4 merger) {
val action = DeferAction.from(promise1, promise2, promise3, promise4, merger);
val promise = action.getPromise();
return promise;
}
public static Promise from(
NamedExpression> promise1,
NamedExpression> promise2,
NamedExpression> promise3,
NamedExpression> promise4,
NamedExpression> promise5,
Func5 merger) {
val action = DeferAction.from(promise1, promise2, promise3, promise4, promise5, merger);
val promise = action.getPromise();
return promise;
}
public static Promise from(
NamedExpression> promise1,
NamedExpression> promise2,
NamedExpression> promise3,
NamedExpression> promise4,
NamedExpression> promise5,
NamedExpression> promise6,
Func6 merger) {
val action = DeferAction.from(promise1, promise2, promise3, promise4, promise5, promise6, merger);
val promise = action.getPromise();
return promise;
}
// DATA
// StartableAction -> NOT START
// consumer -> Pending
// result -> done.
// result.cancelled -> aborted
// result.completed -> completed
final Map, FuncUnit1>> consumers = new ConcurrentHashMap<>(INITIAL_CAPACITY);
final List>> eavesdroppers = new ArrayList<>(INITIAL_CAPACITY);
private static final AtomicInteger ID = new AtomicInteger(0);
final AtomicReference