% Should these be added to the standard Python doc tools? (They'll be
% needed for my "Distributing Python Modules" guide, too.)
\newcommand{\command}[1]{\code{#1}}
-\newcommand{\option}[1]{\code{#1}}
+\newcommand{\option}[1]{\textsf{\small{#1}}}
\newcommand{\filevar}[1]{{\textsl{\filenq{#1}}}}
+\newcommand{\homefile}[1]{\file{\tilde/#1}}
\newcommand{\comingsoon}{\emph{Coming soon$\ \ldots$}}
% And how about these? Very handy for writing pathnames (tilde for
couple of options to the \command{install} command:
\begin{tableii}{ll}{option}{Option}{Description}
- \lineii{prefix}{base dir for pure Python distributions
- (overrides \code{sys.prefix})}
- \lineii{exec-prefix}{base dir for distributions with extensions
- (overrides \code{sys.exec_prefix})}
- \lineii{install-lib}{install dir for top-level modules from pure
- Python distributions}
- \lineii{install-platlib}{install dir for top-level modules from
- distributions with extensions}
- \lineii{install-path}{extra path under \option{install-lib} or
- \option{install-platlib} to install to}
+ \lineii {install-lib}
+ {install directory for modules from pure Python distributions}
+ \lineii {install-platlib}
+ {install directory for modules from distributions with extensions}
+ \lineii {prefix}
+ {override \code{sys.prefix}:
+ point to an alternate Python installation}
+ \lineii {exec-prefix}
+ {override \code{sys.exec_prefix}:
+ point to an alternate Python installation}
+ \lineii {install-path}
+ {extra sub-path to append to \option{install-lib} (for
+ non-package-ized distributions)}
\end{tableii}
+Of these, the most commonly used will probably be \option{install-lib}
+and \option{install-platlib}: you use them to point module installation
+right at a particular directory. (You'll only need
+\option{install-platlib} if you maintain a multi-platform installation,
+which is often done on \UNIX{} networks with different architectures and
+operating systems.) The two prefix options are intended for the
+somewhat arcane purpose of installing modules into a different Python
+installation than the Python binary used to perform the installation.
+The last, \option{install-path}, is mainly used for module developers to
+ensure that their module will go into a directory of their own, but it
+may occasionally be useful to you as a module installer.
-\subsection{Prefix options}
-\label{sec:prefix-options}
-
-There are a lot of picky little rules that govern the interactions of
-these five options. As usual, it's easier to explain things with
-examples, so we'll save all the picky rules for later, after you've seen
-a bunch of examples. However, we really have to establish some ground
-rules before we can dive into the examples:
-\begin{itemize}
-\item in a normal \UNIX{} installation, \code{sys.prefix} and
- \code{sys.exec\_prefix} are both \file{/usr/local}.
-\item in a multi-platform \UNIX{} installation, \code{sys.prefix} and
- \code{sys.exec\_prefix} are different, and are selected when you
- configure and build Python itself. Our canonical example of a
- multi-platform installation will have a \code{sys.prefix} of
- \file{/usr/local} and a \code{sys.exec\_prefix} of
- \file{/usr/local.\filevar{plat}} (for whatever value of \filevar{plat}
- is appropriate).
-\item the canonical place to install third-party modules is
- either \file{\filevar{prefix}/lib/python1.\filevar{X}/site-packages}
- or \file{\filevar{exec\_prefix}/lib/python1.\filevar{X}/site-packages}.
- These will be referred to as ``the site-packages directories.''
-\end{itemize}
-
-
-\subsubsection{Pure Python module distribution}
-
-To demonstrate, consider a hypothetical module distribution that
-contains one top-level module and a package with two modules:
-\begin{tableii}{ll}{module}{Module}{Filename}
- \lineii{mymod}{\filenq{mymod.py}}
- \lineii{mypkg.mod1}{\filenq{mypkg/mod1.py}}
- \lineii{mypkg.mod2}{\filenq{mypkg/mod2.py}}
-\end{tableii}
-where the filenames are relative to \file{build/lib} after building, or
-to some directory in \code{sys.path} after installation.
-
-The goal of installation is to copy these files into a directory in
-\code{sys.path} without interfering with the standard Python library.
-The canonical, preferred, and most obvious thing to do is to put them in
-the ``site-packages'' directory, which is exactly what the
-\command{install} comand does by default: under a normal \UNIX{} Python
-installation,
-\begin{verbatim}
- python setup.py install
-\end{verbatim}
-installs \file{/usr/local/lib/python1.\filevar{X}/lib/site-packages/mymod.py},
-with the \module{mypkg} package in a \file{mypkg} directory under
-\file{site-packages}.
-However, if you were interested in a standard installation, you wouldn't
-be reading this section. The next-most-standard thing to do is to
-specify a custom prefix to override \code{sys.prefix}. For example:
+\subsection{Directly specifying installation directories}
+\label{sec:install-dirs}
+
+The most common type of custom module installation is where you maintain
+a personal stash of Python modules under your home directory, say in
+\homefile{lib/python}. If you only care about a single platform
+there, then you only need to specify the \option{install-lib} option and
+can forget about \option{install-platlib}:
\begin{verbatim}
- python setup.py install --prefix=/home/greg
+python setup.py install --install-lib=~/lib/python
\end{verbatim}
-is a sensible way to install Python modules to your home directory: this
-results in the installation of \file{/home/greg/lib/python/mymod.py},
-with the \module{mypkg} modules in \file{/home/greg/lib/python/mypkg/}.
-An important point here is that in both this example and the ``plain
-vanilla'' example above, the actual installation directory is derived
-from the \option{prefix} option. However, when \option{prefix} differs
-from \code{sys.prefix}, the installation directory is derived
-differently: the Python version and \file{site-packages} are omitted.
-(The version number is part of the standard library directory name to
-describe the version of the standard library, so it doesn't make sense
-to include it in the name of a non-standard-library directory; likewise,
-\file{site-packages} is meant to denote non-standard modules living in
-the same area as the standard library, so it doesn't make sense to
-include it when installing to a non-standard library. [XXX check with
-Guido that this reasoning is valid and correct; Fred disagrees!])
-
-
-\subsubsection{Module distribution with extensions}
-
-Now let's consider a different hypothetical module distribution, which
-consists of a single package, \module{foo}, containing one pure Python
-module and one extension module:
-\begin{tableii}{ll}{module}{Module}{Filename}
- \lineii{foo.pure}{\filenq{foo/pure.py}}
- \lineii{foo.ext}{\filenq{foo/ext.so} (or \file{foo/extmodule.so})}
-\end{tableii}
-In this case, the two modules will be in different locations in the
-build tree: \file{build/lib/foo/pure.py} and
-\file{build/platlib/foo/ext.so}. (The \file{.so} (``shared object'')
-extension isn't universal, but it's the norm on \UNIX-like systems;
-under Windows, the extension module will be in \file{foo/ext.pyd} or
-\file{foo/extmodule.pyd}.)
-
-Consider again a standard, plain-vanilla installation:
+You can, of course, supply whatever directory you like in place of
+\homefile{lib/python}. More importantly, you can specify this
+directory permanently in your personal configuration file (XXX
+filename?):
\begin{verbatim}
- python setup.py install
+[install]
+install-lib=~/lib/python
\end{verbatim}
-In this case, \emph{both} modules will be installed to the site-packages
-directory under \code{sys.exec\_prefix}, e.g. to
-\file{/usr/local.\filevar{plat}/lib/python1.\filevar{X}/site-packages}
-on a \UNIX{} system where Python was configured with
-\samp{--exec-prefix=/usr/local.plat}. (On Windows, again, there is no
-site-packages directory and \code{sys.prefix} and
-\code{sys.exec\_prefix} are the same---so both modules will just be
-installed to \code{sys.prefix}.)
-
-Of course, we've already established that you're not interested in
-standard installations. If you just want to install these modules to
-your home directory, and you don't maintain a multi-platform home
-directory, no problem---just set the prefix as before:
+Note that use of shell-style tilde and environment variable expansion is
+supported both on the command line and in configuration files. (See
+section~\ref{sec:config-files} for more information on configuration
+files.)
+
+Of course, in order for this personal Python library scheme to work, you
+have to ensure that \homefile{lib/python} is in \code{sys.path} when you
+run Python. The easiest way to do this under \UNIX{} is to add it to
+your \code{PYTHONPATH} environment variable when you login. For
+example, if you use a Bourne shell derivative such as bash, zsh, or ksh,
+add the following to your \homefile{.profile} (or \homefile{.bashrc}, or
+\homefile{.zshenv}, depending on your shell and personal preferences):
\begin{verbatim}
-python setup.py install --prefix=/home/greg
+export PYTHONPATH=$HOME/lib/python
\end{verbatim}
-and both modules will be installed to \file{/home/greg/lib/python}.
-
-Now let's say your Python installation is in \file{/usr}---as is the
-case in many Linux distributions---but your local policy is to install
-third-party software to a network-wide \file{/usr/local} and
-\file{/usr/local.\filevar{plat}}. That is, \code{sys.prefix} and
-\code{sys.exec\_prefix} are both \file{/usr}, and you want Python
-modules to be installed to either \file{/usr/local/lib/python} or
-\file{/usr/local.\filevar{plat}/lib/python}. This is one case where you
-want to specify both \option{prefix} and \option{exec-prefix}:
+If you use a csh-derivative such as tcsh, add the following to your
+\homefile{.cshrc}:
\begin{verbatim}
-python setup.py install --prefix=/usr/local \
- --exec-prefix=/usr/local.plat
+setenv PYTHONPATH $HOME/lib/python
\end{verbatim}
-An oddity of this situation is that for any given module distribution,
-you only have to supply \emph{one} of \option{prefix} and
-\option{exec-prefix}, because pure Python distributions are always
-installed under \option{prefix}, and extension-containing distributions
-are always installed under \option{exec-prefix}. For consistency's
-sake, though, it's best always to supply both---and the best way to do
-that is by using a system-wide configuration file (see
-Section~\ref{sec:config-files}).
-
-You could use a similar scheme to maintain a multi-platform personal
-Python library. For example, if you install lots of stuff to your home
-directory (not just Python modules), you might have a complete
-\file{\tilde/usr} with \file{include}, \file{man}, \file{lib}, and so
-forth. (The advantage of this scheme is that it keeps those mock system
-directories out of your home directory and makes it easier to support a
-multi-platform personal \file{usr} tree.) If you don't care about a
-multi-platform installation, you can just install with
+
+If you use multiple platforms (architectures and/or operating systems)
+from the same home directory, then you probably want to maintain a
+multi-platform personal Python library. One possible scheme is to put
+platform-neutral (pure Python) distributions in \homefile{lib/python}
+and platform-specific distributions (any that containe extension
+modules) in \homefile{lib/python.\filevar{plat}}:
\begin{verbatim}
-python setup.py install --prefix=$HOME/usr
+python setup.py install --install-lib=~/lib/python \
+ --install-lib-plat=~/lib/python.plat \
\end{verbatim}
-But if you want to keep separate \file{usr} trees for each architecture
-that you use, you could say
+On the command line, of course, you can just type in the current
+platform in place of \filevar{plat}: \file{linux-x86},
+\file{solaris-sparc}, \file{linux-alpha}, whatever. That's not an
+option in a configuration file, though---the same file has to cover all
+platforms for which you maintain a personal Python library. So the
+Distutils provide a \code{PLAT} environment variable which will expand
+to the current platform name:
\begin{verbatim}
-python setup.py install --prefix=$HOME/usr \
- --exec-prefix=$HOME/usr.plat
+[install]
+install-lib=~/lib/python
+install-platlib=~/lib/python.$PLAT
\end{verbatim}
-for various values of \file{plat}.
-
-% this paragraph is for Michel Sanner ;-)
-(Perceptive readers will note that on a multi-platform Python
-installation, multiple identical copies of \file{foo/pure.py} will be
-installed, one for each platform. This is deliberate. First, it makes
-Python's module search algorithm simpler (XXX check this): when you say
-\samp{import foo.pure}, Python searches \code{sys.path} until it finds a
-directory containing \file{foo/__init__.py}. When it finds one, that
-directory is deemed to be the directory containing the \module{foo}
-package for this import. Even if the search algorithm were changed
-(necessitating a trip back in time to ``fix'' Python 1.5), the only way
-to make multiple candidate \module{foo} directories (one for pure
-Python, one for extension modules) would be to make copies of
-\file{__init__.py}---in which case, why not make copies of all the pure
-Python modules? Second, if you kept pure Python modules related to
-extension modules in a platform-shared directory, what happens while you
-are upgrading your favourite extension from version 1.0 to 1.1 on
-platforms X and Y? After you install 1.1 for platform X, the 1.1
-\file{.py} files will be in the platform-shared directory---but the 1.0
-extensions will still be in the platform Y directory. If the interval
-between installing 1.1 for platform X and for platform Y is long---e.g.,
-there are portability problems with platform Y---then there's a good
-probability of a version mismatch between the 1.1 Python modules and the
-1.0 extensions on platform Y. The solution to both problems is to
-install separate copies of the pure Python modules for every platform.
-In this day and age, unnecessary disk use is no argument.)
-
-Other ways to support a multi-platform personal Python library are
-discussed below, when we cover the \option{install-lib} and
-\option{install-platlib} options.
-
-
-% Gory details on the prefix options (still need to work these into the
-% surrounding text):
-XXX need to finish these rules and give them some context!
-\begin{itemize}
-\item \code{sys.exec\_prefix} (and the \option{exec-prefix} option)
- only matters on a multi-platform installation. If you don't have a
- multi-platform installation (or even know what that is), then you
- don't care about \option{exec-prefix}.
-\item in a normal Windows installation, \code{sys.prefix} and
- \code{sys.exec\_prefix} are both \file{C:\bslash Program Files\bslash
- Python}; they are never different under Windows (XXX check!).
-\item you may supply \emph{both} of \option{prefix} and
- \option{exec-prefix}, or \emph{neither} of them, or \emph{just}
- \option{prefix}---but you may not supply just \option{exec-prefix}.
-\end{itemize}
-
-
-\subsection{Installation directory options}
-\label{sec:install-dirs}
-
-Most of the time, it's enough to specify just \option{prefix} (and
-possibly \option{exec-prefix})---your modules are installed to
-\file{lib/python} under one or the other, you add the appropriate
-directory to \code{sys.path}, and that's it.
-
-However, there will inevitably be times when you want finer control over
-the installation directories, and that is when the \option{install-lib},
-\option{install-platlib}, and \option{install-path} options are
-essential. Normally, \option{install-lib} and \option{install-platlib}
-are simply the directories where pure Python modules and extension
-modules, respectively, are installed. That is, top-level modules
-(modules not in a package) are installed straight to
-\option{install-lib} (or \option{install-platlib} if there are any
-extensions in the module distribution). (If \option{install-path} is
-supplied, then things are a bit more complex; we'll deal with that
+(If \code{PLAT} is already defined in your environment, the Distutils
+won't override it: that way you can maintain consistency with other
+applications that look for a \code{PLAT} variable; this is especially
+useful when you refer to \code{PLAT} in your login scripts, as explained
below.)
-Normally, \option{install-lib} and \option{install-platlib} are derived
-from \option{prefix} and/or \option{exec-prefix}. For example, if you
-don't supply anything, then \option{prefix} defaults to
-\code{sys.prefix}, and \option{install-lib} defaults to
-\file{\filevar{prefix}/lib/python1.\filevar{X}/site-packages}. If you
-supply \option{prefix} but not \option{install-lib}, then
-\option{install-lib} defaults to \file{\filevar{prefix}/lib/python}
-(unless you just happen to supply a prefix which equals
-\code{sys.prefix}, which is treated the same as if you don't supply
-\option{prefix} at all). (The rules for \option{exec-prefix} and
-\option{install-platlib} are a bit more complex; the following examples
-should clarify. Consult the Distutils source for the gory details.)
-
-To illustrate, let's go back to our hypothetical pure-Python module
-distribution containing \module{mymod}, \module{mypkg.mod1}, and
-\module{mypkg.mod2}. If you maintain a personal stash of Python modules
-in your home directory, but don't like the \file{\tilde/lib/python}
-convention, no problem---you can put the modules right in a
-\file{\tilde/python} directory with
+(XXX danger danger! this environment-variable-in-config-file thing is
+frighteningly make-like: is there any way to avoid it?)
+
+Again, you have to make sure that your personal Python library appears
+in \code{sys.path}, and again the easiest way to do this is to set
+\code{PYTHONPATH} in your login scripts. This time, though, you have to
+be sure to set \emph{both} directories (platform-neutral and the current
+platform-specific directory). For Bourne-shell derivatives:
+\begin{verbatim}
+export PYTHONPATH=$HOME/lib/python:$HOME/lib/python.$PLAT
+\end{verbatim}
+and for csh-derivatives:
+\begin{verbatim}
+setenv PYTHONPATH $HOME/lib/python:$HOME/lib/python.$PLAT
+\end{verbatim}
+Note that it is your responsibility to set the \code{PATH} environment
+variable (unless your system administrator has kindly taken care of it
+in the system-wide login scripts, which is a wise thing to do on
+multi-platform networks). One way to do this is with the \code{uname}
+command:
\begin{verbatim}
-python setup.py install --install-lib=$HOME/python
+export PLAT=`uname -sm | tr 'A-Z ' 'a-z-'`
\end{verbatim}
-which will install \file{\$HOME/python/mymod.py},
-\file{\$HOME/python/mypkg/mod1.py}, and
-\file{\$HOME/python/mypkg/mod2.py}.
-
-If you happen to install a module distribution that contains extensions,
-again that's no problem---in the absence of \option{exec-prefix},
-\option{install-platlib} defaults to \option{install-lib}, so the above
-example will also put extension modules in \file{\$HOME/python}.
-(XXX is this correct? is this the best way to describe it? should it be
-implemented this way or some other way? how should it be described?)
-
-This may not be what you want, though, if you maintain a multi-platform
-stash of Python modules in your home directory. In that case, you need
-to specify \option{install-platlib}---this is the directory where module
-distributions with extensions will be installed. For example, if you
-keep pure Python module distributions in \file{\tilde/python} and
-extension distributions in \file{\tilde/python.plat}:
+(XXX check that this works well on other Unices: on Linux, \code{-m}
+becomes eg. \code{i586}, which is not the \emph{machine} but the
+\emph{processor}. Arggh!)
+
+Of course, there are more reasons to do custom installation than
+maintaining a personal Python library. Even if you have write access to
+the system-wide directories for third-party modules
+(\file{\filevar{prefix}/lib/python1.\filevar{x}/site-packages} and
+\file{\filevar{exec-prefix}/lib/python1.\filevar{x}/site-packages}), you
+might want to install new module distributions---especially upgrades of
+modules that are crucial to your local infrastructure---to a temporary
+location, in order to test them before installing them ``for real.''
+This is fundamentally no different from installing to your home
+directory, except that you probably won't bother to set
+\code{PYTHONPATH} permanently. For example, to install a module
+distribution to \file{/tmp/pylib}:
\begin{verbatim}
-python setup.py install --install-lib=$HOME/python \
- --install-platlib=$HOME/python.plat
+python setup.py install --install-lib=/tmp/pylib
\end{verbatim}
-(Just as with \option{prefix} and \option{exec-prefix}, it's only
-necessary to supply one of \option{install-lib} and
-\option{install-platlib} for any given module distribution, but to
-ensure consistency you should always supply them both using a
-configuration file (section~\ref{sec:config-files}).)
-
-An alternate way to maintain a multi-platform personal Python library is
-in \file{\tilde/lib/python} and \file{\tilde/lib/python.plat}. In that
-case, you can get away with supplying \option{prefix} and
-\option{install-platlib}:
+Then, of course, you'll want to run some script that depends on these
+modules to make sure that they still work with your installed base of
+code:
\begin{verbatim}
-python setup.py install --prefix=$HOME \
- --install-platlib=$HOME/lib/python.plat
+env PYTHONPATH=/tmp/pylib python /usr/local/bin/crucial_script ...
\end{verbatim}
-Finally, the \option{install-path} option, which exists mainly to gum up
-the whole works---but in a productive (and important) way.
-Specifically, \option{install-path} exists to give a directory of their
-own to module distributions that wouldn't otherwise have one, i.e.\ that
-are not distributed as a (Python) package.
-
-Consider a module distribution, Foo, that consists of (pure Python)
-modules \module{foobar}, \module{foobaz}, and \module{fooqux}.
-Obviously these are related, and if the project had started in the
-Python 1.5 era (and doesn't worry about backwards compatibility with
-Python 1.4), they probably would be packaged up and called
-\module{foo.bar}, \module{foo.baz}, and \module{foo.qux}.
-Unfortunately, they aren't, but we still want the Foo modules to go into
-a directory of their own.
-
-Normally, this will be taken care of by the module developer: he adds a
-line \samp{install_path = 'Foo'} to his setup script, which has the
-following consequences:
-\begin{enumerate}
-\item instead of \option{install-lib} the modules would be installed in
- \file{\filevar{install-lib}/Foo}
-\item if \option{install-lib} is the same as the default
- \option{install-lib}---e.g., you supplied neither \option{prefix} or
- \option{install-lib}---then a \file{Foo.pth} will be created in
- \option{install-lib}, so that Python adds
- \file{\filevar{install-lib}/Foo} to \code{sys.path}
-\item if \option{install-lib} is not the default, then a warning will be
- printed, reminding you to add \file{\filevar{install-lib}/Foo} to
- \code{sys.path} yourself, such as with the \code{PYTHONPATH}
- environment variable
-\end{enumerate}
-
-Thus, you as a module installer have to be aware of the
-\option{install-path} option---especially if you maintain a personal
-stash of Python modules and don't have write permission to the standard
-library, so Distutils can't create \file{.pth} files for you---but you
-don't often have to supply it yourself. There are situations in which
-you might want to supply it, though:
-\begin{itemize}
-\item a module developer forgot to include it (the distribution really
- should go in a directory of its own, but it won't unless you make it)
-\item you want to override the \option{install-path} supplied by the
- developer (e.g., you'd rather have a huge jumble of files in
- \file{site-packages} than make Python wade through a bunch of
- \file{.pth} files at startup)
-\end{itemize}
-
-The first case is easy: say we're dealing with the Foo distribution
-again, but the developer forgot to include \option{install-path}. No
-problem, you can supply it on the command line:
+Of course, you can do this temporary installation with separate
+\option{install-lib} and \option{install-platlib} options. If you're
+doing this to a network-wide directory, not \file{/tmp}, this might be
+essential. As you might have guessed, it's not too hard:
\begin{verbatim}
-python setup.py install --install-path=Foo
+python setup.py install --install-lib=/scratch/pylib \
+ --install-platlib=/scratch/pylib.plat
\end{verbatim}
-Note that this will work just fine if you supply \option{prefix} or
-\option{install-lib}---but of course, you'll probably have to ensure
-that the \file{Foo} directory is in \code{sys.path} yourself.
-
-If you're really fanatical about keeping track of what you have
-installed, you might want to supply your own \option{install-path} that
-records the version as well as the name of the module distribution; this
-overrides any \option{install-path} included by the module developer in
-the setup script:
+and then, testing your crucial scripts on multiple platforms:
\begin{verbatim}
-python setup.py install --install-path=Foo-1.3
+env PYTHONPATH=/scratch/pylib:/scratch/pylib.plat \
+ python /usr/local/bin/crucial_script ...
\end{verbatim}
-Finally, you can disable \option{install-path} entirely:
+However you do the testing, once you're satisfied that the new version
+doesn't break anything, you can install it to the system-wide
+third-party module directory as usual:
\begin{verbatim}
-python setup.py install --install-path=''
+python setup.py install
\end{verbatim}
-...but the mess that will result (modules from many different
-distributions in the same \option{install-lib} and
-\option{install-platlib} directories) is your own problem.
-
-% Points to make
-% * only one of prefix or exec_prefix matters
-% * don't have to specify exec_prefix unless != prefix
-% * thus, usually enough to supply prefix
-% * only have to supply install_lib if you don't like
-% "prefix/lib/python"
-% * likewise for install_platlib and exec_prefix
-% * don't have to supply install_platlib unless != install_lib (??)
-% * in the absence of install_path, top-level modules wind up in
-% install_lib or install_platlib
-In case you're interested, here are the exact rules for how
-\option{install-lib} and \option{install-platlib} are initialized, and
-how they and \option{install-path} affect where modules (pure Python and
-extensions) are installed to:
-\begin{itemize}
-\item If you don't supply \option{prefix} (and possibly
- \option{exec-prefix}), then \option{install-lib} and
- \option{install-platlib} will be, respectively,
- \file{\filevar{\$prefix}/lib/python1.\filevar{X}/site-packages} and
- \file{\filevar{\$exec\_prefix}/lib/python1.\filevar{X}/site-packages}. In a
- normal \UNIX{} installation, both of these resolve to
- \file{/usr/local/lib/python1.\filevar{X}/site-packages}.
-\item in the absence of an \option{install-path} option, top-level
- modules and packages from a pure Python distribution are installed to
- \option{install-lib}
-\item in the absence of an \option{install-path} option, top-level
- modules and packages from a distribution that contains \emph{any}
- extension modules are installed to \option{install-platlib}.
-\item \emph{there're more, but I don't remember everything offhand}
-%\item \option{install-lib} is initialized from \option{prefix} (which
-% in turn is initialized from \code{sys.prefix})---so you should
-\end{itemize}
+
+
+\subsection{Indirect specification: prefix directories}
+\label{sec:prefix-dirs}
+
+Occasionally, you may want to install a module distribution
\section{Custom Installation (Windows)}