mirror of
https://github.com/python/cpython.git
synced 2025-01-27 03:24:35 +08:00
Remove more usage of APIs deprecated by PEP 451.
This commit is contained in:
parent
3a62d14b24
commit
02b9f9d6bb
@ -659,20 +659,20 @@ class EditorWindow(object):
|
||||
return
|
||||
# XXX Ought to insert current file's directory in front of path
|
||||
try:
|
||||
loader = importlib.find_loader(name)
|
||||
spec = importlib.find_spec(name)
|
||||
except (ValueError, ImportError) as msg:
|
||||
tkMessageBox.showerror("Import error", str(msg), parent=self.text)
|
||||
return
|
||||
if loader is None:
|
||||
if spec is None:
|
||||
tkMessageBox.showerror("Import error", "module not found",
|
||||
parent=self.text)
|
||||
return
|
||||
if not isinstance(loader, importlib.abc.SourceLoader):
|
||||
if not isinstance(spec.loader, importlib.abc.SourceLoader):
|
||||
tkMessageBox.showerror("Import error", "not a source-based module",
|
||||
parent=self.text)
|
||||
return
|
||||
try:
|
||||
file_path = loader.get_filename(name)
|
||||
file_path = spec.loader.get_filename(name)
|
||||
except AttributeError:
|
||||
tkMessageBox.showerror("Import error",
|
||||
"loader does not support get_filename",
|
||||
|
@ -554,13 +554,14 @@ def extend_path(path, name):
|
||||
|
||||
finder = get_importer(dir)
|
||||
if finder is not None:
|
||||
portions = []
|
||||
if hasattr(finder, 'find_spec'):
|
||||
spec = finder.find_spec(final_name)
|
||||
if spec is not None:
|
||||
portions = spec.submodule_search_locations or []
|
||||
# Is this finder PEP 420 compliant?
|
||||
if hasattr(finder, 'find_loader'):
|
||||
loader, portions = finder.find_loader(final_name)
|
||||
else:
|
||||
# No, no need to call it
|
||||
loader = None
|
||||
portions = []
|
||||
elif hasattr(finder, 'find_loader'):
|
||||
_, portions = finder.find_loader(final_name)
|
||||
|
||||
for portion in portions:
|
||||
# XXX This may still add duplicate entries to path on
|
||||
|
@ -140,13 +140,14 @@ def _readmodule(module, path, inpackage=None):
|
||||
search_path = path
|
||||
else:
|
||||
search_path = path + sys.path
|
||||
loader = importlib.find_loader(fullmodule, search_path)
|
||||
fname = loader.get_filename(fullmodule)
|
||||
# XXX This will change once issue19944 lands.
|
||||
spec = importlib.find_spec(fullmodule, search_path)
|
||||
fname = spec.loader.get_filename(fullmodule)
|
||||
_modules[fullmodule] = dict
|
||||
if loader.is_package(fullmodule):
|
||||
if spec.loader.is_package(fullmodule):
|
||||
dict['__path__'] = [os.path.dirname(fname)]
|
||||
try:
|
||||
source = loader.get_source(fullmodule)
|
||||
source = spec.loader.get_source(fullmodule)
|
||||
if source is None:
|
||||
return dict
|
||||
except (AttributeError, ImportError):
|
||||
|
Loading…
Reference in New Issue
Block a user