Kaydet (Commit) 8dcc48ee authored tarafından Steve Dower's avatar Steve Dower

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

üst 347dc95c
...@@ -596,7 +596,7 @@ class UncompressedZipImportTestCase(ImportHooksBaseTestCase): ...@@ -596,7 +596,7 @@ class UncompressedZipImportTestCase(ImportHooksBaseTestCase):
z.writestr(zinfo, test_src) z.writestr(zinfo, test_src)
z.close() z.close()
try: try:
zipimport.zipimporter(filename) zipimport.zipimporter(filename).load_module(TESTMOD)
finally: finally:
os.remove(filename) os.remove(filename)
......
...@@ -10,6 +10,9 @@ Release date: TBA ...@@ -10,6 +10,9 @@ Release date: TBA
Core and Builtins 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 - Issue #27812: Properly clear out a generator's frame's backreference to the
generator to prevent crashes in frame.clear(). generator to prevent crashes in frame.clear().
......
...@@ -1362,22 +1362,16 @@ normalize_line_endings(PyObject *source) ...@@ -1362,22 +1362,16 @@ normalize_line_endings(PyObject *source)
static PyObject * static PyObject *
compile_source(PyObject *pathname, PyObject *source) compile_source(PyObject *pathname, PyObject *source)
{ {
PyObject *code, *fixed_source, *pathbytes; PyObject *code, *fixed_source;
pathbytes = PyUnicode_EncodeFSDefault(pathname);
if (pathbytes == NULL)
return NULL;
fixed_source = normalize_line_endings(source); fixed_source = normalize_line_endings(source);
if (fixed_source == NULL) { if (fixed_source == NULL) {
Py_DECREF(pathbytes);
return NULL; return NULL;
} }
code = Py_CompileString(PyBytes_AsString(fixed_source), code = Py_CompileStringObject(PyBytes_AsString(fixed_source),
PyBytes_AsString(pathbytes), pathname, Py_file_input, NULL, 1);
Py_file_input);
Py_DECREF(pathbytes);
Py_DECREF(fixed_source); Py_DECREF(fixed_source);
return code; return code;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment