summaryrefslogtreecommitdiffstats
path: root/Lib/runpy.py
diff options
context:
space:
mode:
authorNick Coghlan <ncoghlan@gmail.com>2008-12-14 10:54:50 (GMT)
committerNick Coghlan <ncoghlan@gmail.com>2008-12-14 10:54:50 (GMT)
commita2053475bb8a908e1cc80c765e02c98a6f354b19 (patch)
tree8449947a38952aaf7e64a7320c58fedf85fa07db /Lib/runpy.py
parent3e16f3dd7f9219a19e5802b721b19fde93fc56a5 (diff)
downloadcpython-a2053475bb8a908e1cc80c765e02c98a6f354b19.zip
cpython-a2053475bb8a908e1cc80c765e02c98a6f354b19.tar.gz
cpython-a2053475bb8a908e1cc80c765e02c98a6f354b19.tar.bz2
Fix several issues relating to access to source code inside zipfiles. Initial work by Alexander Belopolsky. See Misc/NEWS in this checkin for details.
Diffstat (limited to 'Lib/runpy.py')
-rwxr-xr-xLib/runpy.py13
1 files changed, 7 insertions, 6 deletions
diff --git a/Lib/runpy.py b/Lib/runpy.py
index f3c3890..fea6104 100755
--- a/Lib/runpy.py
+++ b/Lib/runpy.py
@@ -65,13 +65,14 @@ def _run_module_code(code, init_globals=None,
# This helper is needed due to a missing component in the PEP 302
# loader protocol (specifically, "get_filename" is non-standard)
+# Since we can't introduce new features in maintenance releases,
+# support was added to zipimporter under the name '_get_filename'
def _get_filename(loader, mod_name):
- try:
- get_filename = loader.get_filename
- except AttributeError:
- return None
- else:
- return get_filename(mod_name)
+ for attr in ("get_filename", "_get_filename"):
+ meth = getattr(loader, attr, None)
+ if meth is not None:
+ return meth(mod_name)
+ return None
# Helper to get the loader, code and filename for a module
def _get_module_details(mod_name):