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  }