From 30416ecb91c8c81388cd77b4e2ca715a31a4c4ff Mon Sep 17 00:00:00 2001 From: Victor Stinner Date: Tue, 8 Jul 2014 11:19:35 +0200 Subject: Tulip issue #185: Add a create_task() method to event loops The create_task() method can be overriden in custom event loop to implement their own task class. For example, greenio and Pulsar projects use their own task class. The create_task() method is now preferred over creating directly task using the Task class. --- asyncio/tasks.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) (limited to 'asyncio/tasks.py') diff --git a/asyncio/tasks.py b/asyncio/tasks.py index 8c7217b..befc296 100644 --- a/asyncio/tasks.py +++ b/asyncio/tasks.py @@ -505,7 +505,9 @@ def async(coro_or_future, *, loop=None): raise ValueError('loop argument must agree with Future') return coro_or_future elif coroutines.iscoroutine(coro_or_future): - task = Task(coro_or_future, loop=loop) + if loop is None: + loop = events.get_event_loop() + task = loop.create_task(coro_or_future) if task._source_traceback: del task._source_traceback[-1] return task -- cgit v1.2.1