summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrett Cannon <bcannon@gmail.com>2009-02-01 05:33:17 (GMT)
committerBrett Cannon <bcannon@gmail.com>2009-02-01 05:33:17 (GMT)
commit51c502689cb174016364f0b8f2a75efa0de090f3 (patch)
treee0f40469293292dc5327827cbc9c5d6ca9b44938
parent6c3aaf3276df9e9b7880acad3f4cc5ed8c6b6ba4 (diff)
downloadcpython-51c502689cb174016364f0b8f2a75efa0de090f3.zip
cpython-51c502689cb174016364f0b8f2a75efa0de090f3.tar.gz
cpython-51c502689cb174016364f0b8f2a75efa0de090f3.tar.bz2
Expose source_path and bytecode_path on _PyFileLoader.
-rw-r--r--Lib/importlib/NOTES3
-rw-r--r--Lib/importlib/_bootstrap.py21
2 files changed, 13 insertions, 11 deletions
diff --git a/Lib/importlib/NOTES b/Lib/importlib/NOTES
index 57e2674..089fef7 100644
--- a/Lib/importlib/NOTES
+++ b/Lib/importlib/NOTES
@@ -3,8 +3,7 @@ to do
* API simplification?
- + read_source -> get_data/source_path
- + read_bytecode -> get_data/bytecode_path
+ + Use *_path() along with get_data
+ write_bytecode -> complete set of bytes for bytecode instead of
individual arguments.
diff --git a/Lib/importlib/_bootstrap.py b/Lib/importlib/_bootstrap.py
index d2d5d34..da24291 100644
--- a/Lib/importlib/_bootstrap.py
+++ b/Lib/importlib/_bootstrap.py
@@ -341,13 +341,15 @@ class _PyFileLoader(object):
else:
return None
- def _source_path(self):
+ @check_name
+ def source_path(self, fullname):
"""Return the path to an existing source file for the module, or None
if one cannot be found."""
# Not a property so that it is easy to override.
return self._find_path(imp.PY_SOURCE)
- def _bytecode_path(self):
+ @check_name
+ def bytecode_path(self, fullname):
"""Return the path to a bytecode file, or None if one does not
exist."""
# Not a property for easy overriding.
@@ -357,8 +359,9 @@ class _PyFileLoader(object):
@get_module
def load_module(self, module):
"""Load a Python source or bytecode module."""
- source_path = self._source_path()
- bytecode_path = self._bytecode_path()
+ name = module.__name__
+ source_path = self.source_path(name)
+ bytecode_path = self.bytecode_path(name)
code_object = self.get_code(module.__name__)
module.__file__ = source_path if source_path else bytecode_path
module.__loader__ = self
@@ -376,7 +379,7 @@ class _PyFileLoader(object):
def source_mtime(self, name):
"""Return the modification time of the source for the specified
module."""
- source_path = self._source_path()
+ source_path = self.source_path(name)
if not source_path:
return None
return int(_os.stat(source_path).st_mtime)
@@ -389,7 +392,7 @@ class _PyFileLoader(object):
laoder cannot handle the specified module.
"""
- source_path = self._source_path()
+ source_path = self._source_path(name)
if source_path is None:
return None
import tokenize
@@ -407,7 +410,7 @@ class _PyFileLoader(object):
The returned path is used by 'compile' for error messages.
"""
- source_path = self._source_path()
+ source_path = self.source_path(fullname)
if source_path is None:
return None
with closing(_fileio._FileIO(source_path, 'r')) as bytes_file:
@@ -422,7 +425,7 @@ class _PyFileLoader(object):
the module. Returns None if there is no bytecode.
"""
- path = self._bytecode_path()
+ path = self.bytecode_path(name)
if path is None:
return None
file = _fileio._FileIO(path, 'r')
@@ -443,7 +446,7 @@ class _PyFileLoader(object):
cannot be handled by the loader.
"""
- bytecode_path = self._bytecode_path()
+ bytecode_path = self.bytecode_path(name)
if not bytecode_path:
bytecode_path = self._base_path + suffix_list(imp.PY_COMPILED)[0]
file = _fileio._FileIO(bytecode_path, 'w')