[Twisted-Python] ANN: Crochet 1.2.0 - Use Twisted Anywhere!
Itamar Turner-Trauring
itamar at itamarst.org
Mon Apr 14 08:29:43 MDT 2014
Crochet is an MIT-licensed library that makes it easier to use Twisted
from regular blocking code. Some use cases include:
* Easily use Twisted from a blocking framework like Django or Flask.
* Write a library that provides a blocking API, but uses Twisted for
its implementation.
* Port blocking code to Twisted more easily, by keeping a backwards
compatibility layer.
* Allow normal Twisted programs that use threads to interact with
Twisted more cleanly from their threaded parts. For example this can be
useful when using Twisted as a WSGI container.
New in this release:
* crochet.wait_for implements the timeout/cancellation pattern
documented in previous versions of Crochet.
* Functions wrapped with wait_for and run_in_reactor can now be
accessed via the wrapped_function attribute, to ease unit testing of the
underlying Twisted code.
* Bug fixes, documentation improvements and more - for a full list see
the
Documentation can be found at http://crochet.readthedocs.org [1]
Bugs and feature requests should be filed at the project
https://github.com/itamarst/crochet [2]
Here's an example of a program using Crochet. Notice that you get a
completely blocking interface to Twisted and do not need to run the
Twisted reactor, the event loop, yourself.
#!/usr/bin/python
"""
Do a DNS lookup using Twisted's APIs.
"""
from __future__ import print_function
# The Twisted code we'll be using:
from twisted.names import client
from crochet import setup, wait_for
setup()
# Crochet layer, wrapping Twisted's DNS library in a blocking call.
@wait_for(timeout=5.0)
def gethostbyname(name):
"""Lookup the IP of a given hostname.
Unlike socket.gethostbyname() which can take an arbitrary amount of
time
to finish, this function will raise crochet.TimeoutError if more than 5
seconds elapse without an answer being received.
"""
d = client.lookupAddress(name)
d.addCallback(lambda result: result[0][0].payload.dottedQuad())
return d
if __name__ == '__main__':
# Application code using the public API - notice it works in a normal
# blocking manner, with no event loop visible:
import sys
name = sys.argv[1]
ip = gethostbyname(name)
print(name, "->", ip)
Run on the command line:
> $ python blockingdns.py twistedmatrix.com
> twistedmatrix.com -> 66.35.39.66
Links:
------
[1] https://crochet.readthedocs.org/
[2] https://github.com/itamarst/crochet
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://twistedmatrix.com/pipermail/twisted-python/attachments/20140414/2783ac8b/attachment.html>
More information about the Twisted-Python
mailing list