diff options
author | Benjamin Peterson <benjamin@python.org> | 2008-12-27 18:24:11 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2008-12-27 18:24:11 (GMT) |
commit | 8d5934b25d7c3e636444428dc715316a08b8c94e (patch) | |
tree | a1e10950058a0271d0b15d385a8edcb4c4814595 | |
parent | c3a98034106502a661281c5198ed818849591d40 (diff) | |
download | cpython-8d5934b25d7c3e636444428dc715316a08b8c94e.zip cpython-8d5934b25d7c3e636444428dc715316a08b8c94e.tar.gz cpython-8d5934b25d7c3e636444428dc715316a08b8c94e.tar.bz2 |
#4748 lambda generators shouldn't return values
-rw-r--r-- | Lib/test/test_generators.py | 10 | ||||
-rw-r--r-- | Misc/NEWS | 2 | ||||
-rw-r--r-- | Python/compile.c | 7 |
3 files changed, 18 insertions, 1 deletions
diff --git a/Lib/test/test_generators.py b/Lib/test/test_generators.py index 3702abc..b7c3fdc 100644 --- a/Lib/test/test_generators.py +++ b/Lib/test/test_generators.py @@ -928,6 +928,16 @@ Test the __name__ attribute and the repr() 'f' >>> repr(g) # doctest: +ELLIPSIS '<generator object f at ...>' + +Lambdas shouldn't have their usual return behavior. + +>>> x = lambda: (yield 1) +>>> list(x()) +[1] + +>>> x = lambda: ((yield 1), (yield 2)) +>>> list(x()) +[1, 2] """ # conjoin is a simple backtracking generator, named in honor of Icon's @@ -83,6 +83,8 @@ Core and Builtins - Issue #4509: Various issues surrounding resize of bytearray objects to which there are buffer exports. +- Issue #4748: Lambda generators no longer return a value. + Library ------- diff --git a/Python/compile.c b/Python/compile.c index 756a903..8f0fd8d 100644 --- a/Python/compile.c +++ b/Python/compile.c @@ -1534,7 +1534,12 @@ compiler_lambda(struct compiler *c, expr_ty e) c->u->u_argcount = asdl_seq_LEN(args->args); VISIT_IN_SCOPE(c, expr, e->v.Lambda.body); - ADDOP_IN_SCOPE(c, RETURN_VALUE); + if (c->u->u_ste->ste_generator) { + ADDOP_IN_SCOPE(c, POP_TOP); + } + else { + ADDOP_IN_SCOPE(c, RETURN_VALUE); + } co = assemble(c, 1); compiler_exit_scope(c); if (co == NULL) |