summaryrefslogtreecommitdiffstats
path: root/Lib/site.py
diff options
context:
space:
mode:
authorBrett Cannon <brett@python.org>2020-11-07 02:45:56 (GMT)
committerGitHub <noreply@github.com>2020-11-07 02:45:56 (GMT)
commit825ac383327255d38b69a753e5e41710bb3ed010 (patch)
tree86543aba40795918c174dbb899528e339c619208 /Lib/site.py
parent7c01f1540f958d4f52188b28afca721a9a6925c3 (diff)
downloadcpython-825ac383327255d38b69a753e5e41710bb3ed010.zip
cpython-825ac383327255d38b69a753e5e41710bb3ed010.tar.gz
cpython-825ac383327255d38b69a753e5e41710bb3ed010.tar.bz2
bpo-42133: update parts of the stdlib to fall back to `__spec__.loader` when `__loader__` is missing (#22929)
Diffstat (limited to 'Lib/site.py')
-rw-r--r--Lib/site.py11
1 files changed, 9 insertions, 2 deletions
diff --git a/Lib/site.py b/Lib/site.py
index 4d3b869..3a0f619 100644
--- a/Lib/site.py
+++ b/Lib/site.py
@@ -105,8 +105,15 @@ def makepath(*paths):
def abs_paths():
"""Set all module __file__ and __cached__ attributes to an absolute path"""
for m in set(sys.modules.values()):
- if (getattr(getattr(m, '__loader__', None), '__module__', None) not in
- ('_frozen_importlib', '_frozen_importlib_external')):
+ loader_module = None
+ try:
+ loader_module = m.__loader__.__module__
+ except AttributeError:
+ try:
+ loader_module = m.__spec__.loader.__module__
+ except AttributeError:
+ pass
+ if loader_module not in {'_frozen_importlib', '_frozen_importlib_external'}:
continue # don't mess with a PEP 302-supplied __file__
try:
m.__file__ = os.path.abspath(m.__file__)