summaryrefslogtreecommitdiffstats
path: root/Doc/ref/refa1.tex
diff options
context:
space:
mode:
authorMichael W. Hudson <mwh@python.net>2001-08-27 20:02:17 (GMT)
committerMichael W. Hudson <mwh@python.net>2001-08-27 20:02:17 (GMT)
commit53da3178011d5eaf143d6d9d76274a7530204179 (patch)
treefb925ca1fbd4b221068a84a2d0c81205c67abc46 /Doc/ref/refa1.tex
parent71b6af91d382a0e084b55f1d519aedc1b71a97d4 (diff)
downloadcpython-53da3178011d5eaf143d6d9d76274a7530204179.zip
cpython-53da3178011d5eaf143d6d9d76274a7530204179.tar.gz
cpython-53da3178011d5eaf143d6d9d76274a7530204179.tar.bz2
Docs for the PEP 264 changes.
Diffstat (limited to 'Doc/ref/refa1.tex')
-rw-r--r--Doc/ref/refa1.tex34
1 files changed, 23 insertions, 11 deletions
diff --git a/Doc/ref/refa1.tex b/Doc/ref/refa1.tex
index 9a22513..bd3a38c 100644
--- a/Doc/ref/refa1.tex
+++ b/Doc/ref/refa1.tex
@@ -40,14 +40,17 @@ lines that can appear before a future statement are:
\end{itemize}
-The only feature recognized by Python 2.1 is \samp{nested_scopes}.
-
-A future statement is recognized and treated specially at compile time:
-Changes to the semantics of core constructs are often implemented by
-generating different code. It may even be the case that a new feature
-introduces new incompatible syntax (such as a new reserved word), in
-which case the compiler may need to parse the module differently. Such
-decisions cannot be pushed off until runtime.
+The features recognized by Python 2.2 are \samp{generators},
+\samp{division} and \samp{nested_scopes}. \samp{nested_scopes}
+is redundant in 2.2 as the nested scopes feature is active by default.
+
+A future statement is recognized and treated specially at compile
+time: Changes to the semantics of core constructs are often
+implemented by generating different code. It may even be the case
+that a new feature introduces new incompatible syntax (such as a new
+reserved word), in which case the compiler may need to parse the
+module differently. Such decisions cannot be pushed off until
+runtime.
For any given release, the compiler knows which feature names have been
defined, and raises a compile-time error if a future statement contains
@@ -72,8 +75,11 @@ no special semantics or syntax restrictions.
Code compiled by an exec statement or calls to the builtin functions
\function{compile()} and \function{execfile()} that occur in a module
-\module{M} containing a future statement will use the new syntax or
-semantics associated with the future statement.
+\module{M} containing a future statement will, by default, use the new
+syntax or semantics associated with the future statement. This can,
+starting with Python 2.2 be controlled by optional arguments to
+\function{compile()} --- see the documentation of that function in the
+library reference for details.
A future statement typed at an interactive interpreter prompt will
take effect for the rest of the interpreter session. If an
@@ -110,7 +116,8 @@ is executed.
Each statment in \file{__future__.py} is of the form:
\begin{verbatim}
-FeatureName = "_Feature(" OptionalRelease "," MandatoryRelease ")"
+FeatureName = "_Feature(" OptionalRelease "," MandatoryRelease ","
+ CompilerFlag ")"
\end{verbatim}
where, normally, OptionalRelease is less then MandatoryRelease, and
@@ -143,6 +150,11 @@ feature got dropped.
Instances of class \class{_Feature} have two corresponding methods,
\method{getOptionalRelease()} and \method{getMandatoryRelease()}.
+CompilerFlag is the (bitfield) flag that should be passed in the
+fourth argument to the builtin function \function{compile()} to enable
+the feature in dynamically compiled code. This flag is stored in the
+\member{compiler_flag} attribute on \class{_Future} instances.
+
No feature description will ever be deleted from \module{__future__}.
\section{Nested scopes \label{nested-scopes}}