Part of twisted.internet.defer View Source View In Hierarchy
Known subclasses: twisted.internet.defer.DeferredList, twisted.persisted.crefutil._Defer
This is a callback which will be put off until later.
Why do we want this? Well, in cases where a function in a threaded
program would block until it gets a result, for Twisted it should not
block. Instead, it should return a Deferred
.
This can be implemented for protocols that run over the network by
writing an asynchronous protocol for twisted.internet
. For methods
that come from outside packages that are not under our control, we use
threads (see for example twisted.enterprise.adbapi
).
For more information about Deferreds, see doc/howto/defer.html or http://twistedmatrix.com/projects/core/documentation/howto/defer.html
When creating a Deferred, you may provide a canceller function, which will be called by d.cancel() to let you do any clean-up necessary if the user decides not to wait for the deferred to complete.Method | __init__ | Initialize a Deferred .
|
Method | addCallbacks | Add a pair of callbacks (success and error) to this Deferred .
|
Method | addCallback | Convenience method for adding just a callback. |
Method | addErrback | Convenience method for adding just an errback. |
Method | addBoth | Convenience method for adding a single callable as both a callback and an errback. |
Method | chainDeferred | Chain another Deferred to
this Deferred .
|
Method | callback | Run all success callbacks that have been added to this Deferred .
|
Method | errback | Run all error callbacks that have been added to this Deferred .
|
Method | pause | Stop processing on a Deferred until
unpause ()
is called.
|
Method | unpause | Process all callbacks made since pause ()
was called.
|
Method | cancel | Cancel this Deferred .
|
Method | setTimeout | Set a timeout function to be triggered if I am not called. |
Method | __str__ | Undocumented |
Method | _continue | Undocumented |
Method | _startRunCallbacks | Undocumented |
Method | _runCallbacks | Undocumented |
Deferred
.
Parameters | canceller | a callable used to stop the pending operation scheduled by this If a canceller is not given, or does not invoke its argument's
callback or
errback may still be invoked exactly once, even though
defer.py will have already invoked errback , as described
above. This allows clients of code which returns a Deferred to
cancel it without requiring the Deferred
instantiator to provide any specific implementation support for
cancellation. New in 10.0.
(type: a 1-argument callable which takes a Deferred . The
return result is ignored.
) |
Add a pair of callbacks (success and error) to this Deferred
.
Convenience method for adding a single callable as both a callback and an errback.
SeeaddCallbacks
.
Chain another Deferred
to
this Deferred
.
Deferred
to
call d
's callback or errback, as appropriate. It is merely a
shorthand way of performing the following:
self.addCallbacks(d.callback, d.errback)When you chain a deferred d2 to another deferred d1 with d1.chainDeferred(d2), you are making d2 participate in the callback chain of d1. Thus any event that fires d1 will also fire d2. However, the converse is not true; if d2 is fired d1 will not be affected.
Run all success callbacks that have been added to this Deferred
.
Failure
or
raises an Exception
, processing will continue on the *error*
callback chain. If a callback (or errback) returns another Deferred
, this
Deferred
will be chained to it (and further callbacks will not run until that Deferred
has a
result).
Run all error callbacks that have been added to this Deferred
.
Each callback will have its result passed as the first argument to the
next; this way, the callbacks act as a 'processing chain'. Also, if the
error-callback returns a non-Failure or doesn't raise an
Exception
, processing will continue on the *success*-callback
chain.
If the argument that's passed to me is not a failure.Failure
instance, it will be embedded in one. If no argument is passed, a failure.Failure
instance will be created based on the current traceback stack.
Raises | NoCurrentExceptionError | If fail is None but there is no current
exception state.
|
Cancel this Deferred
.
If the Deferred
has
not yet had its errback
or callback
method
invoked, call the canceller function provided to the constructor. If that
function does not invoke callback
or errback
, or
if no canceller function was provided, errback with CancelledError
.
Deferred
is
waiting on another Deferred
,
forward the cancellation to the other Deferred
.
Parameters | seconds | How long to wait (from now) before firing the
timeoutFunc .
|
timeoutFunc | will receive the Deferred and
*args, **kw as its arguments. The default timeoutFunc will
call the errback with a TimeoutError .
|