<div dir="ltr">Agreed. (But let's hear from the OP first.)<br></div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Dec 15, 2015 at 12:27 PM, Andrew Svetlov <span dir="ltr"><<a href="mailto:andrew.svetlov@gmail.com" target="_blank">andrew.svetlov@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Both Yury's suggestions sounds reasonable.<br>
<div><div class="h5"><br>
On Tue, Dec 15, 2015 at 10:24 PM, Yury Selivanov<br>
<<a href="mailto:yselivanov.ml@gmail.com">yselivanov.ml@gmail.com</a>> wrote:<br>
> Hi Roy and Guido,<br>
><br>
> On 2015-12-15 3:08 PM, Guido van Rossum wrote:<br>
> [..]<br>
>><br>
>><br>
>> I don't know how long you have been using async/await, but I wonder if<br>
>> it's possible that you just haven't gotten used to the typical usage<br>
>> patterns? In particular, your claim "anything that takes an `awaitable` has<br>
>> to know that it wasn't already awaited" makes me sound that you're just<br>
>> using it in an atypical way (perhaps because your model is based on other<br>
>> languages). In typical asyncio code, one does not usually take an awaitable,<br>
>> wait for it, and then return it -- one either awaits it and then extracts<br>
>> the result, or one returns it without awaiting it.<br>
><br>
><br>
> I agree.  Holding a return value just so that coroutine can return it again<br>
> seems wrong to me.<br>
><br>
> However, since coroutines are now a separate type (although they share a lot<br>
> of code with generators internally), maybe we can change them to throw an<br>
> error when they are awaited on more than one time?<br>
><br>
> That should be better than letting them return `None`:<br>
><br>
>     coro = coroutine()<br>
>     await coro<br>
>     await coro  # <- will raise RuntimeError<br>
><br>
><br>
> I'd also add a check that the coroutine isn't being awaited by more than one<br>
> coroutine simultaneously (another, completely different issue, more on which<br>
> here: <a href="https://github.com/python/asyncio/issues/288" rel="noreferrer" target="_blank">https://github.com/python/asyncio/issues/288</a>).  This was fixed in<br>
> asyncio in debug mode, but ideally, we should fix this in the interpreter<br>
> core.<br>
><br>
> Yury<br>
> _______________________________________________<br>
> Python-Dev mailing list<br>
> <a href="mailto:Python-Dev@python.org">Python-Dev@python.org</a><br>
> <a href="https://mail.python.org/mailman/listinfo/python-dev" rel="noreferrer" target="_blank">https://mail.python.org/mailman/listinfo/python-dev</a><br>
> Unsubscribe:<br>
</div></div>> <a href="https://mail.python.org/mailman/options/python-dev/andrew.svetlov%40gmail.com" rel="noreferrer" target="_blank">https://mail.python.org/mailman/options/python-dev/andrew.svetlov%40gmail.com</a><br>
<span class="HOEnZb"><font color="#888888"><br>
<br>
<br>
--<br>
Thanks,<br>
Andrew Svetlov<br>
</font></span><div class="HOEnZb"><div class="h5">_______________________________________________<br>
Python-Dev mailing list<br>
<a href="mailto:Python-Dev@python.org">Python-Dev@python.org</a><br>
<a href="https://mail.python.org/mailman/listinfo/python-dev" rel="noreferrer" target="_blank">https://mail.python.org/mailman/listinfo/python-dev</a><br>
Unsubscribe: <a href="https://mail.python.org/mailman/options/python-dev/guido%40python.org" rel="noreferrer" target="_blank">https://mail.python.org/mailman/options/python-dev/guido%40python.org</a><br>
</div></div></blockquote></div><br><br clear="all"><br>-- <br><div class="gmail_signature">--Guido van Rossum (<a href="http://python.org/~guido" target="_blank">python.org/~guido</a>)</div>
</div>