(merge 3.2) Issue #12451: pydoc: importfile() now opens the Python script in
binary mode, instead of text mode using the locale encoding, to avoid encoding issues.
This commit is contained in:
commit
5f9a995ad7
26
Lib/pydoc.py
26
Lib/pydoc.py
|
@ -250,20 +250,18 @@ class ErrorDuringImport(Exception):
|
|||
def importfile(path):
|
||||
"""Import a Python source file or compiled file given its path."""
|
||||
magic = imp.get_magic()
|
||||
file = open(path, 'r')
|
||||
if file.read(len(magic)) == magic:
|
||||
kind = imp.PY_COMPILED
|
||||
else:
|
||||
kind = imp.PY_SOURCE
|
||||
file.close()
|
||||
filename = os.path.basename(path)
|
||||
name, ext = os.path.splitext(filename)
|
||||
file = open(path, 'r')
|
||||
try:
|
||||
module = imp.load_module(name, file, path, (ext, 'r', kind))
|
||||
except:
|
||||
raise ErrorDuringImport(path, sys.exc_info())
|
||||
file.close()
|
||||
with open(path, 'rb') as file:
|
||||
if file.read(len(magic)) == magic:
|
||||
kind = imp.PY_COMPILED
|
||||
else:
|
||||
kind = imp.PY_SOURCE
|
||||
file.seek(0)
|
||||
filename = os.path.basename(path)
|
||||
name, ext = os.path.splitext(filename)
|
||||
try:
|
||||
module = imp.load_module(name, file, path, (ext, 'r', kind))
|
||||
except:
|
||||
raise ErrorDuringImport(path, sys.exc_info())
|
||||
return module
|
||||
|
||||
def safeimport(path, forceload=0, cache={}):
|
||||
|
|
|
@ -209,6 +209,9 @@ Core and Builtins
|
|||
Library
|
||||
-------
|
||||
|
||||
- Issue #12451: pydoc: importfile() now opens the Python script in binary mode,
|
||||
instead of text mode using the locale encoding, to avoid encoding issues.
|
||||
|
||||
- Issue #12451: runpy: run_path() now opens the Python script in binary mode,
|
||||
instead of text mode using the locale encoding, to support other encodings
|
||||
than UTF-8 (scripts using the coding cookie).
|
||||
|
|
Loading…
Reference in New Issue