Package jadex.commons.future
Class IntermediateFuture<E>
- java.lang.Object
- 
- jadex.commons.future.Future<java.util.Collection<E>>
- 
- jadex.commons.future.IntermediateFuture<E>
 
 
- 
- All Implemented Interfaces:
- IForwardCommandFuture,- IFuture<java.util.Collection<E>>,- IIntermediateFuture<E>
 - Direct Known Subclasses:
- TerminableIntermediateDelegationFuture,- TerminableIntermediateFuture,- Tuple2Future
 
 public class IntermediateFuture<E> extends Future<java.util.Collection<E>> implements IIntermediateFuture<E> Default implementation of an intermediate future.
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface jadex.commons.future.IForwardCommandFutureIForwardCommandFuture.Type
 
- 
 - 
Field SummaryFields Modifier and Type Field Description protected java.util.Map<ISuspendable,java.lang.String>icallersThe blocked intermediate callers (caller->state).protected java.util.Map<java.lang.Thread,java.lang.Integer>indicesThe index of the next result for a thread.protected booleanintermediateFlag indicating that addIntermediateResult()has been called.protected intmaxresultcntThe max result count (if given by the producer).protected ICommand<IResultListener<java.util.Collection<E>>>notcommandprotected java.util.List<E>resultsThe intermediate results.- 
Fields inherited from class jadex.commons.future.FutureCALLER_QUEUED, CALLER_RESUMED, CALLER_SUSPENDED, callers, creation, DEBUG, exception, first, listeners, NO_STACK_COMPACTION, NONE, NOTIFICATIONS, notificount, notified, result, resultavailable, undone, UNSET
 - 
Fields inherited from interface jadex.commons.future.IIntermediateFutureDONE
 
- 
 - 
Constructor SummaryConstructors Constructor Description IntermediateFuture()Create a future that is already done.IntermediateFuture(java.lang.Exception exception)Create a future that is already done (failed).IntermediateFuture(java.util.Collection<E> results)Create a future that is already done.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddIntermediateResult(E result)Add an intermediate result.booleanaddIntermediateResultIfUndone(E result)Set the result.voidaddResultListener(IResultListener<java.util.Collection<E>> listener)Add a result listener.java.util.stream.Stream<E>asStream()Return a stream of the results of this future.java.util.stream.Stream<E>asStream(long timeout, boolean realtime)Return a stream of the results of this future.IIntermediateFuture<E>catchEx(java.util.function.Consumer<? super java.lang.Exception> consumer, java.lang.Class<?> futuretype)Called on exception.<T> IIntermediateFuture<E>delegateEx(Future<T> delegate)Called on exception.protected booleandoAddIntermediateResult(E result, boolean undone)Set the result and schedule listener notifications.protected EdoGetNextIntermediateResult(int index, long timeout, boolean realtime)Perform the get without increasing the index.IIntermediateFuture<? extends E>done(java.util.function.Consumer<? super java.lang.Exception> consumer)Called when the future is done (finished or exception occurred).protected booleandoSetException(java.lang.Exception exception, boolean undone)Set the exception (internal implementation for normal and if-undone).protected booleandoSetFinished(boolean undone)Declare that the future is finished.protected booleandoSetResult(java.util.Collection<E> result, boolean undone)Set the result.IIntermediateFuture<? extends E>finished(java.util.function.Consumer<java.lang.Void> function)Called when the future is finished.java.util.Collection<E>getIntermediateResults()Get the intermediate results that are available.EgetNextIntermediateResult()Iterate over the intermediate results in a blocking fashion.EgetNextIntermediateResult(boolean realtime)Iterate over the intermediate results in a blocking fashion.EgetNextIntermediateResult(long timeout, boolean realtime)Iterate over the intermediate results in a blocking fashion.protected ICommand<IResultListener<java.util.Collection<E>>>getNotificationCommand()Get the notification command.protected intgetResultCount()Get the number of results already collected.booleanhasNextIntermediateResult()Check if there are more results for iteration for the given caller.booleanhasNextIntermediateResult(long timeout, boolean realtime)Check if there are more results for iteration for the given caller.IIntermediateFuture<? extends E>max(java.util.function.Consumer<java.lang.Integer> function)Called when the maximum number of results is available.IIntermediateFuture<? extends E>next(java.util.function.Consumer<? super E> function)Called when the next intermediate value is available.protected voidnotifyIntermediateResult(IIntermediateResultListener<E> listener, E result)Notify a result listener.protected voidresume()Resume also intermediate waiters.protected voidresumeIntermediate()Resume after intermediate result.protected booleanscheduleMaxNotification(IResultListener<java.util.Collection<E>> lis)voidsetFinished()Declare that the future is finished.booleansetFinishedIfUndone()Declare that the future is finished.voidsetMaxResultCount(int max)Set the maximum number of results.protected voidstoreResult(E result, boolean scheduled)Add a result.IIntermediateFuture<E>then(java.util.function.Consumer<? super java.util.Collection<E>> function)Applies a function after the result is available, using the result of this Future as input.- 
Methods inherited from class jadex.commons.future.FutureabortGet, catchEx, catchEx, delegate, doAddResultListener, doStartScheduledNotifications, executeNotification, get, get, get, get, get, getEmptyFuture, getException, getFuture, hasResultListener, isDone, isNotified, scheduleNotification, scheduleNotification, sendForwardCommand, setException, setExceptionIfUndone, setResult, setResultIfUndone, startScheduledNotifications, thenAccept, thenAccept, thenApply, thenApply, thenCombine, thenCompose, thenCompose, throwException
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface jadex.commons.future.IFuturecatchEx, catchEx, delegate, get, get, get, get, get, getException, isDone, thenApply, thenApply, thenCompose, thenCompose
 
