diff options
author | Christoph Junghans <junghans@gentoo.org> | 2018-01-10 23:51:00 -0700 |
---|---|---|
committer | Christoph Junghans <junghans@gentoo.org> | 2018-01-10 23:51:34 -0700 |
commit | 742b311d309929ac2c752a00efa323b231bba650 (patch) | |
tree | b0317b9d6123430d4a57a3b9c175dbc31f29258b /sci-libs | |
parent | dev-qt/qtsql: pass -no-nis to configure (diff) | |
download | gentoo-742b311d309929ac2c752a00efa323b231bba650.tar.gz gentoo-742b311d309929ac2c752a00efa323b231bba650.tar.bz2 gentoo-742b311d309929ac2c752a00efa323b231bba650.zip |
sci-libs/fftw: live ebuild update (bug #643128)
Package-Manager: Portage-2.3.13, Repoman-2.3.3
Diffstat (limited to 'sci-libs')
-rw-r--r-- | sci-libs/fftw/fftw-9999.ebuild | 63 |
1 files changed, 35 insertions, 28 deletions
diff --git a/sci-libs/fftw/fftw-9999.ebuild b/sci-libs/fftw/fftw-9999.ebuild index af34cba86168..bef41e83ea09 100644 --- a/sci-libs/fftw/fftw-9999.ebuild +++ b/sci-libs/fftw/fftw-9999.ebuild @@ -10,11 +10,13 @@ inherit flag-o-matic fortran-2 toolchain-funcs versionator multibuild multilib-m DESCRIPTION="Fast C library for the Discrete Fourier Transform" HOMEPAGE="http://www.fftw.org/" +MY_P=${PN}-${PV/_p/-pl} + if [[ ${PV} = *9999 ]]; then inherit autotools git-r3 EGIT_REPO_URI="https://github.com/FFTW/fftw3.git" else - SRC_URI="http://www.fftw.org/${P}.tar.gz" + SRC_URI="http://www.fftw.org/${PN}-${PV/_p/-pl}.tar.gz" KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86 ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos" fi @@ -23,22 +25,24 @@ SLOT="3.0/3" IUSE="altivec cpu_flags_x86_avx cpu_flags_x86_avx2 cpu_flags_x86_fma3 cpu_flags_x86_fma4 cpu_flags_x86_sse cpu_flags_x86_sse2 doc fortran mpi neon openmp quad static-libs test threads zbus" RDEPEND=" - mpi? ( virtual/mpi )" + mpi? ( >=virtual/mpi-2.0-r4[${MULTILIB_USEDEP}] )" DEPEND="${RDEPEND} test? ( dev-lang/perl )" +if [[ ${PV} = *9999 ]]; then + DEPEND="${DEPEND} + dev-ml/ocamlbuild" +fi -pkg_setup() { - if [[ ${MERGE_TYPE} != binary ]] && use openmp; then - if ! tc-has-openmp; then - ewarn "OpenMP is not available in your current selected compiler" +S=${WORKDIR}/${MY_P} +HTML_DOCS=( doc/html/. ) - if tc-is-clang; then - ewarn "OpenMP support in sys-devel/clang is provided by sys-libs/libomp," - ewarn "which you will need to build ${CATEGORY}/${PN} with USE=\"openmp\"" - fi +pkg_pretend() { + [[ ${MERGE_TYPE} != binary ]] && use openmp && tc-check-openmp +} - die "need openmp capable compiler" - fi +pkg_setup() { + if [[ ${MERGE_TYPE} != binary ]] && use openmp; then + tc-check-openmp FORTRAN_NEED_OPENMP=1 fi @@ -46,7 +50,7 @@ pkg_setup() { MULTIBUILD_VARIANTS=( single double longdouble ) if use quad; then - if tc-is-gcc && ! version_is_at_least 4.6 $(gcc-version); then + if ! tc-is-gcc; then ewarn "quad precision only available for gcc >= 4.6" die "need quad precision capable gcc" fi @@ -64,9 +68,6 @@ src_prepare() { } multilib_src_configure() { - # there is no abi_x86_32 port of virtual/mpi right now, bug 519700 - local enable_mpi=$(multilib_native_use_enable mpi) - # jlec reported USE=quad on abi_x86_32 has too few registers # stub Makefiles if [[ ${MULTILIB_ABI_FLAG} == abi_x86_32 && ${MULTIBUILD_ID} == quad-* ]]; then @@ -79,6 +80,7 @@ multilib_src_configure() { local myconf=( --enable-shared + $([[ ${PV} = *9999 ]] && echo "--enable-maintainer-mode") $(use_enable static-libs static) $(use_enable "cpu_flags_x86_fma$(usex cpu_flags_x86_fma3 3 4)" fma) $(use_enable fortran) @@ -88,7 +90,7 @@ multilib_src_configure() { ) case "${MULTIBUILD_ID}" in single-*) - #altivec, sse, single-paired only work for single + # altivec, sse, single-paired only work for single myconf+=( --enable-single $(use_enable altivec) @@ -97,7 +99,7 @@ multilib_src_configure() { $(use_enable cpu_flags_x86_sse sse) $(use_enable cpu_flags_x86_sse2 sse2) $(use_enable neon) - ${enable_mpi} + $(use_enable mpi) ) ;; @@ -106,19 +108,19 @@ multilib_src_configure() { $(use_enable cpu_flags_x86_avx avx) $(use_enable cpu_flags_x86_avx2 avx2) $(use_enable cpu_flags_x86_sse2 sse2) - ${enable_mpi} + $(use_enable mpi) ) ;; longdouble-*) myconf+=( --enable-long-double - ${enable_mpi} + $(use_enable mpi) ) ;; quad-*) - #quad does not support mpi + # quad does not support mpi myconf+=( --enable-quad-precision ) @@ -129,7 +131,14 @@ multilib_src_configure() { ;; esac - ECONF_SOURCE="${S}" econf "${myconf[@]}" + local MY_S="${S}" + #out-of-source build is broken for 9999 due to maintainer mode + if [[ ${PV} = *9999 ]]; then + cp -al "${S}"/* "${BUILD_DIR}"/ + MY_S="${BUILD_DIR}" + fi + + ECONF_SOURCE="${MY_S}" econf "${myconf[@]}" MPICC="$(tc-getCC -lmpi)" } src_configure() { @@ -155,21 +164,19 @@ src_test() { } src_install() { - DOCS=( AUTHORS ChangeLog NEWS README TODO COPYRIGHT CONVENTIONS ) - HTML_DOCS=( doc/html/ ) - multibuild_foreach_variant multilib-minimal_src_install + dodoc CONVENTIONS if use doc; then dodoc doc/*.pdf docinto faq dodoc -r doc/FAQ/fftw-faq.html/. else - rm -r "${ED}"/usr/share/doc/${PF}/html || die + rm -r "${ED%/}"/usr/share/doc/${PF}/html || die fi local x - for x in "${ED}"/usr/lib*/pkgconfig/*.pc; do + for x in "${ED%/}"/usr/lib*/pkgconfig/*.pc; do local u for u in $(usev mpi) $(usev threads) $(usex openmp omp ""); do sed -e "s|-lfftw3[flq]\?|&_${u} &|" "$x" > "${x%.pc}_${u}.pc" || die @@ -177,5 +184,5 @@ src_install() { done # fftw uses pkg-config to record its private dependencies - find "${ED}" -name '*.la' -delete || die + find "${D}" -name '*.la' -delete || die } |