Class CompletableFutureUtils
java.lang.Object
software.amazon.awssdk.utils.CompletableFutureUtils
Utility class for working with 
CompletableFuture.- 
Method SummaryModifier and TypeMethodDescriptionstatic CompletableFuture<Void> allOfExceptionForwarded(CompletableFuture<?>[] futures) Similar toCompletableFuture.allOf(CompletableFuture[]), but when any future is completed exceptionally, forwards the exception to other futures.static CompletionExceptionWraps the given error in aCompletionExceptionif necessary.static <U> CompletableFuture<U> Convenience method for creating a future that is immediately completed exceptionally with the givenThrowable.static <T> CompletableFuture<T> forwardExceptionTo(CompletableFuture<T> src, CompletableFuture<?> dst) Forward theThrowablefromsrctodst.static <T> CompletableFuture<T> forwardResultTo(CompletableFuture<T> src, CompletableFuture<T> dst) Completes thedstfuture based on the result of thesrcfuture asynchronously on the providedExecutorand return thesrcfuture.static <T> CompletableFuture<T> forwardResultTo(CompletableFuture<T> src, CompletableFuture<T> dst, Executor executor) Completes thedstfuture based on the result of thesrcfuture asynchronously on the providedExecutorand return thesrcfuture.static <T> CompletableFuture<T> forwardTransformedExceptionTo(CompletableFuture<T> src, CompletableFuture<?> dst, Function<Throwable, Throwable> transformationFunction) Forward theThrowablethat can be transformed as per the transformationFunction fromsrctodst.static <SourceT,DestT> 
 CompletableFuture<SourceT> forwardTransformedResultTo(CompletableFuture<SourceT> src, CompletableFuture<DestT> dst, Function<SourceT, DestT> function) Completes thedstfuture based on the result of thesrcfuture, synchronously, after applying the provided transformationFunctionif successful.static <T> TjoinInterruptibly(CompletableFuture<T> future) static voidstatic <T> TjoinLikeSync(CompletableFuture<T> future) Joins (interruptibly) on the future, and re-throws any RuntimeExceptions or Errors just like the async task would have thrown if it was executed synchronously.
- 
Method Details- 
failedFutureConvenience method for creating a future that is immediately completed exceptionally with the givenThrowable.Similar to CompletableFuture#failedFuturewhich was added in Java 9.- Type Parameters:
- U- The type of the element.
- Parameters:
- t- The failure.
- Returns:
- The failed future.
 
- 
errorAsCompletionExceptionWraps the given error in aCompletionExceptionif necessary. Useful if an exception needs to be rethrown from withinCompletableFuture.handle(java.util.function.BiFunction)or similar methods.- Parameters:
- t- The error.
- Returns:
- The error as a CompletionException.
 
- 
forwardExceptionTopublic static <T> CompletableFuture<T> forwardExceptionTo(CompletableFuture<T> src, CompletableFuture<?> dst) Forward theThrowablefromsrctodst.- Parameters:
- src- The source of the- Throwable.
- dst- The destination where the- Throwablewill be forwarded to.
- Returns:
- src.
 
- 
forwardTransformedExceptionTopublic static <T> CompletableFuture<T> forwardTransformedExceptionTo(CompletableFuture<T> src, CompletableFuture<?> dst, Function<Throwable, Throwable> transformationFunction) Forward theThrowablethat can be transformed as per the transformationFunction fromsrctodst.- Parameters:
- src- The source of the- Throwable.
- dst- The destination where the- Throwablewill be forwarded to
- transformationFunction- Transformation function taht will be applied on to the forwarded exception.
- Returns:
 
- 
forwardResultTopublic static <T> CompletableFuture<T> forwardResultTo(CompletableFuture<T> src, CompletableFuture<T> dst) Completes thedstfuture based on the result of thesrcfuture asynchronously on the providedExecutorand return thesrcfuture.- Parameters:
- src- The source- CompletableFuture
- dst- The destination where the- Throwableor response will be forwarded to.
- Returns:
- the srcfuture.
 
- 
forwardResultTopublic static <T> CompletableFuture<T> forwardResultTo(CompletableFuture<T> src, CompletableFuture<T> dst, Executor executor) Completes thedstfuture based on the result of thesrcfuture asynchronously on the providedExecutorand return thesrcfuture.- Parameters:
- src- The source- CompletableFuture
- dst- The destination where the- Throwableor response will be forwarded to.
- executor- the executor to complete the des future
- Returns:
- the srcfuture.
 
- 
forwardTransformedResultTopublic static <SourceT,DestT> CompletableFuture<SourceT> forwardTransformedResultTo(CompletableFuture<SourceT> src, CompletableFuture<DestT> dst, Function<SourceT, DestT> function) Completes thedstfuture based on the result of thesrcfuture, synchronously, after applying the provided transformationFunctionif successful. If the function threw an exception, the destination future will be completed exceptionally with that exception.- Parameters:
- src- The source- CompletableFuture
- dst- The destination where the- Throwableor transformed result will be forwarded to.
- Returns:
- the srcfuture.
 
- 
allOfExceptionForwardedSimilar toCompletableFuture.allOf(CompletableFuture[]), but when any future is completed exceptionally, forwards the exception to other futures.- Parameters:
- futures- The futures.
- Returns:
- The new future that is completed when all the futures in futuresare.
 
- 
joinInterruptibly
- 
joinInterruptiblyIgnoringFailures
- 
joinLikeSyncJoins (interruptibly) on the future, and re-throws any RuntimeExceptions or Errors just like the async task would have thrown if it was executed synchronously.
 
-