2009-05-24 21:02:59 +00: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. */
|
|
|
|
|
2011-03-28 16:33:33 +00:00
|
|
|
{ python, setuptools, wrapPython, lib }:
|
2009-05-24 21:02:59 +00:00
|
|
|
|
2011-03-28 15:30:48 +00:00
|
|
|
{ name, namePrefix ? "python-"
|
2009-05-24 21:02:59 +00:00
|
|
|
|
2011-03-28 15:30:48 +00:00
|
|
|
, buildInputs ? []
|
2010-07-28 13:05:04 +00:00
|
|
|
|
2011-03-28 15:30:48 +00: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 21:02:59 +00:00
|
|
|
|
2012-02-26 17:22:59 +00: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 15:30:48 +00:00
|
|
|
, installCommand ?
|
|
|
|
''
|
2012-02-26 17:22:59 +00:00
|
|
|
# install the current package with easy_install.pth including dependencies
|
|
|
|
python setup.py install --prefix="$out"
|
|
|
|
|
|
|
|
# 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
|
2011-03-28 15:30:48 +00:00
|
|
|
easy_install --prefix="$out" .
|
2012-02-26 17:22:59 +00:00
|
|
|
|
|
|
|
# move colliding easy_install.pth to specifically named one
|
|
|
|
mv "$out/lib/${python.libPrefix}/site-packages/"{easy-install.pth,${name}.pth}
|
|
|
|
|
|
|
|
# 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 15:30:48 +00:00
|
|
|
''
|
|
|
|
|
|
|
|
, buildPhase ? "true"
|
2009-05-24 21:02:59 +00:00
|
|
|
|
2011-03-30 12:27:04 +00:00
|
|
|
, doCheck ? true
|
|
|
|
|
|
|
|
, checkPhase ?
|
|
|
|
''
|
|
|
|
runHook preCheck
|
|
|
|
python setup.py test
|
|
|
|
runHook postCheck
|
|
|
|
''
|
2009-06-28 14:05:41 +00:00
|
|
|
|
2011-03-28 15:30:48 +00:00
|
|
|
, postInstall ? ""
|
2009-06-28 14:05:41 +00:00
|
|
|
|
2011-03-28 15:30:48 +00:00
|
|
|
, ... } @ attrs:
|
2009-05-24 21:02:59 +00:00
|
|
|
|
2011-03-28 15:30:48 +00:00
|
|
|
# Keep extra attributes from ATTR, e.g., `patchPhase', etc.
|
|
|
|
python.stdenv.mkDerivation (attrs // {
|
|
|
|
inherit doCheck buildPhase checkPhase;
|
2009-05-24 21:02:59 +00:00
|
|
|
|
2011-03-28 15:30:48 +00:00
|
|
|
name = namePrefix + name;
|
2009-05-24 21:02:59 +00:00
|
|
|
|
2011-03-28 16:33:33 +00:00
|
|
|
buildInputs = [ python wrapPython setuptools ] ++ buildInputs ++ pythonPath;
|
2009-05-24 21:02:59 +00:00
|
|
|
|
2011-03-28 15:30:48 +00:00
|
|
|
pythonPath = [ setuptools] ++ pythonPath;
|
2009-05-24 21:02:59 +00:00
|
|
|
|
2009-05-24 21:14:32 +00:00
|
|
|
# XXX: Should we run `easy_install --always-unzip'? It doesn't seem
|
|
|
|
# to have a noticeable impact on small scripts.
|
2009-05-24 21:02:59 +00:00
|
|
|
installPhase = ''
|
2012-01-18 20:16:00 +00:00
|
|
|
mkdir -p "$out/lib/${python.libPrefix}/site-packages"
|
2009-05-24 21:02:59 +00:00
|
|
|
|
|
|
|
echo "installing \`${name}' with \`easy_install'..."
|
|
|
|
export PYTHONPATH="$out/lib/${python.libPrefix}/site-packages:$PYTHONPATH"
|
2011-03-28 15:30:48 +00:00
|
|
|
${installCommand}
|
2009-08-11 16:25:41 +00:00
|
|
|
|
|
|
|
${postInstall}
|
2009-05-24 21:02:59 +00:00
|
|
|
'';
|
|
|
|
|
2011-03-28 15:30:48 +00:00
|
|
|
postFixup =
|
|
|
|
''
|
2011-03-28 16:33:33 +00:00
|
|
|
wrapPythonPrograms
|
2011-03-28 15:30:48 +00: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 17:22:59 +00: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 15:30:48 +00: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 21:02:59 +00:00
|
|
|
fi
|
2011-03-28 15:30:48 +00:00
|
|
|
'';
|
|
|
|
})
|