Guido van Rossum <gu...@python.org> added the comment:

Lots of food for thought! There seem to be mostly two discussions: API design 
for the new asyncio cancel scopes (do we make it more like Trio or more like 
async-timeout?); and cancel semantics in edge cases.

I'll pass on the API design for now: I recommend that Tin and Andrew agree on 
some middle ground first. (Personally I could do without move_on(), I'd just 
add a try/except TimeoutError.)

On the cancel edge case, I am beginning to warm up to (ab)using the existing 
cancel message hack, rather than a separate nonce. I think the message argument 
could be the cancel scope or its id().

I think Andrew missed one case: in his second diagram, what if the explicit 
cancel() happened *after* the timeout (but still in the same iteration)? That's 
the case that makes me want to delete those two lines from Task.cancel() (see 
my earlier message).

(Sorry, I've gotta go play now.)

----------

_______________________________________
Python tracker <rep...@bugs.python.org>
<https://bugs.python.org/issue46771>
_______________________________________
_______________________________________________
Python-bugs-list mailing list
Unsubscribe: 
https://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com

Reply via email to