2009-05-24 23:02:59 +02:00
|
|
|
/* This function provides a generic Python package builder. It is
|
|
|
|
intended to work with packages that use `setuptools'
|
|
|
|
(http://pypi.python.org/pypi/setuptools/), which represents a large
|
|
|
|
number of Python packages nowadays. */
|
|
|
|
|
2012-02-27 18:33:55 +01:00
|
|
|
{ python, setuptools, wrapPython, lib, site, offlineDistutils, unzip }:
|
2009-05-24 23:02:59 +02:00
|
|
|
|
2011-03-28 17:30:48 +02:00
|
|
|
{ name, namePrefix ? "python-"
|
2009-05-24 23:02:59 +02:00
|
|
|
|
2011-03-28 17:30:48 +02:00
|
|
|
, buildInputs ? []
|
2010-07-28 15:05:04 +02:00
|
|
|
|
2011-03-28 17:30:48 +02:00
|
|
|
, # List of packages that should be added to the PYTHONPATH
|
|
|
|
# environment variable in programs built by this function. Packages
|
|
|
|
# in the standard `propagatedBuildInputs' variable are also added.
|
|
|
|
# The difference is that `pythonPath' is not propagated to the user
|
|
|
|
# environment. This is preferrable for programs because it doesn't
|
|
|
|
# pollute the user environment.
|
|
|
|
pythonPath ? []
|
2009-05-24 23:02:59 +02:00
|
|
|
|
2012-02-26 18:22:59 +01:00
|
|
|
# distutils registers dependencies in .pth (good) but also creates
|
|
|
|
# console_scripts for dependencies in bin/ (bad). easy_install
|
|
|
|
# creates no scripts for dependencies (good) but does not register
|
|
|
|
# them in pth neither (bad) - the combination gives us a pth with
|
|
|
|
# dependencies and scripts only for the package we are currently
|
|
|
|
# installing.
|
2011-03-28 17:30:48 +02:00
|
|
|
, installCommand ?
|
|
|
|
''
|
2012-02-26 18:22:59 +01:00
|
|
|
# install the current package with easy_install.pth including dependencies
|
|
|
|
python setup.py install --prefix="$out"
|
|
|
|
|
2012-02-26 18:23:35 +01:00
|
|
|
# plain distutils knows no dependencies
|
|
|
|
eapth="$out"/lib/${python.libPrefix}/site-packages/easy-install.pth
|
|
|
|
if [ -e "$eapth" ]; then
|
|
|
|
# remove console_scripts again, because they were created for deps, too
|
|
|
|
rm -Rf "$out"/bin
|
|
|
|
|
|
|
|
# run easy_install to generate scripts for the current package,
|
|
|
|
# it won't reinstall
|
|
|
|
easy_install --prefix="$out" .
|
|
|
|
|
|
|
|
# move colliding easy_install.pth to specifically named one
|
|
|
|
mv "$eapth" $(dirname "$eapth")/${name}.pth
|
|
|
|
fi
|
2012-02-26 18:22:59 +01:00
|
|
|
|
|
|
|
# These cause collisions and our output is not a site anyway
|
|
|
|
# If you need a site, install python-site
|
|
|
|
rm -f "$out/lib/${python.libPrefix}/site-packages/"site.py*
|
|
|
|
|
|
|
|
# If setuptools is a dependency, it is included in $(name}.pth
|
|
|
|
rm -f "$out/lib/${python.libPrefix}/site-packages/setuptools.pth"
|
2011-03-28 17:30:48 +02:00
|
|
|
''
|
|
|
|
|
|
|
|
, buildPhase ? "true"
|
2009-05-24 23:02:59 +02:00
|
|
|
|
2011-03-30 14:27:04 +02:00
|
|
|
, doCheck ? true
|
|
|
|
|
2012-02-27 18:34:02 +01:00
|
|
|
# run after fixupPhase
|
2011-03-30 14:27:04 +02:00
|
|
|
, checkPhase ?
|
|
|
|
''
|
|
|
|
runHook preCheck
|
|
|
|
python setup.py test
|
|
|
|
runHook postCheck
|
|
|
|
''
|
2009-06-28 16:05:41 +02:00
|
|
|
|
2011-03-28 17:30:48 +02:00
|
|
|
, postInstall ? ""
|
2009-06-28 16:05:41 +02:00
|
|
|
|
2011-03-28 17:30:48 +02:00
|
|
|
, ... } @ attrs:
|
2009-05-24 23:02:59 +02:00
|
|
|
|
2011-03-28 17:30:48 +02:00
|
|
|
# Keep extra attributes from ATTR, e.g., `patchPhase', etc.
|
|
|
|
python.stdenv.mkDerivation (attrs // {
|
|
|
|
inherit doCheck buildPhase checkPhase;
|
2009-05-24 23:02:59 +02:00
|
|
|
|
2012-02-27 18:34:02 +01:00
|
|
|
# moves checkPhase from after buildPhase to after fixupPhase
|
|
|
|
builder = ./builder.sh;
|
|
|
|
|
2011-03-28 17:30:48 +02:00
|
|
|
name = namePrefix + name;
|
2009-05-24 23:02:59 +02:00
|
|
|
|
2012-02-27 18:33:55 +01:00
|
|
|
buildInputs = [ python wrapPython setuptools unzip ] ++ buildInputs ++ pythonPath;
|
2009-05-24 23:02:59 +02:00
|
|
|
|
2012-02-26 18:23:47 +01:00
|
|
|
preConfigure = ''
|
2012-02-26 18:23:09 +01:00
|
|
|
# do not allow distutils to make downloads, whatever install command is used
|
|
|
|
export PYTHONPATH="${setuptools}/lib/${python.libPrefix}:$PYTHONPATH"
|
|
|
|
export PYTHONPATH="${offlineDistutils}/lib/${python.libPrefix}:$PYTHONPATH"
|
|
|
|
|
|
|
|
# enable pth files for dependencies
|
|
|
|
export PYTHONPATH="${site}/lib/${python.libPrefix}/site-packages:$PYTHONPATH"
|
|
|
|
'';
|
|
|
|
|
2012-02-26 18:23:05 +01:00
|
|
|
# XXX: I think setuptools is not needed here
|
|
|
|
pythonPath = [ setuptools site ] ++ pythonPath;
|
2009-05-24 23:02:59 +02:00
|
|
|
|
2009-05-24 23:14:32 +02:00
|
|
|
# XXX: Should we run `easy_install --always-unzip'? It doesn't seem
|
|
|
|
# to have a noticeable impact on small scripts.
|
2009-05-24 23:02:59 +02:00
|
|
|
installPhase = ''
|
2012-01-18 21:16:00 +01:00
|
|
|
mkdir -p "$out/lib/${python.libPrefix}/site-packages"
|
2009-05-24 23:02:59 +02:00
|
|
|
|
|
|
|
echo "installing \`${name}' with \`easy_install'..."
|
|
|
|
export PYTHONPATH="$out/lib/${python.libPrefix}/site-packages:$PYTHONPATH"
|
2011-03-28 17:30:48 +02:00
|
|
|
${installCommand}
|
2009-08-11 18:25:41 +02:00
|
|
|
|
|
|
|
${postInstall}
|
2009-05-24 23:02:59 +02:00
|
|
|
'';
|
|
|
|
|
2011-03-28 17:30:48 +02:00
|
|
|
postFixup =
|
|
|
|
''
|
2011-03-28 18:33:33 +02:00
|
|
|
wrapPythonPrograms
|
2011-03-28 17:30:48 +02:00
|
|
|
|
|
|
|
# If a user installs a Python package, she probably also wants its
|
|
|
|
# dependencies in the user environment (since Python modules don't
|
|
|
|
# have something like an RPATH, so the only way to find the
|
|
|
|
# dependencies is to have them in the PYTHONPATH variable).
|
2012-02-26 18:22:59 +01:00
|
|
|
#
|
|
|
|
# XXX: this is not needed for things to work (pth pulls in deps)
|
|
|
|
# but would be nice to have anyway - However, python deps end up
|
|
|
|
# in propagated-build-native-inputs
|
2011-03-28 17:30:48 +02:00
|
|
|
if test -e $out/nix-support/propagated-build-inputs; then
|
|
|
|
ln -s $out/nix-support/propagated-build-inputs $out/nix-support/propagated-user-env-packages
|
2009-05-24 23:02:59 +02:00
|
|
|
fi
|
2011-03-28 17:30:48 +02:00
|
|
|
'';
|
|
|
|
})
|