summaryrefslogtreecommitdiffstats
path: root/Doc/whatsnew
diff options
context:
space:
mode:
authorChris Jerdonek <chris.jerdonek@gmail.com>2012-12-23 23:35:23 (GMT)
committerChris Jerdonek <chris.jerdonek@gmail.com>2012-12-23 23:35:23 (GMT)
commit7d2fad1be2cb5f02f5dd2940c5e1fdd9cb3659af (patch)
tree8066712bdfeeabf17b038f785ec0213ffa1b6124 /Doc/whatsnew
parented3115b9d98c86fd0b00f5e91e5ee3dd3639fac9 (diff)
parent2654b86e88aa14f0916cfa10ecdbc0852e7e6795 (diff)
downloadcpython-7d2fad1be2cb5f02f5dd2940c5e1fdd9cb3659af.zip
cpython-7d2fad1be2cb5f02f5dd2940c5e1fdd9cb3659af.tar.gz
cpython-7d2fad1be2cb5f02f5dd2940c5e1fdd9cb3659af.tar.bz2
Merge from 3.3: link to "yield from" examples in yield documentation.
Diffstat (limited to 'Doc/whatsnew')
-rw-r--r--Doc/whatsnew/3.3.rst18
1 files changed, 11 insertions, 7 deletions
diff --git a/Doc/whatsnew/3.3.rst b/Doc/whatsnew/3.3.rst
index 4b9dc9c..4ea4995 100644
--- a/Doc/whatsnew/3.3.rst
+++ b/Doc/whatsnew/3.3.rst
@@ -393,14 +393,18 @@ inspection of exception attributes::
PEP written and implemented by Antoine Pitrou
+.. index::
+ single: yield; yield from (in What's New)
+
.. _pep-380:
PEP 380: Syntax for Delegating to a Subgenerator
================================================
-PEP 380 adds the ``yield from`` expression, allowing a generator to delegate
+PEP 380 adds the ``yield from`` expression, allowing a :term:`generator` to
+delegate
part of its operations to another generator. This allows a section of code
-containing 'yield' to be factored out and placed in another generator.
+containing :keyword:`yield` to be factored out and placed in another generator.
Additionally, the subgenerator is allowed to return with a value, and the
value is made available to the delegating generator.
@@ -421,15 +425,15 @@ However, unlike an ordinary loop, ``yield from`` allows subgenerators to
receive sent and thrown values directly from the calling scope, and
return a final value to the outer generator::
- >>> def accumulate(start=0):
- ... tally = start
+ >>> def accumulate():
+ ... tally = 0
... while 1:
... next = yield
... if next is None:
... return tally
... tally += next
...
- >>> def gather_tallies(tallies, start=0):
+ >>> def gather_tallies(tallies):
... while 1:
... tally = yield from accumulate()
... tallies.append(tally)
@@ -437,7 +441,7 @@ return a final value to the outer generator::
>>> tallies = []
>>> acc = gather_tallies(tallies)
>>> next(acc) # Ensure the accumulator is ready to accept values
- >>> for i in range(10):
+ >>> for i in range(4):
... acc.send(i)
...
>>> acc.send(None) # Finish the first tally
@@ -446,7 +450,7 @@ return a final value to the outer generator::
...
>>> acc.send(None) # Finish the second tally
>>> tallies
- [45, 10]
+ [6, 10]
The main principle driving this change is to allow even generators that are
designed to be used with the ``send`` and ``throw`` methods to be split into