summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorBrett Cannon <brett@python.org>2012-04-17 02:11:25 (GMT)
committerBrett Cannon <brett@python.org>2012-04-17 02:11:25 (GMT)
commit16475adcbb9b8131da2a1615bfbeb34a358e7400 (patch)
treef53a2d5f6669f63858b950a9c829a6a64bf7b0ff /Lib
parent4132368d0aeaba66195c75686dcb16d5e841bb7d (diff)
downloadcpython-16475adcbb9b8131da2a1615bfbeb34a358e7400.zip
cpython-16475adcbb9b8131da2a1615bfbeb34a358e7400.tar.gz
cpython-16475adcbb9b8131da2a1615bfbeb34a358e7400.tar.bz2
Issue #13959: Re-implement imp.load_source() in imp.py.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/imp.py29
1 files changed, 28 insertions, 1 deletions
diff --git a/Lib/imp.py b/Lib/imp.py
index 2832d54..0b344d6 100644
--- a/Lib/imp.py
+++ b/Lib/imp.py
@@ -14,7 +14,7 @@ from _imp import (lock_held, acquire_lock, release_lock, reload,
from _imp import (get_magic, get_tag, get_suffixes, cache_from_source,
source_from_cache)
# Should be re-implemented here (and mostly deprecated)
-from _imp import (find_module, load_compiled, load_source, NullImporter,
+from _imp import (find_module, load_compiled, NullImporter,
SEARCH_ERROR, PY_SOURCE, PY_COMPILED, C_EXTENSION,
PY_RESOURCE, PKG_DIRECTORY, C_BUILTIN, PY_FROZEN,
PY_CODERESOURCE, IMP_HOOK)
@@ -25,6 +25,33 @@ from importlib import _bootstrap
import os
+class _LoadSourceCompatibility(_bootstrap._SourceFileLoader):
+
+ """Compatibility support for implementing load_source()."""
+
+ def __init__(self, fullname, path, file=None):
+ super().__init__(fullname, path)
+ self.file = file
+
+ def get_data(self, path):
+ """Gross hack to contort SourceFileLoader to deal w/ load_source()'s bad
+ API."""
+ if path == self._path:
+ with self.file:
+ # Technically should be returning bytes, but
+ # SourceLoader.get_code() just passed what is returned to
+ # compile() which can handle str. And converting to bytes would
+ # require figuring out the encoding to decode to and
+ # tokenize.detect_encoding() only accepts bytes.
+ return self.file.read()
+ else:
+ return super().get_data(path)
+
+
+def load_source(name, pathname, file=None):
+ return _LoadSourceCompatibility(name, pathname, file).load_module(name)
+
+
def load_package(name, path):
if os.path.isdir(path):
extensions = _bootstrap._suffix_list(PY_SOURCE)