3
0
Fork 0
forked from mirrors/nixpkgs
nixpkgs/pkgs/development/python-modules/h5py/default.nix

53 lines
1.6 KiB
Nix
Raw Normal View History

{ stdenv, fetchPypi, isPy27, python, buildPythonPackage
, numpy, hdf5, cython, six, pkgconfig, unittest2, fetchpatch
, mpi4py ? null, openssh }:
2014-08-31 19:02:38 +01:00
assert hdf5.mpiSupport -> mpi4py != null && hdf5.mpi == mpi4py.mpi;
2014-08-31 19:02:38 +01:00
with stdenv.lib;
let
mpi = hdf5.mpi;
mpiSupport = hdf5.mpiSupport;
in buildPythonPackage rec {
2019-01-10 14:02:06 +00:00
version = "2.9.0";
pname = "h5py";
2014-08-31 19:02:38 +01:00
2018-02-18 18:53:00 +00:00
src = fetchPypi {
inherit pname version;
2019-01-10 14:02:06 +00:00
sha256 = "9d41ca62daf36d6b6515ab8765e4c8c4388ee18e2a665701fef2b41563821002";
2014-08-31 19:02:38 +01:00
};
patches = [ ( fetchpatch {
# Skip a test that probes an already fixed bug in HDF5 (upstream patch)
url = "https://github.com/h5py/h5py/commit/141eafa531c6c09a06efe6a694251a1eea84908d.patch";
sha256 = "0lmdn0gznr7gadx7qkxybl945fvwk6r0cc4lg3ylpf8ril1975h8";
})];
configure_flags = "--hdf5=${hdf5}" + optionalString mpiSupport " --mpi";
postConfigure = ''
${python.executable} setup.py configure ${configure_flags}
# Needed to run the tests reliably. See:
# https://bitbucket.org/mpi4py/mpi4py/issues/87/multiple-test-errors-with-openmpi-30
${optionalString mpiSupport "export OMPI_MCA_rmaps_base_oversubscribe=yes"}
'';
2014-08-31 19:02:38 +01:00
preBuild = if mpiSupport then "export CC=${mpi}/bin/mpicc" else "";
checkInputs = optional isPy27 unittest2 ++ [ openssh ];
nativeBuildInputs = [ pkgconfig ];
buildInputs = [ hdf5 cython ]
2018-02-18 18:53:00 +00:00
++ optional mpiSupport mpi;
propagatedBuildInputs = [ numpy six]
2018-02-18 18:53:00 +00:00
++ optionals mpiSupport [ mpi4py openssh ];
2014-08-31 19:02:38 +01:00
meta = {
description =
2014-09-04 17:48:08 +01:00
"Pythonic interface to the HDF5 binary data format";
homepage = http://www.h5py.org/;
2014-08-31 19:02:38 +01:00
license = stdenv.lib.licenses.bsd2;
};
}