summaryrefslogtreecommitdiff
path: root/net/py-mpi4py/Makefile
blob: fc95ce3058cc8e9d2d522c57c8130e3d6e6152c4 (plain) (blame)
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
PORTNAME=	mpi4py
DISTVERSION=	4.1.0
CATEGORIES=	net parallel python
MASTER_SITES=	PYPI
PKGNAMEPREFIX=	${PYTHON_PKGNAMEPREFIX}

MAINTAINER=	laurent.chardon@gmail.com
COMMENT?=	Python bindings for MPI (OpenMPI)
WWW=		https://github.com/mpi4py/mpi4py

LICENSE=	BSD3CLAUSE
LICENSE_FILE=	${WRKSRC}/LICENSE.rst

USES=		pkgconfig python
USE_PYTHON=	autoplist concurrent cython3 distutils

LDFLAGS+=	${MPI_LIBS}

MP?=			OPENMPI
.if ${MP} == "OPENMPI"
USES+=			mpi:openmpi
CONFLICTS_INSTALL=	${PYTHON_PKGNAMEPREFIX}mpi4py-mpich-4*
MPIOPTIONS=		--oversubscribe --stream-buffering 0
.elif ${MP} == "MPICH"
USES+=			fortran mpi:mpich
LDFLAGS+=		${LOCALBASE}/lib/gcc${GCC_DEFAULT}/libgcc_s.so
CONFLICTS_INSTALL=	${PYTHON_PKGNAMEPREFIX}mpi4py-4*
MPIOPTIONS=
.else
BROKEN=			invalid parameter MP
.endif

PORTDOCS=	*

#SLAVEDIRS=	net/py-mpi4py-mpich

OPTIONS_DEFINE=	DOCS

pre-configure:
	${CP} ${FILESDIR}/mpi.cfg ${WRKSRC}/
	${REINPLACE_CMD} -e 's|%%LOCALBASE%%/mpi/openmpi|${MPI_HOME}|'	\
		${WRKSRC}/mpi.cfg

do-install-DOCS-on:
	${MKDIR} ${STAGEDIR}${DOCSDIR}
	${INSTALL_DATA} ${WRKSRC}/README.rst ${STAGEDIR}${DOCSDIR}
	(cd ${WRKSRC}/docs && ${COPYTREE_SHARE} . ${STAGEDIR}${DOCSDIR})

post-install:
	(cd ${STAGEDIR}${PYTHON_SITELIBDIR}/mpi4py && ${STRIP_CMD} *.so)

do-test:
	(cd ${WRKSRC} && ${MPIEXEC} ${MPIOPTIONS} -n 5 ${PYTHON_CMD} test/main.py)

.include <bsd.port.mk>