summaryrefslogtreecommitdiffstats
path: root/Doc/ref
diff options
context:
space:
mode:
Diffstat (limited to 'Doc/ref')
-rw-r--r--Doc/ref/ref5.tex24
1 files changed, 19 insertions, 5 deletions
diff --git a/Doc/ref/ref5.tex b/Doc/ref/ref5.tex
index 9590ee4..d66996a 100644
--- a/Doc/ref/ref5.tex
+++ b/Doc/ref/ref5.tex
@@ -869,17 +869,31 @@ that functions created with lambda forms cannot contain statements.
\indexii{lambda}{form}
\indexii{anonmymous}{function}
-\strong{Programmer's note:} a lambda form defined inside a function
-has no access to names defined in the function's namespace. This is
-because Python has only two scopes: local and global. A common
-work-around is to use default argument values to pass selected
-variables into the lambda's namespace, e.g.:
+\strong{Programmer's note:} Prior to Python 2.1, a lambda form defined
+inside a function has no access to names defined in the function's
+namespace. This is because Python had only two scopes: local and
+global. A common work-around was to use default argument values to
+pass selected variables into the lambda's namespace, e.g.:
\begin{verbatim}
def make_incrementor(increment):
return lambda x, n=increment: x+n
\end{verbatim}
+As of Python 2.1, nested scopes were introduced, and this work-around
+has not been necessary. Python 2.1 supports nested scopes in modules
+which include the statement \samp{from __future__ import
+nested_scopes}, and more recent versions of Python enable nested
+scopes by default. This version works starting with Python 2.1:
+
+\begin{verbatim}
+from __future__ import nested_scopes
+
+def make_incrementor(increment):
+ return lambda x: x+increment
+\end{verbatim}
+
+
\section{Expression lists\label{exprlists}}
\indexii{expression}{list}