2004-08-07 17:13:34 -03:00
|
|
|
\section{\module{modulefinder} ---
|
|
|
|
Find modules used by a script}
|
|
|
|
\sectionauthor{A.M. Kuchling}{amk@amk.ca}
|
|
|
|
|
|
|
|
\declaremodule{standard}{modulefinder}
|
|
|
|
\modulesynopsis{Find modules used by a script.}
|
|
|
|
|
2006-01-10 20:14:29 -04:00
|
|
|
\versionadded{2.3}
|
|
|
|
|
2004-08-07 17:13:34 -03:00
|
|
|
This module provides a \class{ModuleFinder} class that can be used to
|
|
|
|
determine the set of modules imported by a script.
|
|
|
|
\code{modulefinder.py} can also be run as a script, giving the
|
|
|
|
filename of a Python script as its argument, after which a report of
|
|
|
|
the imported modules will be printed.
|
|
|
|
|
|
|
|
\begin{funcdesc}{AddPackagePath}{pkg_name, path}
|
|
|
|
Record that the package named \var{pkg_name} can be found in the specified \var{path}.
|
|
|
|
\end{funcdesc}
|
|
|
|
|
|
|
|
\begin{funcdesc}{ReplacePackage}{oldname, newname}
|
|
|
|
Allows specifying that the module named \var{oldname} is in fact
|
|
|
|
the package named \var{newname}. The most common usage would be
|
|
|
|
to handle how the \module{_xmlplus} package replaces the \module{xml}
|
|
|
|
package.
|
|
|
|
\end{funcdesc}
|
|
|
|
|
|
|
|
\begin{classdesc}{ModuleFinder}{\optional{path=None, debug=0, excludes=[], replace_paths=[]}}
|
|
|
|
|
|
|
|
This class provides \method{run_script()} and \method{report()}
|
|
|
|
methods to determine the set of modules imported by a script.
|
|
|
|
\var{path} can be a list of directories to search for modules; if not
|
|
|
|
specified, \code{sys.path} is used.
|
|
|
|
\var{debug} sets the debugging level; higher values make the class print
|
|
|
|
debugging messages about what it's doing.
|
|
|
|
\var{excludes} is a list of module names to exclude from the analysis.
|
|
|
|
\var{replace_paths} is a list of \code{(\var{oldpath}, \var{newpath})}
|
|
|
|
tuples that will be replaced in module paths.
|
|
|
|
\end{classdesc}
|
|
|
|
|
|
|
|
\begin{methoddesc}[ModuleFinder]{report}{}
|
|
|
|
Print a report to standard output that lists the modules imported by the script
|
|
|
|
and their
|
|
|
|
paths, as well as modules that are missing or seem to be missing.
|
|
|
|
\end{methoddesc}
|
|
|
|
|
|
|
|
\begin{methoddesc}[ModuleFinder]{run_script}{pathname}
|
|
|
|
Analyze the contents of the \var{pathname} file, which must contain
|
|
|
|
Python code.
|
|
|
|
\end{methoddesc}
|
|
|
|
|
|
|
|
|