- 
 
- 
- 
- 
Field Detail- 
resultsprotected java.util.List<E> results The intermediate results.
 - 
intermediateprotected boolean intermediate Flag indicating that addIntermediateResult()has been called.
 - 
icallersprotected java.util.Map<ISuspendable,java.lang.String> icallers The blocked intermediate callers (caller->state).
 - 
indicesprotected java.util.Map<java.lang.Thread,java.lang.Integer> indices The index of the next result for a thread.
 - 
maxresultcntprotected int maxresultcnt The max result count (if given by the producer).
 - 
notcommandprotected ICommand<IResultListener<java.util.Collection<E>>> notcommand 
 
- 
 - 
Constructor Detail- 
IntermediateFuturepublic IntermediateFuture() Create a future that is already done.- Parameters:
- result- The result, if any.
 
 - 
IntermediateFuturepublic IntermediateFuture(java.util.Collection<E> results) Create a future that is already done.- Parameters:
- result- The result, if any.
 
 - 
IntermediateFuturepublic IntermediateFuture(java.lang.Exception exception) Create a future that is already done (failed).- Parameters:
- exception- The exception.
 
 
- 
 - 
Method Detail- 
getIntermediateResultspublic java.util.Collection<E> getIntermediateResults() Get the intermediate results that are available.- Specified by:
- getIntermediateResultsin interface- IIntermediateFuture<E>
- Returns:
- The current intermediate results (copy of the list).
 
 - 
addIntermediateResultpublic void addIntermediateResult(E result) Add an intermediate result.
 - 
addIntermediateResultIfUndonepublic boolean addIntermediateResultIfUndone(E result) Set the result.- Parameters:
- result- The result.
- Returns:
- True if result was set.
 
 - 
doAddIntermediateResultprotected boolean doAddIntermediateResult(E result, boolean undone) Set the result and schedule listener notifications.- Returns:
- true, when the result was added (finished and undone otherwise).
 
 - 
storeResultprotected void storeResult(E result, boolean scheduled) Add a result.- Parameters:
- result- The result.
- scheduled- True, if any listener notification has been scheduled for this result. (used for subscription futures to check for lost values)
 
 - 
doSetResultprotected boolean doSetResult(java.util.Collection<E> result, boolean undone) Set the result. Listener notifications occur on calling thread of this method.- Overrides:
- doSetResultin class- Future<java.util.Collection<E>>
- Parameters:
- result- The result.
 
 - 
setFinishedpublic void setFinished() Declare that the future is finished.
 - 
setFinishedIfUndonepublic boolean setFinishedIfUndone() Declare that the future is finished.
 - 
doSetFinishedprotected boolean doSetFinished(boolean undone) Declare that the future is finished.
 - 
doSetExceptionprotected boolean doSetException(java.lang.Exception exception, boolean undone)Description copied from class:FutureSet the exception (internal implementation for normal and if-undone).- Overrides:
- doSetExceptionin class- Future<java.util.Collection<E>>
 
 - 
addResultListenerpublic void addResultListener(IResultListener<java.util.Collection<E>> listener) Add a result listener.- Specified by:
- addResultListenerin interface- IFuture<E>
- Overrides:
- addResultListenerin class- Future<java.util.Collection<E>>
- Parameters:
- listener- The listener.
 
 - 
getNotificationCommandprotected ICommand<IResultListener<java.util.Collection<E>>> getNotificationCommand() Get the notification command.- Overrides:
- getNotificationCommandin class- Future<java.util.Collection<E>>
 
 - 
hasNextIntermediateResultpublic boolean hasNextIntermediateResult() Check if there are more results for iteration for the given caller. If there are currently no unprocessed results and future is not yet finished, the caller is blocked until either new results are available and true is returned or the future is finished, thus returning false.- Specified by:
- hasNextIntermediateResultin interface- IIntermediateFuture<E>
- Returns:
- True, when there are more intermediate results for the caller.
 
 - 
hasNextIntermediateResultpublic boolean hasNextIntermediateResult(long timeout, boolean realtime)Check if there are more results for iteration for the given caller. If there are currently no unprocessed results and future is not yet finished, the caller is blocked until either new results are available and true is returned or the future is finished, thus returning false.- Specified by:
- hasNextIntermediateResultin interface- IIntermediateFuture<E>
- Parameters:
- timeout- The timeout in millis.
- realtime- Flag, if wait should be realtime (in constrast to simulation time).
- Returns:
- True, when there are more intermediate results for the caller.
 
 - 
getNextIntermediateResultpublic E getNextIntermediateResult() Iterate over the intermediate results in a blocking fashion. Manages results independently for different callers, i.e. when called from different threads, each thread receives all intermediate results. The operation is guaranteed to be non-blocking, if hasNextIntermediateResult() has returned true before for the same caller. Otherwise the caller is blocked until a result is available or the future is finished.- Specified by:
- getNextIntermediateResultin interface- IIntermediateFuture<E>
- Returns:
- The next intermediate result.
 
 - 
getNextIntermediateResultpublic E getNextIntermediateResult(boolean realtime) Iterate over the intermediate results in a blocking fashion. Manages results independently for different callers, i.e. when called from different threads, each thread receives all intermediate results. The operation is guaranteed to be non-blocking, if hasNextIntermediateResult() has returned true before for the same caller. Otherwise the caller is blocked until a result is available or the future is finished.- Returns:
- The next intermediate result.
 
 - 
getNextIntermediateResultpublic E getNextIntermediateResult(long timeout, boolean realtime) Iterate over the intermediate results in a blocking fashion. Manages results independently for different callers, i.e. when called from different threads, each thread receives all intermediate results. The operation is guaranteed to be non-blocking, if hasNextIntermediateResult() has returned true before for the same caller. Otherwise the caller is blocked until a result is available or the future is finished.- Specified by:
- getNextIntermediateResultin interface- IIntermediateFuture<E>
- Parameters:
- timeout- The timeout in millis.
- realtime- Flag, if wait should be realtime (in constrast to simulation time).
- Returns:
- The next intermediate result.
 
 - 
