1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package io.netty.util.concurrent;
17
18 import io.netty.util.internal.ObjectUtil;
19 import io.netty.util.internal.logging.InternalLogger;
20 import io.netty.util.internal.logging.InternalLoggerFactory;
21
22 public final class UnaryPromiseNotifier<T> implements FutureListener<T> {
23 private static final InternalLogger logger = InternalLoggerFactory.getInstance(UnaryPromiseNotifier.class);
24 private final Promise<? super T> promise;
25
26 public UnaryPromiseNotifier(Promise<? super T> promise) {
27 this.promise = ObjectUtil.checkNotNull(promise, "promise");
28 }
29
30 @Override
31 public void operationComplete(Future<T> future) throws Exception {
32 cascadeTo(future, promise);
33 }
34
35 public static <X> void cascadeTo(Future<X> completedFuture, Promise<? super X> promise) {
36 if (completedFuture.isSuccess()) {
37 if (!promise.trySuccess(completedFuture.getNow())) {
38 logger.warn("Failed to mark a promise as success because it is done already: {}", promise);
39 }
40 } else if (completedFuture.isCancelled()) {
41 if (!promise.cancel(false)) {
42 logger.warn("Failed to cancel a promise because it is done already: {}", promise);
43 }
44 } else {
45 if (!promise.tryFailure(completedFuture.cause())) {
46 logger.warn("Failed to mark a promise as failure because it's done already: {}", promise,
47 completedFuture.cause());
48 }
49 }
50 }
51 }