diff options
author | Martin v. Löwis <martin@v.loewis.de> | 2006-02-27 19:56:30 (GMT) |
---|---|---|
committer | Martin v. Löwis <martin@v.loewis.de> | 2006-02-27 19:56:30 (GMT) |
commit | 415ed937c21f0d563fb11a20189831b908673462 (patch) | |
tree | 022cd5e9955db1b55dc5583a50e10ae2f7207c0f | |
parent | b9eb5510e676627759d804271dc3b46682291cc2 (diff) | |
download | cpython-415ed937c21f0d563fb11a20189831b908673462.zip cpython-415ed937c21f0d563fb11a20189831b908673462.tar.gz cpython-415ed937c21f0d563fb11a20189831b908673462.tar.bz2 |
Skip over doc strings.
-rw-r--r-- | Lib/compiler/future.py | 9 | ||||
-rw-r--r-- | Misc/NEWS | 2 |
2 files changed, 10 insertions, 1 deletions
diff --git a/Lib/compiler/future.py b/Lib/compiler/future.py index 868b7cbb..414e64e 100644 --- a/Lib/compiler/future.py +++ b/Lib/compiler/future.py @@ -22,7 +22,14 @@ class FutureParser: def visitModule(self, node): stmt = node.node + found_docstring = False for s in stmt.nodes: + # Skip over docstrings + if not found_docstring and isinstance(s, ast.Discard) \ + and isinstance(s.expr, ast.Const) \ + and isinstance(s.expr.value, str): + found_docstring = True + continue if not self.check_stmt(s): break @@ -50,7 +57,7 @@ class BadFutureParser: return if node.modname != "__future__": return - raise SyntaxError, "invalid future statement" + raise SyntaxError, "invalid future statement " + repr(node) def find_futures(node): p1 = FutureParser() @@ -393,6 +393,8 @@ Extension Modules Library ------- +- The compiler package now supports future imports after the module docstring. + - Bug #1413790: zipfile now sanitizes absolute archive names that are not allowed by the specs. |