Skip to content Skip to sidebar Skip to footer

Is It Possible To Use Tornado's Gen.engine And Gen.task With Twisted?

The project I am working on is all written in Tornado, but I have included a bit of Twisted to deal with asynchronous XML-RPC. I was wondering if you can use Tornado's gen.engine a

Solution 1:

Sure - but it's called inlineCallbacks in Twisted:

from twisted.internet.defer import inlineCallbacks

@inlineCallbacksdeffoo():
    x = yield bar()
    print x

Solution 2:

You can use gen.Task with anything that takes a callback keyword argument. However, Twisted-style code usually returns a Deferred instead of taking a callback as input. You'll need to wrap the Deferred in something tornado.gen can understand (probably a Future). Something like this (untested):

defwrap_deferred(deferred):
    # Could also use concurrent.futures.Future from the standard library,# but Tornado's version gives better tracebacks on python 2.
    future = tornado.concurrent.TracebackFuture()
    deferred.addCallbacks(future.set_result, future.set_exception)
    return future

@gen.coroutine
defmy_coroutine(self):
    # Use wrap_deferred instead of gen.Task
    x = yield wrap_deferred(some_twisted_function())

Solution 3:

I modified Ben's sample code a bit in order to set exception correctly.

def wrap_deferred(deferred):
    future = tornado.concurrent.TracebackFuture()
    deferred.addCallback(future.set_result)
    deferred.addErrback(lambda err: future.set_exception(err.value))
    return future

twisted wrap exception as a failure.Failure. future.set_exception complains it is not an exception type.

Post a Comment for "Is It Possible To Use Tornado's Gen.engine And Gen.task With Twisted?"