]> granicus.if.org Git - python/commitdiff
Forward port MvL's fix in 43227:
authorNeal Norwitz <nnorwitz@gmail.com>
Thu, 23 Mar 2006 05:39:47 +0000 (05:39 +0000)
committerNeal Norwitz <nnorwitz@gmail.com>
Thu, 23 Mar 2006 05:39:47 +0000 (05:39 +0000)
Fix crash when a Unicode string containing an encoding declaration is
compile()d. Fixes #1115379.

Lib/test/test_compile.py
Misc/NEWS
Python/ast.c

index 1d47f91b4cb371ec282834506ac8ee1ec8b64fd9..72c4f7e9286bfd03a2ab752333d0546467ac0cdb 100644 (file)
@@ -284,6 +284,10 @@ if 1:
         f1, f2 = f()
         self.assertNotEqual(id(f1.func_code), id(f2.func_code))
 
+    def test_unicode_encoding(self):
+        code = u"# -*- coding: utf-8 -*-\npass\n"
+        self.assertRaises(SyntaxError, compile, code, "tmp", "exec")
+
     def test_subscripts(self):
         # SF bug 1448804
         # Class to make testing subscript results easy
index 400504ddcefd1a54fb69a023b0584eb61d49c670..f41f23737f223a81205968cd4421b30e7d8bf926 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -12,6 +12,9 @@ What's New in Python 2.5 alpha 1?
 Core and builtins
 -----------------
 
+- Bug #1115379: Compiling a Unicode string with an encoding declaration
+  now gives a SyntaxError.
+
 - Previously, Python code had no easy way to access the contents of a
   cell object. Now, a ``cell_contents`` attribute has been added
   (closes patch #1170323).
index 3c339f000ee0fd669a1ced0fd892d0461962a408..30275a6d403d476e8c5b541b26e26fb85ab0d3b9 100644 (file)
@@ -191,6 +191,10 @@ PyAST_FromNode(const node *n, PyCompilerFlags *flags, const char *filename,
 
     if (flags && flags->cf_flags & PyCF_SOURCE_IS_UTF8) {
         c.c_encoding = "utf-8";
+        if (TYPE(n) == encoding_decl) {
+                ast_error(n, "encoding declaration in Unicode string");
+                goto error;
+        }
     } else if (TYPE(n) == encoding_decl) {
         c.c_encoding = STR(n);
         n = CHILD(n, 0);