summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2014-01-29 23:18:50 (GMT)
committerVictor Stinner <victor.stinner@gmail.com>2014-01-29 23:18:50 (GMT)
commit1ad5afc050778759dcbd6e338d9bd94ae2211a43 (patch)
tree8de94fc03e986e4eeca78093b9f20fd153536805
parent0e5b2412c2162ca57a3c9f0882e9e2c71ade964e (diff)
downloadcpython-1ad5afc050778759dcbd6e338d9bd94ae2211a43.zip
cpython-1ad5afc050778759dcbd6e338d9bd94ae2211a43.tar.gz
cpython-1ad5afc050778759dcbd6e338d9bd94ae2211a43.tar.bz2
asyncio: document iscoroutine(), iscoroutinefunction() and wait_for()
Mention that wait_for() now accepts None for the timeout.
-rw-r--r--Doc/library/asyncio-task.rst30
1 files changed, 28 insertions, 2 deletions
diff --git a/Doc/library/asyncio-task.rst b/Doc/library/asyncio-task.rst
index 8630f82..9bdf1c1 100644
--- a/Doc/library/asyncio-task.rst
+++ b/Doc/library/asyncio-task.rst
@@ -20,12 +20,13 @@ different (though related) concepts:
- The function that defines a coroutine (a function definition
decorated with ``@asyncio.coroutine``). If disambiguation is needed
- we will call this a *coroutine function*.
+ we will call this a *coroutine function* (:func:`iscoroutinefunction`
+ returns ``True``).
- The object obtained by calling a coroutine function. This object
represents a computation or an I/O operation (usually a combination)
that will complete eventually. If disambiguation is needed we will
- call it a *coroutine object*.
+ call it a *coroutine object* (:func:`iscoroutine` returns ``True``).
Things a coroutine can do:
@@ -425,6 +426,15 @@ Task functions
outer Future is *not* cancelled in this case. (This is to prevent the
cancellation of one child to cause other children to be cancelled.)
+.. function:: iscoroutine(obj)
+
+ Return ``True`` if *obj* is a :ref:`coroutine object <coroutine>`.
+
+.. function:: iscoroutinefunction(obj)
+
+ Return ``True`` if *func* is a decorated :ref:`coroutine function
+ <coroutine>`.
+
.. function:: sleep(delay, result=None, \*, loop=None)
Create a :ref:`coroutine object <coroutine>` that completes after a given
@@ -501,3 +511,19 @@ Task functions
the timeout occurs are returned in the second set.
+.. function:: wait_for(fut, timeout, \*, loop=None)
+
+ Wait for the single :class:`Future` or :ref:`coroutine object <coroutine>`
+ to complete, with timeout. If *timeout* is ``None``, block until the future
+ completes.
+
+ Coroutine will be wrapped in :class:`Task`.
+
+ Returns result of the Future or coroutine. When a timeout occurs, it
+ cancels the task and raises :exc:`TimeoutError`. To avoid the task
+ cancellation, wrap it in :func:`shield`.
+
+ Usage::
+
+ result = yield from asyncio.wait_for(fut, 60.0)
+