Commit 7ed99544 authored by Jim Mussared's avatar Jim Mussared Committed by Damien George

extmod/uasyncio: Add asyncio.current_task().

Matches CPython behavior.

Fixes #6686
parent d1289999
...@@ -40,6 +40,10 @@ Core functions ...@@ -40,6 +40,10 @@ Core functions
Returns the corresponding `Task` object. Returns the corresponding `Task` object.
.. function:: current_task()
Return the `Task` object associated with the currently running task.
.. function:: run(coro) .. function:: run(coro)
Create a new task from the given coroutine and run it until it completes. Create a new task from the given coroutine and run it until it completes.
......
...@@ -264,6 +264,10 @@ def get_event_loop(runq_len=0, waitq_len=0): ...@@ -264,6 +264,10 @@ def get_event_loop(runq_len=0, waitq_len=0):
return Loop return Loop
def current_task():
return cur_task
def new_event_loop(): def new_event_loop():
global _task_queue, _io_queue global _task_queue, _io_queue
# TaskQueue of Task instances # TaskQueue of Task instances
......
# Test current_task() function
try:
import uasyncio as asyncio
except ImportError:
try:
import asyncio
except ImportError:
print("SKIP")
raise SystemExit
async def task(result):
result[0] = asyncio.current_task()
async def main():
result = [None]
t = asyncio.create_task(task(result))
await asyncio.sleep(0)
await asyncio.sleep(0)
print(t is result[0])
asyncio.run(main())
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment