mirror of
https://github.com/tommyskeff/futur4j.git
synced 2026-01-18 07:16:45 +00:00
handle null in compose methods
This commit is contained in:
@@ -166,12 +166,16 @@ public abstract class AbstractPromise<T, F> implements Promise<T> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public <V> @NotNull Promise<V> thenComposeSync(@NotNull ExceptionalFunction<T, @NotNull Promise<V>> task) {
|
public <V> @NotNull Promise<V> thenComposeSync(@NotNull ExceptionalFunction<T, Promise<V>> task) {
|
||||||
Promise<V> promise = getFactory().unresolved();
|
Promise<V> promise = getFactory().unresolved();
|
||||||
thenApplySync(task).addDirectListener(
|
thenApplySync(task).addDirectListener(
|
||||||
nestedPromise -> {
|
nestedPromise -> {
|
||||||
|
if (nestedPromise == null) {
|
||||||
|
promise.complete(null);
|
||||||
|
} else {
|
||||||
propagateResult(nestedPromise, promise);
|
propagateResult(nestedPromise, promise);
|
||||||
propagateCancel(promise, nestedPromise);
|
propagateCancel(promise, nestedPromise);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
promise::completeExceptionally
|
promise::completeExceptionally
|
||||||
);
|
);
|
||||||
@@ -267,8 +271,12 @@ public abstract class AbstractPromise<T, F> implements Promise<T> {
|
|||||||
Promise<V> promise = getFactory().unresolved();
|
Promise<V> promise = getFactory().unresolved();
|
||||||
thenApplyAsync(task).addDirectListener(
|
thenApplyAsync(task).addDirectListener(
|
||||||
nestedPromise -> {
|
nestedPromise -> {
|
||||||
|
if (nestedPromise == null) {
|
||||||
|
promise.complete(null);
|
||||||
|
} else {
|
||||||
propagateResult(nestedPromise, promise);
|
propagateResult(nestedPromise, promise);
|
||||||
propagateCancel(promise, nestedPromise);
|
propagateCancel(promise, nestedPromise);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
promise::completeExceptionally
|
promise::completeExceptionally
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ public interface Promise<T> {
|
|||||||
|
|
||||||
<V> @NotNull Promise<V> thenApplyDelayedSync(@NotNull ExceptionalFunction<T, V> task, long delay, @NotNull TimeUnit unit);
|
<V> @NotNull Promise<V> thenApplyDelayedSync(@NotNull ExceptionalFunction<T, V> task, long delay, @NotNull TimeUnit unit);
|
||||||
|
|
||||||
<V> @NotNull Promise<V> thenComposeSync(@NotNull ExceptionalFunction<T, @NotNull Promise<V>> task);
|
<V> @NotNull Promise<V> thenComposeSync(@NotNull ExceptionalFunction<T, Promise<V>> task);
|
||||||
|
|
||||||
@NotNull Promise<Void> thenRunAsync(@NotNull ExceptionalRunnable task);
|
@NotNull Promise<Void> thenRunAsync(@NotNull ExceptionalRunnable task);
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user