[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