2020-07-21 13:47:28 -04:00
|
|
|
# test waiting within "async for" __anext__ function
|
2016-04-13 10:27:06 -04:00
|
|
|
|
2020-10-11 02:39:32 -04:00
|
|
|
# uPy allows normal generators to be awaitables.
|
|
|
|
# CircuitPython does not.
|
|
|
|
# In CircuitPython you need to have an __await__ method on an awaitable like in CPython;
|
|
|
|
# and like in CPython, generators do not have __await__.
|
|
|
|
|
|
|
|
class Awaitable:
|
|
|
|
def __init__(self, x):
|
|
|
|
self.x = x
|
|
|
|
|
|
|
|
def __await__(self):
|
|
|
|
print('f start:', self.x)
|
|
|
|
yield self.x + 1
|
|
|
|
yield self.x + 2
|
|
|
|
return self.x + 3
|
2016-04-13 10:27:06 -04:00
|
|
|
|
|
|
|
class ARange:
|
|
|
|
def __init__(self, high):
|
|
|
|
print('init')
|
|
|
|
self.cur = 0
|
|
|
|
self.high = high
|
|
|
|
|
2020-07-21 13:47:28 -04:00
|
|
|
def __aiter__(self):
|
2016-04-13 10:27:06 -04:00
|
|
|
print('aiter')
|
|
|
|
return self
|
|
|
|
|
|
|
|
async def __anext__(self):
|
|
|
|
print('anext')
|
2020-10-11 02:39:32 -04:00
|
|
|
print('f returned:', await Awaitable(20))
|
2016-04-13 10:27:06 -04:00
|
|
|
if self.cur < self.high:
|
|
|
|
val = self.cur
|
|
|
|
self.cur += 1
|
|
|
|
return val
|
|
|
|
else:
|
|
|
|
raise StopAsyncIteration
|
|
|
|
|
|
|
|
async def coro():
|
|
|
|
async for x in ARange(4):
|
|
|
|
print('x', x)
|
|
|
|
|
|
|
|
o = coro()
|
|
|
|
try:
|
|
|
|
while True:
|
|
|
|
print('coro yielded:', o.send(None))
|
|
|
|
except StopIteration:
|
|
|
|
print('finished')
|