setMaxResultCountpublic void setMaxResultCount(int max) Set the maximum number of results.- Parameters:
- max- The maximum number of results.
 
 - 
scheduleMaxNotificationprotected boolean scheduleMaxNotification(IResultListener<java.util.Collection<E>> lis) - Parameters:
- max-
 
 - 
getResultCountprotected int getResultCount() Get the number of results already collected.- Returns:
- The number of results.
 
 - 
doGetNextIntermediateResultprotected E doGetNextIntermediateResult(int index, long timeout, boolean realtime) Perform the get without increasing the index.
 - 
notifyIntermediateResultprotected void notifyIntermediateResult(IIntermediateResultListener<E> listener, E result) Notify a result listener.- Parameters:
- listener- The listener.
 
 - 
resumeprotected void resume() Resume also intermediate waiters.
 - 
resumeIntermediateprotected void resumeIntermediate() Resume after intermediate result.
 - 
catchExpublic IIntermediateFuture<E> catchEx(java.util.function.Consumer<? super java.lang.Exception> consumer, java.lang.Class<?> futuretype) Description copied from class:FutureCalled on exception.
 - 
delegateExpublic <T> IIntermediateFuture<E> delegateEx(Future<T> delegate) Called on exception.- Overrides:
- delegateExin class- Future<java.util.Collection<E>>
- Parameters:
- delegate- The future the exception will be delegated to.
 
 - 
thenpublic IIntermediateFuture<E> then(java.util.function.Consumer<? super java.util.Collection<E>> function) Description copied from interface:IFutureApplies a function after the result is available, using the result of this Future as input.
 - 
nextpublic IIntermediateFuture<? extends E> next(java.util.function.Consumer<? super E> function) Called when the next intermediate value is available.- Specified by:
- nextin interface- IIntermediateFuture<E>
- Parameters:
- function- Called when value arrives.
- Returns:
- The future for chaining.
 
 - 
maxpublic IIntermediateFuture<? extends E> max(java.util.function.Consumer<java.lang.Integer> function) Called when the maximum number of results is available.- Specified by:
- maxin interface- IIntermediateFuture<E>
- Parameters:
- function- Called when max value arrives.
- Returns:
- The future for chaining.
 
 - 
finishedpublic IIntermediateFuture<? extends E> finished(java.util.function.Consumer<java.lang.Void> function) Called when the future is finished.- Specified by:
- finishedin interface- IIntermediateFuture<E>
- Parameters:
- function- Called when max value arrives.
- Returns:
- The future for chaining.
 
 - 
donepublic IIntermediateFuture<? extends E> done(java.util.function.Consumer<? super java.lang.Exception> consumer) Called when the future is done (finished or exception occurred). Exception parameter will be set if the cause was an exception, null otherwise.- Specified by:
- donein interface- IIntermediateFuture<E>
- Parameters:
- consumer- Called future is done.
- Returns:
- The future for chaining.
 
 - 
asStreampublic java.util.stream.Stream<E> asStream() Return a stream of the results of this future. Although this method itself is non-blocking, all terminal stream methods (e.g. forEach) will block until the future is finished!- Specified by:
- asStreamin interface- IIntermediateFuture<E>
 
 - 
asStreampublic java.util.stream.Stream<E> asStream(long timeout, boolean realtime) Return a stream of the results of this future. Use the given timeout settings when waiting for elements in the stream. Although this method itself is non-blocking, all terminal stream methods (e.g. forEach) will block until the future is finished!- Specified by:
- asStreamin interface- IIntermediateFuture<E>
- Parameters:
- timeout- The timeout in millis.
- realtime- Flag, if wait should be realtime (in constrast to simulation time).
 
 
- 
 
-