Disclaimer
-----------
+==========
Full documentation is not yet ready; we hope to have it written
before Python 3.4 leaves beta. Until then, the best reference is
.. XXX should the asyncio documentation come in several pages, as for logging?
-
.. _event-loop:
Event loops
------------
+===========
The event loop is the central execution device provided by :mod:`asyncio`.
It provides multiple facilities, amongst which:
* Delegating costly function calls to a pool of threads
Event loop functions
-^^^^^^^^^^^^^^^^^^^^
+--------------------
The easiest way to get an event loop is to call the :func:`get_event_loop`
function.
Event loop policy
-^^^^^^^^^^^^^^^^^
+-----------------
.. function:: get_event_loop_policy()
Run an event loop
-^^^^^^^^^^^^^^^^^
+-----------------
.. method:: BaseEventLoop.run_forever()
Calls
-^^^^^
+-----
.. method:: BaseEventLoop.call_soon(callback, \*args)
Delayed calls
-^^^^^^^^^^^^^
+-------------
The event loop has its own internal clock for computing timeouts.
Which clock is used depends on the (platform-specific) event loop
event loop's internal clock.
-Executor
-^^^^^^^^
-
-Call a function in an :class:`~concurrent.futures.Executor` (pool of threads or
-pool of processes). By default, an event loop uses a thread pool executor
-(:class:`~concurrent.futures.ThreadPoolExecutor`).
-
-.. method:: BaseEventLoop.run_in_executor(executor, callback, \*args)
-
- Arrange for a callback to be called in the specified executor.
-
- *executor* is a :class:`~concurrent.futures.Executor` instance,
- the default executor is used if *executor* is ``None``.
-
-.. method:: BaseEventLoop.set_default_executor(executor)
-
- Set the default executor used by :meth:`run_in_executor`.
-
-
-Creating listening connections
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-.. method:: BaseEventLoop.create_server(protocol_factory, host=None, port=None, \*, family=socket.AF_UNSPEC, flags=socket.AI_PASSIVE, sock=None, backlog=100, ssl=None, reuse_address=None)
-
- A :ref:`coroutine <coroutine>` which creates a TCP server bound to host and
- port.
-
- The return value is a :class:`AbstractServer` object which can be used to stop
- the service.
-
- If *host* is an empty string or None all interfaces are assumed
- and a list of multiple sockets will be returned (most likely
- one for IPv4 and another one for IPv6).
-
- *family* can be set to either :data:`~socket.AF_INET` or
- :data:`~socket.AF_INET6` to force the socket to use IPv4 or IPv6. If not set
- it will be determined from host (defaults to :data:`~socket.AF_UNSPEC`).
-
- *flags* is a bitmask for :meth:`getaddrinfo`.
-
- *sock* can optionally be specified in order to use a preexisting
- socket object.
-
- *backlog* is the maximum number of queued connections passed to
- :meth:`~socket.socket.listen` (defaults to 100).
-
- ssl can be set to an :class:`~ssl.SSLContext` to enable SSL over the
- accepted connections.
-
- *reuse_address* tells the kernel to reuse a local socket in
- TIME_WAIT state, without waiting for its natural timeout to
- expire. If not specified will automatically be set to True on
- UNIX.
-
- This method returns a :ref:`coroutine <coroutine>`.
-
-.. method:: BaseEventLoop.create_datagram_endpoint(protocol_factory, local_addr=None, remote_addr=None, \*, family=0, proto=0, flags=0)
-
- Create datagram connection.
-
- This method returns a :ref:`coroutine <coroutine>`.
-
-
-
Creating connections
^^^^^^^^^^^^^^^^^^^^
are looked up using getaddrinfo(), similarly to *host* and *port*.
+Creating listening connections
+------------------------------
+
+.. method:: BaseEventLoop.create_server(protocol_factory, host=None, port=None, \*, family=socket.AF_UNSPEC, flags=socket.AI_PASSIVE, sock=None, backlog=100, ssl=None, reuse_address=None)
+
+ A :ref:`coroutine <coroutine>` which creates a TCP server bound to host and
+ port.
+
+ The return value is a :class:`AbstractServer` object which can be used to stop
+ the service.
+
+ If *host* is an empty string or None all interfaces are assumed
+ and a list of multiple sockets will be returned (most likely
+ one for IPv4 and another one for IPv6).
+
+ *family* can be set to either :data:`~socket.AF_INET` or
+ :data:`~socket.AF_INET6` to force the socket to use IPv4 or IPv6. If not set
+ it will be determined from host (defaults to :data:`~socket.AF_UNSPEC`).
+
+ *flags* is a bitmask for :meth:`getaddrinfo`.
+
+ *sock* can optionally be specified in order to use a preexisting
+ socket object.
+
+ *backlog* is the maximum number of queued connections passed to
+ :meth:`~socket.socket.listen` (defaults to 100).
+
+ ssl can be set to an :class:`~ssl.SSLContext` to enable SSL over the
+ accepted connections.
+
+ *reuse_address* tells the kernel to reuse a local socket in
+ TIME_WAIT state, without waiting for its natural timeout to
+ expire. If not specified will automatically be set to True on
+ UNIX.
+
+ This method returns a :ref:`coroutine <coroutine>`.
+
+.. method:: BaseEventLoop.create_datagram_endpoint(protocol_factory, local_addr=None, remote_addr=None, \*, family=0, proto=0, flags=0)
+
+ Create datagram connection.
+
+ This method returns a :ref:`coroutine <coroutine>`.
+
+
+
Resolve name
-^^^^^^^^^^^^
+------------
.. method:: BaseEventLoop.getaddrinfo(host, port, \*, family=0, type=0, proto=0, flags=0)
Running subprocesses
-^^^^^^^^^^^^^^^^^^^^
+--------------------
Run subprocesses asynchronously using the :mod:`subprocess` module.
This method returns a :ref:`coroutine <coroutine>`.
+Executor
+--------
+
+Call a function in an :class:`~concurrent.futures.Executor` (pool of threads or
+pool of processes). By default, an event loop uses a thread pool executor
+(:class:`~concurrent.futures.ThreadPoolExecutor`).
+
+.. method:: BaseEventLoop.run_in_executor(executor, callback, \*args)
+
+ Arrange for a callback to be called in the specified executor.
+
+ *executor* is a :class:`~concurrent.futures.Executor` instance,
+ the default executor is used if *executor* is ``None``.
+
+.. method:: BaseEventLoop.set_default_executor(executor)
+
+ Set the default executor used by :meth:`run_in_executor`.
+
+
+Tasks and coroutines
+====================
+
.. _coroutine:
Coroutines
.. _transport:
Transports
-----------
+==========
Transports are classed provided by :mod:`asyncio` in order to abstract
various kinds of communication channels. You generally won't instantiate
the transport's kind.
-Methods common to all transports: BaseTransport
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+BaseTransport: Methods common to all transports
+-----------------------------------------------
.. class:: BaseTransport
- ``'subprocess'``: :class:`subprocess.Popen` instance
-Methods of readable streaming transports: ReadTransport
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+ReadTransport: Methods of readable streaming transports
+-------------------------------------------------------
.. class:: ReadTransport
will be called once again if some data is available for reading.
-Methods of writable streaming transports: WriteTransport
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+WriteTransport: Methods of writable streaming transports
+--------------------------------------------------------
.. class:: WriteTransport
(e.g. SSL) doesn't support half-closes.
-Methods of datagram transports
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+DatagramTransport: Methods of datagram transports
+-------------------------------------------------
.. method:: DatagramTransport.sendto(data, addr=None)
Methods of subprocess transports
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+--------------------------------
.. class:: BaseSubprocessTransport
On Windows, this method is an alias for :meth:`terminate`.
-Stream reader and writer
-------------------------
+Stream reader
+-------------
.. class:: StreamWriter(transport, protocol, reader, loop)
see :meth:`WriteTransport.write_eof`.
+Stream writer
+-------------
+
.. class:: StreamReader(limit=_DEFAULT_LIMIT, loop=None)
.. method:: exception()
.. _protocol:
Protocols
----------
+=========
:mod:`asyncio` provides base classes that you can subclass to implement
your network protocols. Those classes are used in conjunction with
Protocol classes
-^^^^^^^^^^^^^^^^
+----------------
.. class:: Protocol
Connection callbacks
-^^^^^^^^^^^^^^^^^^^^
+--------------------
These callbacks may be called on :class:`Protocol` and
:class:`SubprocessProtocol` instances:
Data reception callbacks
-^^^^^^^^^^^^^^^^^^^^^^^^
+------------------------
Streaming protocols
-"""""""""""""""""""
+^^^^^^^^^^^^^^^^^^^
The following callbacks are called on :class:`Protocol` instances:
and, if called, :meth:`data_received` won't be called after it.
Datagram protocols
-""""""""""""""""""
+^^^^^^^^^^^^^^^^^^
The following callbacks are called on :class:`DatagramProtocol` instances.
Flow control callbacks
-^^^^^^^^^^^^^^^^^^^^^^
+----------------------
These callbacks may be called on :class:`Protocol` and
:class:`SubprocessProtocol` instances:
mark is zero.
-Protocols
----------
-
-:mod:`asyncio` provides base classes that you can subclass to implement
-your network protocols. Those classes are used in conjunction with
-:ref:`transports <transport>` (see below): the protocol parses incoming
-data and asks for the writing of outgoing data, while the transport is
-responsible for the actual I/O and buffering.
-
-When subclassing a protocol class, it is recommended you override certain
-methods. Those methods are callbacks: they will be called by the transport
-on certain events (for example when some data is received); you shouldn't
-call them yourself, unless you are implementing a transport.
-
-.. note::
- All callbacks have default implementations, which are empty. Therefore,
- you only need to implement the callbacks for the events in which you
- are interested.
-
-
Server
------
Network functions
------------------
+=================
.. function:: open_connection(host=None, port=None, *, loop=None, limit=_DEFAULT_LIMIT, **kwds)
.. _sync:
Synchronization primitives
---------------------------
+==========================
+
+Locks
+-----
.. class:: Lock(\*, loop=None)
This method returns a :ref:`coroutine <coroutine>`.
+Semaphores
+----------
+
.. class:: Semaphore(value=1, \*, loop=None)
A Semaphore implementation.
increase the value above the initial value.
+Queues
+------
+
.. class:: Queue(maxsize=0, \*, loop=None)
A queue, useful for coordinating producer and consumer coroutines.