summaryrefslogtreecommitdiffstats
path: root/Doc/library
diff options
context:
space:
mode:
authorBrett Cannon <brett@python.org>2012-05-12 21:43:17 (GMT)
committerBrett Cannon <brett@python.org>2012-05-12 21:43:17 (GMT)
commitee78a2b51cd9ede91bb780b71444119e1da19e4e (patch)
tree1bd412c9e1f23283a0435e665ca2d33c00d2d3c4 /Doc/library
parentacc0c181a85143e0113f1ec9cb838e86cd8df50f (diff)
downloadcpython-ee78a2b51cd9ede91bb780b71444119e1da19e4e.zip
cpython-ee78a2b51cd9ede91bb780b71444119e1da19e4e.tar.gz
cpython-ee78a2b51cd9ede91bb780b71444119e1da19e4e.tar.bz2
Issue #13959: Introduce importlib.find_loader().
The long-term goal is to deprecate imp.find_module() in favour of this API, but it will take some time as some APIs explicitly return/use what imp.find_module() returns.
Diffstat (limited to 'Doc/library')
-rw-r--r--Doc/library/importlib.rst14
1 files changed, 14 insertions, 0 deletions
diff --git a/Doc/library/importlib.rst b/Doc/library/importlib.rst
index cac5251..0bc1b65 100644
--- a/Doc/library/importlib.rst
+++ b/Doc/library/importlib.rst
@@ -86,6 +86,20 @@ Functions
that was imported (e.g. ``pkg.mod``), while :func:`__import__` returns the
top-level package or module (e.g. ``pkg``).
+.. function:: find_loader(name, path=None)
+
+ Find the loader for a module, optionally within the specified *path*. If the
+ module is in :attr:`sys.modules`, then ``sys.modules[name].__loader__`` is
+ returned (unless the loader would be ``None``, in which case
+ :exc:`ValueError` is raised). Otherwise a search using :attr:`sys.meta_path`
+ is done. ``None`` is returned if no loader is found.
+
+ A dotted name does not have its parent's implicitly imported. If that is
+ desired (although not nessarily required to find the loader, it will most
+ likely be needed if the loader actually is used to load the module), then
+ you will have to import the packages containing the module prior to calling
+ this function.
+
.. function:: invalidate_caches()
Invalidate the internal caches of the finders stored at