diff options
Diffstat (limited to 'PKGBUILD')
-rw-r--r-- | PKGBUILD | 76 |
1 files changed, 56 insertions, 20 deletions
@@ -1,26 +1,62 @@ -# Maintainer: Will Handley <wh260@cam.ac.uk> (aur.archlinux.org/account/wjhandley) -_modulename=mpi4py-intel -pkgname=python-$_modulename -pkgver=3.0.1 +# Maintainer: Carlos Aznarán <caznaranl@uni.pe> +# Contributor: Will Handley <wh260@cam.ac.uk> (aur.archlinux.org/account/wjhandley) +# Based on python-mpi4py, maintained by Bruno Pagani <archange@archlinux.org> and et.al. +_base=mpi4py +pkgname=python-${_base}-intel +pkgver=3.1.6 pkgrel=1 pkgdesc="Python bindings for the Message Passing Interface compiled with intel mpi" -arch=(any) -url="https://github.com/mpi4py/mpi4py" -license=('custom') -groups=() -depends=('intel-mpi') -makedepends=('python-setuptools') -provides=('python-mpi4py') -conflicts=('python-mpi4py') -replaces=() -backup=() +arch=(x86_64) +url="https://github.com/${_base}/${_base}" +license=(BSD-2-Clause) +depends=(python intel-oneapi-basekit) # intel-oneapi-dpcpp-cpp +makedepends=(python-build python-installer python-setuptools python-wheel cython0) +checkdepends=(python-pytest python-numba) # python-cupy +provides=(python-${_base}) +conflicts=(python-${_base}) options=(!emptydirs) -install= -source=("${url}/archive/${pkgver}.tar.gz") -sha256sums=('770e8f0414addc88b36dd291fc28aaf2a2160d393f6f4b71a42511c51cbd63e7') +source=(${_base}-${pkgver}.tar.gz::${url}/archive/${pkgver}.tar.gz) +sha512sums=('e99fa0aab13d8e3d2479880a4c920c621512925c6fa2706e7b46b8c3380ca061c1583be70dc5b94f40bf32c0ac7f4cfb508917429226227c52348548ebe0a0d9') + +build() { + cd ${_base}-${pkgver} + source /opt/intel/oneapi/setvars.sh + # /opt/intel/oneapi/compiler/2023.2.0/env/vars.sh + # /opt/intel/oneapi/mpi/2021.10.0/env/vars.sh + # https://community.intel.com/t5/Intel-oneAPI-HPC-Toolkit/MPI-linking-with-LLVM-based-compilers/m-p/1498230 + # CC=icx I_MPI_CC=icx MPICC="mpiicc -cc=icx" LDFLAGS="-shared-intel" + python -m build --wheel --skip-dependency-check --no-isolation +} + +check() { + # This is required starting with OpenMPI 3.0 when trying to run more + # processes than the number of available cores + export OMPI_MCA_rmaps_base_oversubscribe=yes + + cd ${_base}-${pkgver} + python -m venv --system-site-packages test-env + test-env/bin/python -m installer dist/*.whl + test-env/bin/python -m pytest -vv \ + --ignore=test/test_cco_buf.py \ + --ignore=test/test_cco_nb_buf.py \ + --ignore=test/test_cco_nb_vec.py \ + --ignore=test/test_cco_ngh_buf.py \ + --ignore=test/test_cco_obj_inter.py \ + --ignore=test/test_cco_vec.py \ + --ignore=test/test_comm_inter.py \ + --ignore=test/test_comm_inter.py \ + --ignore=test/test_dynproc.py \ + --ignore=test/test_io.py \ + --ignore=test/test_msgspec.py \ + --ignore=test/test_pack.py \ + --ignore=test/test_p2p_buf.py \ + --ignore=test/test_p2p_buf_matched.py \ + --ignore=test/test_rma.py \ + --ignore=test/test_rma_nb.py +} package() { - cd "$srcdir/mpi4py-$pkgver" - export MPICC=mpiicc - python setup.py install --root="$pkgdir/" --optimize=1 + cd ${_base}-${pkgver} + PYTHONPYCACHEPREFIX="${PWD}/.cache/cpython/" python -m installer --destdir="${pkgdir}" dist/*.whl + install -Dm 644 LICENSE.rst -t "${pkgdir}/usr/share/licenses/${pkgname}" } |