diff options
| author | Victor Stinner <victor.stinner@gmail.com> | 2015-01-15 15:29:23 (GMT) |
|---|---|---|
| committer | Victor Stinner <victor.stinner@gmail.com> | 2015-01-15 15:29:23 (GMT) |
| commit | a39eb0f42b8926aad10fe4f11371f0ec219da276 (patch) | |
| tree | 48861a02ef674dc3861bb9ead1bff4ef5ac34ae6 /Lib/asyncio/tasks.py | |
| parent | 9fef5244ebbfddf18889d2b9669f50e2ee3fc449 (diff) | |
| parent | 922bc2ca123630aa9cff63c605a82af05408318d (diff) | |
| download | cpython-a39eb0f42b8926aad10fe4f11371f0ec219da276.zip cpython-a39eb0f42b8926aad10fe4f11371f0ec219da276.tar.gz cpython-a39eb0f42b8926aad10fe4f11371f0ec219da276.tar.bz2 | |
Merge 3.4 (asyncio)
Diffstat (limited to 'Lib/asyncio/tasks.py')
| -rw-r--r-- | Lib/asyncio/tasks.py | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/Lib/asyncio/tasks.py b/Lib/asyncio/tasks.py index 7959a55..63412a9 100644 --- a/Lib/asyncio/tasks.py +++ b/Lib/asyncio/tasks.py @@ -347,10 +347,9 @@ def wait_for(fut, timeout, *, loop=None): it cancels the task and raises TimeoutError. To avoid the task cancellation, wrap it in shield(). - Usage: - - result = yield from asyncio.wait_for(fut, 10.0) + If the wait is cancelled, the task is also cancelled. + This function is a coroutine. """ if loop is None: loop = events.get_event_loop() @@ -367,7 +366,12 @@ def wait_for(fut, timeout, *, loop=None): try: # wait until the future completes or the timeout - yield from waiter + try: + yield from waiter + except futures.CancelledError: + fut.remove_done_callback(cb) + fut.cancel() + raise if fut.done(): return fut.result() |
