blob: 2082140a9e1688d8d04b0e403f66cc928c1d8d39 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
# Copyright 1999-2024 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=8
PYTHON_COMPAT=( python3_{10..13} )
DISTUTILS_EXT=1
DISTUTILS_USE_PEP517=meson-python
inherit distutils-r1 pypi
DESCRIPTION="Message Passing Interface for Python"
HOMEPAGE="
https://github.com/mpi4py/mpi4py
https://pypi.org/project/mpi4py/
"
LICENSE="BSD"
SLOT="0"
KEYWORDS="~amd64 ~arm ~arm64 ~riscv ~x86 ~amd64-linux ~x86-linux"
IUSE="doc examples"
RDEPEND="
dev-python/numpy[${PYTHON_USEDEP}]
virtual/mpi
"
DEPEND="${RDEPEND}"
BDEPEND="
dev-python/cython[${PYTHON_USEDEP}]
>=dev-build/meson-1.0.0
virtual/mpi
"
PATCHES=(
"${FILESDIR}/${PN}-4-use-mesonpy.patch"
"${FILESDIR}/${PN}-4-mpich-no-fortran-fix.patch"
)
python_prepare_all() {
# not needed on install
rm -vr docs/source || die
rm test/test_pickle.py || die # disabled by Gentoo-bug #659348
distutils-r1_python_prepare_all
}
python_compile() {
export CC=mpicc
distutils-r1_python_compile
}
python_test() {
echo "Beginning test phase"
local -x PYTHONPATH="${BUILD_DIR}/install$(python_get_sitedir)"
# python want's all arguments as separate strings
local mpi_opts=(
"-n" "1"
)
if has_version sys-cluster/openmpi; then
local mpi_opts+=(
"--use-hwthread-cpus"
# allow test in systemd-nspawn container
"--mca" "btl" "tcp,self"
"--mca" "oob_tcp_if_include" "lo"
# disable openmpi OSC UCX component
# https://github.com/open-mpi/ompi/issues/12517
"--mca" "osc" "^ucx"
)
fi
mpiexec \
"${mpi_opts[@]}" \
"${PYTHON}" -B -v ./test/runtests.py -v ||
die "Testsuite failed under ${EPYTHON}"
}
python_install_all() {
use doc && local HTML_DOCS=( docs/. )
use examples && local DOCS=( demo )
distutils-r1_python_install_all
}
|