Browse Source

Issue #25758: Prevents zipimport from unnecessarily encoding a filename (patch by Eryk Sun)

pull/40/head
Steve Dower 10 years ago
parent
commit
8dcc48ee3b
  1. 2
      Lib/test/test_zipimport.py
  2. 3
      Misc/NEWS
  3. 14
      Modules/zipimport.c

2
Lib/test/test_zipimport.py

@ -596,7 +596,7 @@ class UncompressedZipImportTestCase(ImportHooksBaseTestCase):
z.writestr(zinfo, test_src)
z.close()
try:
zipimport.zipimporter(filename)
zipimport.zipimporter(filename).load_module(TESTMOD)
finally:
os.remove(filename)

3
Misc/NEWS

@ -10,6 +10,9 @@ Release date: TBA
Core and Builtins
-----------------
- Issue #25758: Prevents zipimport from unnecessarily encoding a filename
(patch by Eryk Sun)
- Issue #27812: Properly clear out a generator's frame's backreference to the
generator to prevent crashes in frame.clear().

14
Modules/zipimport.c

@ -1362,22 +1362,16 @@ normalize_line_endings(PyObject *source)
static PyObject *
compile_source(PyObject *pathname, PyObject *source)
{
PyObject *code, *fixed_source, *pathbytes;
pathbytes = PyUnicode_EncodeFSDefault(pathname);
if (pathbytes == NULL)
return NULL;
PyObject *code, *fixed_source;
fixed_source = normalize_line_endings(source);
if (fixed_source == NULL) {
Py_DECREF(pathbytes);
return NULL;
}
code = Py_CompileString(PyBytes_AsString(fixed_source),
PyBytes_AsString(pathbytes),
Py_file_input);
Py_DECREF(pathbytes);
code = Py_CompileStringObject(PyBytes_AsString(fixed_source),
pathname, Py_file_input, NULL, 1);
Py_DECREF(fixed_source);
return code;
}

Loading…
Cancel
Save