Class ContentSourceCompletableFuture<X>
java.lang.Object
java.util.concurrent.CompletableFuture<X>
org.eclipse.jetty.io.content.ContentSourceCompletableFuture<X>
- All Implemented Interfaces:
- Runnable, CompletionStage<X>, Future<X>, Invocable, Invocable.Task
- Direct Known Subclasses:
- FormFields
public abstract class ContentSourceCompletableFuture<X>
extends CompletableFuture<X>
implements Invocable.Task
A utility class to convert content from a Content.Source to an instance
available via a CompletableFuture.
An example usage to asynchronously read UTF-8 content is:
public static class CompletableUTF8String extends ContentSourceCompletableFuture<String>;
{
    private final Utf8StringBuilder builder = new Utf8StringBuilder();
    public CompletableUTF8String(Content.Source content)
    {
        super(content);
    }
    @Override
    protected String parse(Content.Chunk chunk) throws Throwable
    {
        // Accumulate the chunk bytes.
        if (chunk.hasRemaining())
            builder.append(chunk.getByteBuffer());
        // Not the last chunk, the result is not ready yet.
        if (!chunk.isLast())
            return null;
        // The result is ready.
        return builder.takeCompleteString(IllegalStateException::new);
    }
}
CompletableUTF8String cs = new CompletableUTF8String(source);
cs.parse();
String s = cs.get();
- 
Nested Class SummaryNested classes/interfaces inherited from class CompletableFutureCompletableFuture.AsynchronousCompletionTaskNested classes/interfaces inherited from interface FutureFuture.StateNested classes/interfaces inherited from interface InvocableInvocable.Callable, Invocable.InvocationType, Invocable.ReadyTask, Invocable.TaskNested classes/interfaces inherited from interface Invocable.TaskInvocable.Task.Abstract
- 
Field SummaryFields inherited from interface Invocable__nonBlocking, NOOP
- 
Constructor SummaryConstructorsConstructorDescriptionContentSourceCompletableFuture(Content.Source content, Invocable.InvocationType invocationType) 
- 
Method SummaryModifier and TypeMethodDescriptionacceptEither(CompletionStage<? extends X> other, Consumer<? super X> action) <U> CompletableFuture<U> applyToEither(CompletionStage<? extends X> other, Function<? super X, U> fn) get()<U> CompletableFuture<U> handle(BiFunction<? super X, Throwable, ? extends U> fn) join()protected booleanonTransientFailure(Throwable cause) Callback method that informs the parsing about how to handle transient failures.voidparse()Initiates the parsing of theContent.Source.protected abstract Xparse(Content.Chunk chunk) Called byparse()to parse aContent.Chunk.voidrun()runAfterBoth(CompletionStage<?> other, Runnable action) runAfterEither(CompletionStage<?> other, Runnable action) thenAccept(Consumer<? super X> action) <U> CompletableFuture<Void> thenAcceptBoth(CompletionStage<? extends U> other, BiConsumer<? super X, ? super U> action) <U> CompletableFuture<U> <U,V1> CompletableFuture <V1> thenCombine(CompletionStage<? extends U> other, BiFunction<? super X, ? super U, ? extends V1> fn) <U> CompletableFuture<U> thenCompose(Function<? super X, ? extends CompletionStage<U>> fn) whenComplete(BiConsumer<? super X, ? super Throwable> action) Methods inherited from class CompletableFutureacceptEitherAsync, acceptEitherAsync, allOf, anyOf, applyToEitherAsync, applyToEitherAsync, cancel, complete, completeAsync, completeAsync, completedFuture, completedStage, completeExceptionally, completeOnTimeout, copy, defaultExecutor, delayedExecutor, delayedExecutor, exceptionally, exceptionallyAsync, exceptionallyAsync, exceptionallyCompose, exceptionallyComposeAsync, exceptionallyComposeAsync, exceptionNow, failedFuture, failedStage, getNow, getNumberOfDependents, handleAsync, handleAsync, isCancelled, isCompletedExceptionally, isDone, minimalCompletionStage, newIncompleteFuture, obtrudeException, obtrudeValue, orTimeout, resultNow, runAfterBothAsync, runAfterBothAsync, runAfterEitherAsync, runAfterEitherAsync, runAsync, runAsync, state, supplyAsync, supplyAsync, thenAcceptAsync, thenAcceptAsync, thenAcceptBothAsync, thenAcceptBothAsync, thenApplyAsync, thenApplyAsync, thenCombineAsync, thenCombineAsync, thenComposeAsync, thenComposeAsync, thenRunAsync, thenRunAsync, toCompletableFuture, toString, whenCompleteAsync, whenCompleteAsync
- 
Constructor Details- 
ContentSourceCompletableFuture
- 
ContentSourceCompletableFuturepublic ContentSourceCompletableFuture(Content.Source content, Invocable.InvocationType invocationType) 
 
