diff options
| author | Yury Selivanov <yselivanov@sprymix.com> | 2015-10-02 15:00:19 -0400 | 
|---|---|---|
| committer | Yury Selivanov <yselivanov@sprymix.com> | 2015-10-02 15:00:19 -0400 | 
| commit | 620279b9ace3fff66245672bf7efbb62b2969a30 (patch) | |
| tree | 943003b56ba425a03351846fb81e38e33952df28 /Lib/asyncio/tasks.py | |
| parent | e2382c598c10482398eafb3e717c80e3f8da703f (diff) | |
| download | cpython-git-620279b9ace3fff66245672bf7efbb62b2969a30.tar.gz | |
asyncio: ensure_future() now understands awaitables
Diffstat (limited to 'Lib/asyncio/tasks.py')
| -rw-r--r-- | Lib/asyncio/tasks.py | 16 | 
1 files changed, 14 insertions, 2 deletions
| diff --git a/Lib/asyncio/tasks.py b/Lib/asyncio/tasks.py index a235e742e2..434f498e47 100644 --- a/Lib/asyncio/tasks.py +++ b/Lib/asyncio/tasks.py @@ -512,7 +512,7 @@ def async(coro_or_future, *, loop=None):  def ensure_future(coro_or_future, *, loop=None): -    """Wrap a coroutine in a future. +    """Wrap a coroutine or an awaitable in a future.      If the argument is a Future, it is returned directly.      """ @@ -527,8 +527,20 @@ def ensure_future(coro_or_future, *, loop=None):          if task._source_traceback:              del task._source_traceback[-1]          return task +    elif compat.PY35 and inspect.isawaitable(coro_or_future): +        return ensure_future(_wrap_awaitable(coro_or_future), loop=loop)      else: -        raise TypeError('A Future or coroutine is required') +        raise TypeError('A Future, a coroutine or an awaitable is required') + + +@coroutine +def _wrap_awaitable(awaitable): +    """Helper for asyncio.ensure_future(). + +    Wraps awaitable (an object with __await__) into a coroutine +    that will later be wrapped in a Task by ensure_future(). +    """ +    return (yield from awaitable.__await__())  class _GatheringFuture(futures.Future): | 
