'Catches' exceptions in the given task and returns them as values.
Like run, but returns exceptions as values.
Calls attempt and handles some exceptions using the given partial
function, calling Task.
Calls attempt and handles some exceptions using the given partial
function, calling Task.now on the result. Any nonmatching exceptions
are reraised.
Calls attempt and handles some exceptions using the given partial
function.
Calls attempt and handles some exceptions using the given partial
function. Any nonmatching exceptions are reraised.
Returns a new Task in which f is scheduled to be run on completion.
Returns a new Task in which f is scheduled to be run on completion.
This would typically be used to release any resources acquired by this
Task.
Runs this Task, and if it fails with an exception, runs t2.
Runs this Task, and if it fails with an exception, runs t2.
This is rather coarse-grained. Use attempt, handle, and
flatMap for more fine grained control of exception handling.
Run this Task and block until its result is available.
Run this Task and block until its result is available. This will
throw any exceptions generated by the Task. To return exceptions
in an \/, use attemptRun.
Run this computation to obtain either a result or an exception, then invoke the given callback.
Run this computation to obtain either a result or an exception, then
invoke the given callback. Any pure, non-asynchronous computation at the
head of this Future will be forced in the calling thread. At the first
Async encountered, control to whatever thread backs the Async and
this function returns immediately.
Similar to runAsyncInterruptibly(f,cancel) except instead of interrupting by setting cancel to true,
It returns the function, that, when applied will interrupt the task.
Similar to runAsyncInterruptibly(f,cancel) except instead of interrupting by setting cancel to true,
It returns the function, that, when applied will interrupt the task.
This allows "deterministic" completion of task computation
even if it was interrupted.
That means task will complete even when interrupted,
but with TaskInterrupted exception.
Note 1: When Interrupted, the f callback will run in thread that called the Interrupting function () => Unit
Note 2: If task has handler like attempt, it won't get consulted for handling TaskInterrupted excpetion
Run this computation to obtain an A, so long as cancel remains false.
Run this computation to obtain an A, so long as cancel remains false.
Because of trampolining, we get frequent opportunities to cancel
while stepping through the trampoline, this should provide a fairly
robust means of cancellation.
A Task which returns a TimeoutException after timeoutInMillis,
and attempts to cancel the running computation.