define an idiomatic way to make a generator that throws StopIteration immediately and add it to PEP8
data:image/s3,"s3://crabby-images/e990f/e990f619a25617092a4692371c47cdc75b5b94db" alt=""
the way to make an (aysnc)generator that immediately raises Stop(Async)Iteration immediately is to insert an unreachable `yield` statement, however there's two ways to do it: def example(): if False: yield or: def example(): return yield currently test_asyncgen.py uses both, eg: @types.coroutine def __anext__(self): if False: yield "this is a generator-based coroutine" if self.yielded >= 2: raise StopAsyncIteration() else: self.yielded += 1 return self.yielded or: async def agenfn(): try: await _async_yield(1) except MyError: await _async_yield(2) return yield the `if False: yield` version has a disadvantage in that it can be anywhere in the function, if this one is chosen then an additional caveat is that it should be the first two statements in a function if `return; yield` version has an disadvantage in that the unreachable yield could be inserted after any `return`, if this one is chosen then an additional caveat is that it should be the last two statements in a function and de-dented as much as syntactically possible. Which alternative do you prefer? I prefer `return; yield`
data:image/s3,"s3://crabby-images/98c42/98c429f8854de54c6dfbbe14b9c99e430e0e4b7d" alt=""
03.09.21 10:28, Thomas Grainger пише:
the way to make an (aysnc)generator that immediately raises Stop(Async)Iteration immediately is to insert an unreachable `yield` statement, however there's two ways to do it:
I think it is too uncommon case to specify it in PEP 8.
data:image/s3,"s3://crabby-images/e990f/e990f619a25617092a4692371c47cdc75b5b94db" alt=""
`yield from (,)` produced different byte code when I tried it, so I think it's a tad slower Also yield from doesn't work in async generators
data:image/s3,"s3://crabby-images/98c42/98c429f8854de54c6dfbbe14b9c99e430e0e4b7d" alt=""
03.09.21 10:28, Thomas Grainger пише:
the way to make an (aysnc)generator that immediately raises Stop(Async)Iteration immediately is to insert an unreachable `yield` statement, however there's two ways to do it:
I think it is too uncommon case to specify it in PEP 8.
data:image/s3,"s3://crabby-images/e990f/e990f619a25617092a4692371c47cdc75b5b94db" alt=""
`yield from (,)` produced different byte code when I tried it, so I think it's a tad slower Also yield from doesn't work in async generators
participants (3)
-
Antoine Rozo
-
Serhiy Storchaka
-
Thomas Grainger