Merging a generator's "next" and "send" methods?
data:image/s3,"s3://crabby-images/8dbd5/8dbd55c2312c406f7ab8c23810ff157e8120146c" alt=""
Since .next() seems to be equivalent to .send(None), why wasn't .next() just given an optional parameter which defaults to None? - Andrey On Thu, Oct 1, 2009 at 1:10 PM, Simon Forman <sajmikins@gmail.com> wrote:
data:image/s3,"s3://crabby-images/3c3b2/3c3b2a6eec514cc32680936fa4e74059574d2631" alt=""
On Fri, Feb 19, 2010 at 11:12 AM, Andrey Fedorov <anfedorov@gmail.com> wrote:
Since .next() seems to be equivalent to .send(None), why wasn't .next() just given an optional parameter which defaults to None?
Because for built-in iterator types the next() method is implemented in C and we didn't want to invalidate existing C code by giving it an optional argument. But why do you care? --Guido
-- --Guido van Rossum (python.org/~guido)
data:image/s3,"s3://crabby-images/4217a/4217a515224212b2ea36411402cf9d76744a5025" alt=""
On 19 Feb 2010, at 17:12 , Andrey Fedorov wrote:
You'd have to check the ML discussions on PEP 342 (Coroutines via Enhanced Generators). The PEP explicitly states that send(None) is equivalent to next()
A new method was probably created because it would be quite unclear that `next(value)` sends that value into the generator for consumption by a yield expression. Whereas the purpose of `send(value)` looks pretty obvious.
data:image/s3,"s3://crabby-images/8dbd5/8dbd55c2312c406f7ab8c23810ff157e8120146c" alt=""
Guido van Rossum <guido@python.org> wrote:
Ah, makes sense. But why do you care? Curiosity more than anything. It would be elegant if .send() had identical behavior to .next() without an argument, instead of throwing an exception, but it's no biggie. Cheers, Andrey Masklinn <masklinn@masklinn.net> wrote:
You'd have to check the ML discussions on PEP 342 (Coroutines via Enhanced Generators).
Sweet, thanks for the pointer. Sorry for not searching harder. On Fri, Feb 19, 2010 at 11:32 AM, Masklinn <masklinn@masklinn.net> wrote:
data:image/s3,"s3://crabby-images/3c3b2/3c3b2a6eec514cc32680936fa4e74059574d2631" alt=""
On Fri, Feb 19, 2010 at 11:12 AM, Andrey Fedorov <anfedorov@gmail.com> wrote:
Since .next() seems to be equivalent to .send(None), why wasn't .next() just given an optional parameter which defaults to None?
Because for built-in iterator types the next() method is implemented in C and we didn't want to invalidate existing C code by giving it an optional argument. But why do you care? --Guido
-- --Guido van Rossum (python.org/~guido)
data:image/s3,"s3://crabby-images/4217a/4217a515224212b2ea36411402cf9d76744a5025" alt=""
On 19 Feb 2010, at 17:12 , Andrey Fedorov wrote:
You'd have to check the ML discussions on PEP 342 (Coroutines via Enhanced Generators). The PEP explicitly states that send(None) is equivalent to next()
A new method was probably created because it would be quite unclear that `next(value)` sends that value into the generator for consumption by a yield expression. Whereas the purpose of `send(value)` looks pretty obvious.
data:image/s3,"s3://crabby-images/8dbd5/8dbd55c2312c406f7ab8c23810ff157e8120146c" alt=""
Guido van Rossum <guido@python.org> wrote:
Ah, makes sense. But why do you care? Curiosity more than anything. It would be elegant if .send() had identical behavior to .next() without an argument, instead of throwing an exception, but it's no biggie. Cheers, Andrey Masklinn <masklinn@masklinn.net> wrote:
You'd have to check the ML discussions on PEP 342 (Coroutines via Enhanced Generators).
Sweet, thanks for the pointer. Sorry for not searching harder. On Fri, Feb 19, 2010 at 11:32 AM, Masklinn <masklinn@masklinn.net> wrote:
participants (3)
-
Andrey Fedorov
-
Guido van Rossum
-
Masklinn