2018-09-20 22:31:47 +01:00
|
|
|
{ stdenv, fetchPypi, fetchpatch, python, buildPythonPackage, mpi, openssh }:
|
2014-08-31 19:02:25 +01:00
|
|
|
|
|
|
|
buildPythonPackage rec {
|
2017-05-27 10:25:35 +01:00
|
|
|
pname = "mpi4py";
|
2017-11-15 12:46:49 +00:00
|
|
|
version = "3.0.0";
|
2014-08-31 19:02:25 +01:00
|
|
|
|
2017-09-15 17:11:45 +01:00
|
|
|
src = fetchPypi {
|
|
|
|
inherit pname version;
|
2017-11-15 12:46:49 +00:00
|
|
|
sha256 = "1mzgd26dfv4vwbci8gq77ss9f0x26i9aqzq9b9vs9ndxhlnv0mxl";
|
2014-08-31 19:02:25 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
passthru = {
|
|
|
|
inherit mpi;
|
|
|
|
};
|
|
|
|
|
2018-09-20 22:31:47 +01:00
|
|
|
patches = [ (fetchpatch {
|
|
|
|
# Disable tests failing with 3.1.x and MPI_THREAD_MULTIPLE
|
|
|
|
url = "https://bitbucket.org/mpi4py/mpi4py/commits/c2b6b7e642a182f9b00a2b8e9db363214470548a/raw";
|
|
|
|
sha256 = "0n6bz3kj4vcqb6q7d0mlj5vl6apn7i2bvfc9mpg59vh3wy47119q";
|
|
|
|
})
|
|
|
|
];
|
|
|
|
|
2018-02-11 06:34:36 +00:00
|
|
|
postPatch = ''
|
|
|
|
substituteInPlace test/test_spawn.py --replace \
|
|
|
|
"unittest.skipMPI('openmpi(<3.0.0)')" \
|
|
|
|
"unittest.skipMPI('openmpi')"
|
|
|
|
'';
|
|
|
|
|
2014-08-31 19:02:25 +01:00
|
|
|
configurePhase = "";
|
|
|
|
|
|
|
|
installPhase = ''
|
|
|
|
mkdir -p "$out/lib/${python.libPrefix}/site-packages"
|
|
|
|
export PYTHONPATH="$out/lib/${python.libPrefix}/site-packages:$PYTHONPATH"
|
|
|
|
|
|
|
|
${python}/bin/${python.executable} setup.py install \
|
|
|
|
--install-lib=$out/lib/${python.libPrefix}/site-packages \
|
|
|
|
--prefix="$out"
|
|
|
|
|
|
|
|
# --install-lib:
|
|
|
|
# sometimes packages specify where files should be installed outside the usual
|
|
|
|
# python lib prefix, we override that back so all infrastructure (setup hooks)
|
|
|
|
# work as expected
|
2018-01-27 02:26:22 +00:00
|
|
|
|
|
|
|
# Needed to run the tests reliably. See:
|
|
|
|
# https://bitbucket.org/mpi4py/mpi4py/issues/87/multiple-test-errors-with-openmpi-30
|
|
|
|
export OMPI_MCA_rmaps_base_oversubscribe=yes
|
2014-08-31 19:02:25 +01:00
|
|
|
'';
|
|
|
|
|
|
|
|
setupPyBuildFlags = ["--mpicc=${mpi}/bin/mpicc"];
|
|
|
|
|
2018-01-27 02:26:22 +00:00
|
|
|
buildInputs = [ mpi openssh ];
|
2017-09-15 17:11:45 +01:00
|
|
|
|
2014-08-31 19:02:25 +01:00
|
|
|
meta = {
|
2014-09-03 20:31:00 +01:00
|
|
|
description =
|
2014-09-04 17:47:57 +01:00
|
|
|
"Python bindings for the Message Passing Interface standard";
|
2017-08-01 21:03:30 +01:00
|
|
|
homepage = http://code.google.com/p/mpi4py/;
|
2014-08-31 19:02:25 +01:00
|
|
|
license = stdenv.lib.licenses.bsd3;
|
|
|
|
};
|
|
|
|
}
|