Package jadex.future
Class TerminableDelegationFuture<E>
java.lang.Object
jadex.future.Future<E>
jadex.future.TerminableDelegationFuture<E>
- All Implemented Interfaces:
IBackwardCommandFuture,IForwardCommandFuture,IFuture<E>,ITerminableFuture<E>,Supplier<E>
A terminable delegation future can be used when a termination future
should be delegated. This kind of future needs to be connected to the
termination source (another delegation or a real future). Termination
calls are forwarded to the termination source. The future remembers
when terminate() was called in unconnected state and forwards the request
as soon as the connection is established.
-
Nested Class Summary
Nested classes/interfaces inherited from interface jadex.future.IForwardCommandFuture
IForwardCommandFuture.Type -
Field Summary
FieldsModifier and TypeFieldDescriptionprotected TerminableDelegationFutureHandler<E>The forward/backward handling helper.Fields inherited from class jadex.future.Future
CALLER_QUEUED, CALLER_RESUMED, CALLER_SUSPENDED, callers, creation, DEBUG, exception, first, listeners, NO_STACK_COMPACTION, NONE, notcommand, NOTIFICATIONS, notificount, notified, result, resultavailable, undone, UNSET -
Constructor Summary
ConstructorsConstructorDescriptionCreate a new future.Create a new future. -
Method Summary
Modifier and TypeMethodDescriptionvoiddelegateFrom(IFuture<E> source) Delegate the result and exception from another future.voidsendBackwardCommand(Object info) Send a backward command in direction of the source.voidSet the termination source.voidTerminate the future.voidTerminate the future and supply a custom reason.Methods inherited from class jadex.future.Future
abortGet, addResultListener, catchEx, catchEx, catchEx, delegate, delegateTo, doAddResultListener, doSetException, doSetResult, doStartScheduledNotifications, executeNotification, get, get, get, get, get, getEmptyFuture, getException, getFuture, getNotificationCommand, hasResultListener, isDone, isNotified, printOnEx, resume, scheduleNotification, scheduleNotification, sendForwardCommand, setException, setExceptionIfUndone, setResult, setResultIfUndone, startScheduledNotifications, then, thenAccept, thenAccept, thenApply, thenApply, thenCombine, thenCompose, thenCompose, throwExceptionMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface jadex.future.IFuture
addResultListener, catchEx, catchEx, catchEx, delegate, delegateTo, get, get, get, get, get, getException, isDone, printOnEx, then, thenApply, thenApply, thenCompose, thenCompose
-
Field Details
-
handler
The forward/backward handling helper.
-
-
Constructor Details
-
TerminableDelegationFuture
public TerminableDelegationFuture()Create a new future. -
TerminableDelegationFuture
Create a new future.
-
-
Method Details
-
setTerminationSource
Set the termination source. -
terminate
public void terminate()Terminate the future. The exception will be set to FutureTerminatedException.- Specified by:
terminatein interfaceITerminableFuture<E>
-
terminate
Terminate the future and supply a custom reason.- Specified by:
terminatein interfaceITerminableFuture<E>
-
delegateFrom
Delegate the result and exception from another future.- Overrides:
delegateFromin classFuture<E>- Parameters:
source- The source future.
-
sendBackwardCommand
Send a backward command in direction of the source.- Specified by:
sendBackwardCommandin interfaceIBackwardCommandFuture- Parameters:
info- The command info.
-