Skip to content
Event-driven networking engine written in Python.
Python GAP HTML Shell Batchfile C
Branch: trunk
Clone or download

Latest commit

rodrigc Merge pull request #1255 from twisted/9803-rodrigc-remove-future-imports
Remove unneeded __future__ imports

Author: rodrigc
Reviewer: adiroiban
Fixes: ticket:9803
Latest commit 4e42bf4 May 5, 2020

Files

Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.circleci Merge 9784-no-py2-ci: Remove Python 2 from CI Mar 29, 2020
.github since people keep trying to skip the process, explain they can't Aug 5, 2019
.travis make pypy/pypy3 work in travis configuration Aug 18, 2019
admin Review response Jan 13, 2019
azure-pipelines Merge 9798-altendky-add_cpython_3_8_to_ci: Add Python 3.8 to CI Apr 13, 2020
bin/admin Change topfile to newsfragment Aug 4, 2017
docs Add an example for adding a PTR record Mar 28, 2020
src/twisted Add newsfragment May 5, 2020
.coveragerc correct src spot Aug 17, 2016
.coveralls.yml darn it all Apr 13, 2019
.gitattributes make pems not convert and skip a test May 16, 2018
.gitignore fix May 6, 2019
.travis.yml Rename matrix to jobs to match Travis latest documentation May 5, 2020
CONTRIBUTING Initial PR template. Oct 2, 2017
INSTALL.rst Merge 9784-no-py2-ci: Remove Python 2 from CI Mar 29, 2020
LICENSE Merge release-20.3-9772: Release 20.3.0 Mar 20, 2020
MANIFEST.in Add mypy.ini to MANIFEST.in May 5, 2020
NEWS.rst Merge release-20.3-9772: Release 20.3.0 Mar 20, 2020
README.rst Merge release-20.3-9772: Release 20.3.0 Mar 20, 2020
appveyor.yml fix May 6, 2019
code_of_conduct.md Merge explicit-is-better-than-implicit-8173: Adopt a Code of Conduct Jan 21, 2016
codecov.yml we all get too many github notifications, we don't need these Apr 13, 2019
mypy.ini Add config file for mypy May 5, 2020
pyproject.toml Merge 9634-isort: Add an isort configuration file Dec 18, 2019
setup.py Remove unused import Oct 3, 2017
tox.ini Add mypy environment to tox May 5, 2020

README.rst

Twisted

pypi travis circleci

For information on changes in this release, see the NEWS file.

What is this?

Twisted is an event-based framework for internet applications, supporting Python 2.7 and Python 3.5+. It includes modules for many different purposes, including the following:

  • twisted.web: HTTP clients and servers, HTML templating, and a WSGI server
  • twisted.conch: SSHv2 and Telnet clients and servers and terminal emulators
  • twisted.words: Clients and servers for IRC, XMPP, and other IM protocols
  • twisted.mail: IMAPv4, POP3, SMTP clients and servers
  • twisted.positioning: Tools for communicating with NMEA-compatible GPS receivers
  • twisted.names: DNS client and tools for making your own DNS servers
  • twisted.trial: A unit testing framework that integrates well with Twisted-based code.

Twisted supports all major system event loops -- select (all platforms), poll (most POSIX platforms), epoll (Linux), kqueue (FreeBSD, macOS), IOCP (Windows), and various GUI event loops (GTK+2/3, Qt, wxWidgets). Third-party reactors can plug into Twisted, and provide support for additional event loops.

Installing

To install the latest version of Twisted using pip:

$ pip install twisted

Additional instructions for installing this software are in the installation instructions.

Documentation and Support

Twisted's documentation is available from the Twisted Matrix website. This documentation contains how-tos, code examples, and an API reference.

Help is also available on the Twisted mailing list.

There is also a pair of very lively IRC channels, #twisted (for general Twisted questions) and #twisted.web (for Twisted Web), on chat.freenode.net.

Unit Tests

Twisted has a comprehensive test suite, which can be run by tox:

$ tox -l            # to view all test environments
$ tox -e py27-tests # to run the tests for Python 2.7
$ tox -e py35-tests # to run the tests for Python 3.5

You can test running the test suite under the different reactors with the TWISTED_REACTOR environment variable:

$ env TWISTED_REACTOR=epoll tox -e py27-tests

Some of these tests may fail if you:

  • don't have the dependencies required for a particular subsystem installed,
  • have a firewall blocking some ports (or things like Multicast, which Linux NAT has shown itself to do), or
  • run them as root.

Copyright

All of the code in this distribution is Copyright (c) 2001-2020 Twisted Matrix Laboratories.

Twisted is made available under the MIT license. The included LICENSE file describes this in detail.

Warranty

THIS SOFTWARE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE USE OF THIS SOFTWARE IS WITH YOU.

IN NO EVENT WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE LIBRARY, BE LIABLE TO YOU FOR ANY DAMAGES, EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

Again, see the included LICENSE file for specific legal details.

You can’t perform that action at this time.