- 
- 
Method Details- 
parsepublic void parse()Initiates the parsing of the Content.Source.For every valid chunk that is read, parse(Content.Chunk)is called, until a result is produced that is used to complete thisCompletableFuture.Internally, this method is called multiple times to progress the parsing in response to Content.Source.demand(Runnable)calls.Exceptions thrown during parsing result in this CompletableFutureto be completed exceptionally.
- 
parseCalled by parse()to parse aContent.Chunk.- Parameters:
- chunk- The chunk containing content to parse. The chunk will never be- nullnor a- failure chunk. If the chunk is stored away to be used later beyond the scope of this call, then implementations must call- Retainable.retain()and- Retainable.release()as appropriate.
- Returns:
- The parsed Xresult instance ornullif parsing is not yet complete
- Throws:
- Throwable- If there is an error parsing
 
- 
onTransientFailureCallback method that informs the parsing about how to handle transient failures. - Parameters:
- cause- A transient failure obtained by reading a- non-last- failure chunk
- Returns:
- trueif the transient failure can be ignored,- falseotherwise
 
- 
run
- 
acceptEitherpublic CompletableFuture<Void> acceptEither(CompletionStage<? extends X> other, Consumer<? super X> action) - Specified by:
- acceptEitherin interface- CompletionStage<X>
- Overrides:
- acceptEitherin class- CompletableFuture<X>
 
- 
applyToEitherpublic <U> CompletableFuture<U> applyToEither(CompletionStage<? extends X> other, Function<? super X, U> fn) - Specified by:
- applyToEitherin interface- CompletionStage<X>
- Overrides:
- applyToEitherin class- CompletableFuture<X>
 
- 
get- Specified by:
- getin interface- Future<X>
- Overrides:
- getin class- CompletableFuture<X>
- Throws:
- InterruptedException
- ExecutionException
 
- 
getpublic X get(long timeout, TimeUnit unit) throws InterruptedException, ExecutionException, TimeoutException - Specified by:
- getin interface- Future<X>
- Overrides:
- getin class- CompletableFuture<X>
- Throws:
- InterruptedException
- ExecutionException
- TimeoutException
 
- 
getInvocationType- Specified by:
- getInvocationTypein interface- Invocable
- Returns:
- The InvocationType of this object
 
- 
handle- Specified by:
- handlein interface- CompletionStage<X>
- Overrides:
- handlein class- CompletableFuture<X>
 
- 
join- Overrides:
- joinin class- CompletableFuture<X>
 
- 
runAfterBoth- Specified by:
- runAfterBothin interface- CompletionStage<X>
- Overrides:
- runAfterBothin class- CompletableFuture<X>
 
- 
runAfterEither- Specified by:
- runAfterEitherin interface- CompletionStage<X>
- Overrides:
- runAfterEitherin class- CompletableFuture<X>
 
- 
thenAccept- Specified by:
- thenAcceptin interface- CompletionStage<X>
- Overrides:
- thenAcceptin class- CompletableFuture<X>
 
- 
thenAcceptBothpublic <U> CompletableFuture<Void> thenAcceptBoth(CompletionStage<? extends U> other, BiConsumer<? super X, ? super U> action) - Specified by:
- thenAcceptBothin interface- CompletionStage<X>
- Overrides:
- thenAcceptBothin class- CompletableFuture<X>
 
- 
thenApply- Specified by:
- thenApplyin interface- CompletionStage<X>
- Overrides:
- thenApplyin class- CompletableFuture<X>
 
- 
thenCombinepublic <U,V1> CompletableFuture<V1> thenCombine(CompletionStage<? extends U> other, BiFunction<? super X, ? super U, ? extends V1> fn) - Specified by:
- thenCombinein interface- CompletionStage<X>
- Overrides:
- thenCombinein class- CompletableFuture<X>
 
- 
thenCompose- Specified by:
- thenComposein interface- CompletionStage<X>
- Overrides:
- thenComposein class- CompletableFuture<X>
 
- 
thenRun- Specified by:
- thenRunin interface- CompletionStage<X>
- Overrides:
- thenRunin class- CompletableFuture<X>
 
- 
whenComplete- Specified by:
- whenCompletein interface- CompletionStage<X>
- Overrides:
- whenCompletein class- CompletableFuture<X>
 
 
-