blob: 168825c65b05c9cc78de404f5f05fb7db5be8db5 (
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
|
# Copyright 1999-2020 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=7
PYTHON_COMPAT=( python3_{6..8} )
if [[ ${PV} == 9999 ]] ; then
inherit git-r3
EGIT_REPO_URI="https://github.com/STEllAR-GROUP/hpx.git"
else
SRC_URI="https://stellar.cct.lsu.edu/files/${PN}_${PV}.tar.gz"
KEYWORDS="~amd64 ~x86 ~amd64-linux ~x86-linux"
fi
inherit cmake fortran-2 python-single-r1 check-reqs multiprocessing
DESCRIPTION="C++ runtime system for parallel and distributed applications"
HOMEPAGE="https://stellar.cct.lsu.edu/tag/hpx/"
SLOT="0"
LICENSE="Boost-1.0"
IUSE="doc examples jemalloc mpi papi +perftools tbb test"
RESTRICT="!test? ( test )"
REQUIRED_USE="
${PYTHON_REQUIRED_USE}
?? ( jemalloc perftools tbb )
"
BDEPEND="
virtual/pkgconfig
doc? (
${PYTHON_DEPS}
app-doc/doxygen
$(python_gen_cond_dep '
dev-python/sphinx[${PYTHON_MULTI_USEDEP}]
dev-python/sphinx_rtd_theme[${PYTHON_MULTI_USEDEP}]
>=dev-python/breathe-4.14[${PYTHON_MULTI_USEDEP}]
')
)
test? ( ${PYTHON_DEPS} )
"
RDEPEND="
${PYTHON_DEPS}
dev-libs/boost:=
sys-apps/hwloc
sys-libs/zlib
mpi? ( virtual/mpi )
papi? ( dev-libs/papi )
perftools? ( dev-util/google-perftools )
tbb? ( dev-cpp/tbb )
"
DEPEND="${RDEPEND}"
hpx_memory_requirement() {
# HPX needs enough main memory for compiling
# rule of thumb: 1G per job
if [[ -z ${MAKEOPTS} ]] ; then
echo "2G"
else
local jobs=$(makeopts_jobs "${MAKEOPTS}" "$(get_nproc)")
echo "${jobs}G"
fi
}
pkg_pretend() {
local CHECKREQS_MEMORY=$(hpx_memory_requirement)
check-reqs_pkg_setup
}
pkg_setup() {
local CHECKREQS_MEMORY=$(hpx_memory_requirement)
check-reqs_pkg_setup
python-single-r1_pkg_setup
}
src_configure() {
local mycmakeargs=(
-DHPX_WITH_EXAMPLES=OFF
-DHPX_WITH_DOCUMENTATION=$(usex doc)
-DHPX_WITH_PARCELPORT_MPI=$(usex mpi)
-DHPX_WITH_PAPI=$(usex papi)
-DHPX_WITH_GOOGLE_PERFTOOLS=$(usex perftools)
-DBUILD_TESTING=$(usex test)
)
if use jemalloc; then
mycmakeargs+=( -DHPX_WITH_MALLOC=jemalloc )
elif use perftools; then
mycmakeargs+=( -DHPX_WITH_MALLOC=tcmalloc )
elif use tbb; then
mycmakeargs+=( -DHPX_WITH_MALLOC=tbbmalloc )
else
mycmakeargs+=( -DHPX_WITH_MALLOC=system )
fi
cmake_src_configure
}
src_compile() {
cmake_src_compile
use test && cmake_build tests
}
src_test() {
# avoid over-suscribing
cmake_src_test -j1
}
src_install() {
cmake_src_install
use examples && dodoc -r examples/
python_fix_shebang "${ED}"
}
|