From 677b7ba5c317778df2ad7e70df94b9b7eec4adbc Mon Sep 17 00:00:00 2001 From: V3n3RiX Date: Fri, 10 Sep 2021 04:21:55 +0100 Subject: gentoo resync : 10.09.2021 --- sci-libs/mumps/Manifest | 2 +- sci-libs/mumps/mumps-5.3.5-r1.ebuild | 208 +++++++++++++++++++++++++++++++++++ sci-libs/mumps/mumps-5.3.5.ebuild | 204 ---------------------------------- 3 files changed, 209 insertions(+), 205 deletions(-) create mode 100644 sci-libs/mumps/mumps-5.3.5-r1.ebuild delete mode 100644 sci-libs/mumps/mumps-5.3.5.ebuild (limited to 'sci-libs/mumps') diff --git a/sci-libs/mumps/Manifest b/sci-libs/mumps/Manifest index c55aaaa1b224..28d31afc8af3 100644 --- a/sci-libs/mumps/Manifest +++ b/sci-libs/mumps/Manifest @@ -1,3 +1,3 @@ DIST MUMPS_5.3.5.tar.gz 3940501 BLAKE2B f1767483bb23744a2c5ed11b0823c5b023377d5212abbe29a177cce5b5e51e6f2f391d7caa17022646e36c9e4b4fb4af80b03ac6cf8e89f37502ed960138bbbe SHA512 6e3bb081f38af8540ada7b4fb54c6e766739c854e2a3dd253e3e012eee05dae30064b1b4a8d7493f10691725aba4cc9e80544b0fe5b71670cb0b2726ccfc4439 -EBUILD mumps-5.3.5.ebuild 5709 BLAKE2B 9fdfaad7401159ab5213ed0ea8ce0808d27abebd624b16389796f3a1d64f079744862b0ab16884f58cc87b39da7b95909aa3ff76ff241ccb3f81d33b84fa7fb0 SHA512 09a8bbe8322a2112b591dcc5f7c5fe9dd49b9fc06c71cfed3d84e72d733dbb56b844ae202347d5c389c226b4cbe1a5d66f61323ea36f626cb6e50827c40b740f +EBUILD mumps-5.3.5-r1.ebuild 5882 BLAKE2B 9de181284c5a7e2a4fa35600d12467855ffc94911ab497bf2c5a7fd0eba5e16a2084dbc213554a548a23363bbf411d878984c7dd47cb665c55f833851a821b5d SHA512 ed308d05f42813049013df2327e56b4838e51d1b27b54f7f34a9e334a93d53864723eb63488359fdb8feddc783aa1ddf2277d8306d737e66f378c4b166c7a29f MISC metadata.xml 864 BLAKE2B 78db103b861071cbad317a65db2bb1c7eafc6c3936728cf3854ea05e92210abbf552e01dcbc974dc5238fc1a432ad7ff48fab3d662ea6081ff70fd86263ac11b SHA512 c285d7ed4bd26bb603f40f9d5e4e7262aea8a2679d14f65a4f8959a9bf2c622310422790e6221708fa227cd2c3bb2f4ba140eb5f23acc71b3f1ca20c04c4711a diff --git a/sci-libs/mumps/mumps-5.3.5-r1.ebuild b/sci-libs/mumps/mumps-5.3.5-r1.ebuild new file mode 100644 index 000000000000..8f970661e820 --- /dev/null +++ b/sci-libs/mumps/mumps-5.3.5-r1.ebuild @@ -0,0 +1,208 @@ +# Copyright 1999-2021 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=7 + +inherit fortran-2 flag-o-matic multilib toolchain-funcs + +MYP=MUMPS_${PV} + +DESCRIPTION="MUltifrontal Massively Parallel sparse direct matrix Solver" +HOMEPAGE="http://mumps.enseeiht.fr/" +SRC_URI="http://mumps.enseeiht.fr/${MYP}.tar.gz" +S="${WORKDIR}/${MYP}" + +LICENSE="public-domain" +SLOT="0" +KEYWORDS="~amd64 ~x86 ~amd64-linux ~x86-linux" +IUSE="doc examples metis mpi +scotch static-libs" + +BDEPEND="virtual/pkgconfig" +RDEPEND=" + virtual/blas + metis? ( + >=sci-libs/metis-5 + mpi? ( >=sci-libs/parmetis-4 ) + ) + mpi? ( sci-libs/scalapack ) + !mpi? ( virtual/lapack ) + scotch? ( >=sci-libs/scotch-6.0.1:=[mpi=] ) +" +DEPEND="${RDEPEND}" + +_get_version_component_count() { + local cnt=( $(ver_rs 1- ' ') ) + echo ${#cnt[@]} || die +} + +static_to_shared() { + local libstatic=${1} + shift + local libname=$(basename ${libstatic%.a}) + local soname=${libname}$(get_libname $(ver_cut 1-2)) + local libdir=$(dirname ${libstatic}) + + einfo "Making ${soname} from ${libstatic}" + if [[ ${CHOST} == *-darwin* ]] ; then + ${LINK:-$(tc-getCC)} ${LDFLAGS} \ + -dynamiclib -install_name "${EPREFIX}"/usr/lib/"${soname}" \ + -Wl,-all_load -Wl,${libstatic} \ + "$@" -o ${libdir}/${soname} || die "${soname} failed" + else + ${LINK:-$(tc-getCC)} ${LDFLAGS} \ + -shared -Wl,-soname=${soname} \ + -Wl,--whole-archive ${libstatic} -Wl,--no-whole-archive \ + "$@" -o ${libdir}/${soname} || die "${soname} failed" + + if [[ $(_get_version_component_count) -ge 1 ]] ; then + ln -s ${soname} ${libdir}/${libname}$(get_libname $(ver_cut 1)) || die + fi + + ln -s ${soname} ${libdir}/${libname}$(get_libname) || die + fi +} + +src_prepare() { + # workaround for gcc10 (bug #743442) + append-fflags $(test-flags-FC -fallow-argument-mismatch) + + sed -e "s;^\(CC\s*=\).*;\1$(tc-getCC);" \ + -e "s;^\(FC\s*=\).*;\1$(tc-getFC);" \ + -e "s;^\(FL\s*=\).*;\1$(tc-getFC);" \ + -e "s;^\(AR\s*=\).*;\1$(tc-getAR) cr ;" \ + -e "s;^\(RANLIB\s*=\).*;\1$(tc-getRANLIB);" \ + -e "s;^\(LIBBLAS\s*=\).*;\1$($(tc-getPKG_CONFIG) --libs blas);" \ + -e "s;^\(INCPAR\s*=\).*;\1;" \ + -e 's;^\(LIBPAR\s*=\).*;\1$(SCALAP);' \ + -e "s;^\(OPTF\s*=\).*;\1${FFLAGS} -DALLOW_NON_INIT \$(PIC);" \ + -e "s;^\(OPTC\s*=\).*;\1${CFLAGS} \$(PIC);" \ + -e "s;^\(OPTL\s*=\).*;\1${LDFLAGS};" \ + Make.inc/Makefile.inc.generic > Makefile.inc || die + # fixed a missing copy of libseq to libdir + + default +} + +src_configure() { + # We abuse LIBADD here to work around the fact that MUMPS is criminally + # underlinked. + LIBADD="$($(tc-getPKG_CONFIG) --libs blas) -Llib -lpord" + local ord="-Dpord" + + if use metis && use mpi; then + sed -i \ + -e "s;#\s*\(LMETIS\s*=\).*;\1$($(tc-getPKG_CONFIG) --libs parmetis);" \ + -e "s;#\s*\(IMETIS\s*=\).*;\1$($(tc-getPKG_CONFIG) --cflags parmetis);" \ + Makefile.inc || die + LIBADD="${LIBADD} $($(tc-getPKG_CONFIG) --libs parmetis)" + ord="${ord} -Dparmetis" + elif use metis; then + sed -i \ + -e "s;#\s*\(LMETIS\s*=\).*;\1$($(tc-getPKG_CONFIG) --libs metis);" \ + -e "s;#\s*\(IMETIS\s*=\).*;\1$($(tc-getPKG_CONFIG) --cflags metis);" \ + Makefile.inc || die + LIBADD="${LIBADD} $($(tc-getPKG_CONFIG) --libs metis)" + ord="${ord} -Dmetis" + fi + if use scotch && use mpi; then + sed -i \ + -e "s;#\s*\(LSCOTCH\s*=\).*;\1-lptesmumps -lptscotch -lptscotcherr;" \ + -e "s;#\s*\(ISCOTCH\s*=\).*;\1-I${ESYSROOT}/usr/include/scotch;" \ + Makefile.inc || die + LIBADD="${LIBADD} -lptesmumps -lptscotch -lptscotcherr" + ord="${ord} -Dptscotch" + elif use scotch; then + sed -i \ + -e "s;#\s*\(LSCOTCH\s*=\).*;\1-lesmumps -lscotch -lscotcherr;" \ + -e "s;#\s*\(ISCOTCH\s*=\).*;\1-I${ESYSROOT}/usr/include/scotch;" \ + Makefile.inc || die + LIBADD="${LIBADD} -lesmumps -lscotch -lscotcherr" + ord="${ord} -Dscotch" + fi + if use mpi; then + sed -i \ + -e "s;^\(CC\s*=\).*;\1mpicc;" \ + -e "s;^\(FC\s*=\).*;\1mpif90;" \ + -e "s;^\(FL\s*=\).*;\1mpif90;" \ + -e "s;^\(SCALAP\s*=\).*;\1$($(tc-getPKG_CONFIG) --libs scalapack);" \ + Makefile.inc || die + export LINK=mpif90 + LIBADD="${LIBADD} $($(tc-getPKG_CONFIG) --libs scalapack)" + else + sed -i \ + -e 's;-Llibseq;-L$(topdir)/libseq;' \ + -e 's;PAR);SEQ);g' \ + -e "s;^\(SCALAP\s*=\).*;\1;" \ + -e 's;^LIBSEQNEEDED =;LIBSEQNEEDED = libseqneeded;g' \ + Makefile.inc || die + LIBADD="${LIBADD} $($(tc-getPKG_CONFIG) --libs lapack)" + export LINK="$(tc-getFC)" + fi + sed -i -e "s;^\s*\(ORDERINGSF\s*=\).*;\1 ${ord};" Makefile.inc || die +} + +src_compile() { + # Workaround #462602 + export FAKEROOTKEY=1 + + emake alllib PIC="-fPIC" + if ! use mpi; then + #$(tc-getAR) crs lib/libmumps_common.a libseq/*.o || die + LIBADD+=" -Llibseq -lmpiseq" + static_to_shared libseq/libmpiseq.a + fi + + static_to_shared lib/libpord.a ${LIBADD} + static_to_shared lib/libmumps_common.a ${LIBADD} + + local i + for i in c d s z; do + static_to_shared lib/lib${i}mumps.a -Llib -lmumps_common ${LIBADD} + done + + if use static-libs; then + emake clean + emake alllib + fi +} + +src_test() { + emake all + + local dotest + if use mpi; then + dotest="mpirun -np 2" + else + export LD_LIBRARY_PATH="${S}/libseq:${LD_LIBRARY_PATH}" + fi + + cd examples + ${dotest} ./ssimpletest < input_simpletest_real || die + ${dotest} ./dsimpletest < input_simpletest_real || die + ${dotest} ./csimpletest < input_simpletest_cmplx || die + ${dotest} ./zsimpletest < input_simpletest_cmplx || die + einfo "The solutions should be close to (1,2,3,4,5)" + ${dotest} ./c_example || die + einfo "The solution should be close to (1,2)" + emake clean +} + +src_install() { + dolib.so lib/lib*$(get_libname)* + use static-libs && dolib.a lib/lib*.a + insinto /usr + + doins -r include + if ! use mpi; then + dolib.so libseq/lib*$(get_libname)* + insinto /usr/include/mpiseq + doins libseq/*.h + use static-libs && dolib.a libseq/libmpiseq.a + fi + + dodoc README ChangeLog VERSION + use doc && dodoc doc/*.pdf + if use examples; then + dodoc -r examples + fi +} diff --git a/sci-libs/mumps/mumps-5.3.5.ebuild b/sci-libs/mumps/mumps-5.3.5.ebuild deleted file mode 100644 index 76f2dbe8d4d0..000000000000 --- a/sci-libs/mumps/mumps-5.3.5.ebuild +++ /dev/null @@ -1,204 +0,0 @@ -# Copyright 1999-2021 Gentoo Authors -# Distributed under the terms of the GNU General Public License v2 - -EAPI=7 - -inherit fortran-2 flag-o-matic multilib toolchain-funcs - -MYP=MUMPS_${PV} - -DESCRIPTION="MUltifrontal Massively Parallel sparse direct matrix Solver" -HOMEPAGE="http://mumps.enseeiht.fr/" -SRC_URI="http://mumps.enseeiht.fr/${MYP}.tar.gz" -S="${WORKDIR}/${MYP}" - -LICENSE="public-domain" -SLOT="0" -KEYWORDS="~amd64 ~x86 ~amd64-linux ~x86-linux" -IUSE="doc examples metis mpi +scotch static-libs" - -BDEPEND="virtual/pkgconfig" -RDEPEND=" - virtual/blas - metis? ( - >=sci-libs/metis-5 - mpi? ( >=sci-libs/parmetis-4 ) - ) - mpi? ( sci-libs/scalapack ) - scotch? ( >=sci-libs/scotch-6.0.1:=[mpi=] ) -" -DEPEND="${RDEPEND}" - -_get_version_component_count() { - local cnt=( $(ver_rs 1- ' ') ) - echo ${#cnt[@]} || die -} - -static_to_shared() { - local libstatic=${1} - shift - local libname=$(basename ${libstatic%.a}) - local soname=${libname}$(get_libname $(ver_cut 1-2)) - local libdir=$(dirname ${libstatic}) - - einfo "Making ${soname} from ${libstatic}" - if [[ ${CHOST} == *-darwin* ]] ; then - ${LINK:-$(tc-getCC)} ${LDFLAGS} \ - -dynamiclib -install_name "${EPREFIX}"/usr/lib/"${soname}" \ - -Wl,-all_load -Wl,${libstatic} \ - "$@" -o ${libdir}/${soname} || die "${soname} failed" - else - ${LINK:-$(tc-getCC)} ${LDFLAGS} \ - -shared -Wl,-soname=${soname} \ - -Wl,--whole-archive ${libstatic} -Wl,--no-whole-archive \ - "$@" -o ${libdir}/${soname} || die "${soname} failed" - - if [[ $(_get_version_component_count) -ge 1 ]] ; then - ln -s ${soname} ${libdir}/${libname}$(get_libname $(ver_cut 1)) || die - fi - - ln -s ${soname} ${libdir}/${libname}$(get_libname) || die - fi -} - -src_prepare() { - # workaround for gcc10 (bug #743442) - append-fflags $(test-flags-FC -fallow-argument-mismatch) - - sed -e "s;^\(CC\s*=\).*;\1$(tc-getCC);" \ - -e "s;^\(FC\s*=\).*;\1$(tc-getFC);" \ - -e "s;^\(FL\s*=\).*;\1$(tc-getFC);" \ - -e "s;^\(AR\s*=\).*;\1$(tc-getAR) cr ;" \ - -e "s;^\(RANLIB\s*=\).*;\1$(tc-getRANLIB);" \ - -e "s;^\(LIBBLAS\s*=\).*;\1$($(tc-getPKG_CONFIG) --libs blas);" \ - -e "s;^\(INCPAR\s*=\).*;\1;" \ - -e 's;^\(LIBPAR\s*=\).*;\1$(SCALAP);' \ - -e "s;^\(OPTF\s*=\).*;\1${FFLAGS} -DALLOW_NON_INIT \$(PIC);" \ - -e "s;^\(OPTC\s*=\).*;\1${CFLAGS} \$(PIC);" \ - -e "s;^\(OPTL\s*=\).*;\1${LDFLAGS};" \ - Make.inc/Makefile.inc.generic > Makefile.inc || die - # fixed a missing copy of libseq to libdir - - default -} - -src_configure() { - LIBADD="$($(tc-getPKG_CONFIG) --libs blas) -Llib -lpord" - local ord="-Dpord" - - if use metis && use mpi; then - sed -i \ - -e "s;#\s*\(LMETIS\s*=\).*;\1$($(tc-getPKG_CONFIG) --libs parmetis);" \ - -e "s;#\s*\(IMETIS\s*=\).*;\1$($(tc-getPKG_CONFIG) --cflags parmetis);" \ - Makefile.inc || die - LIBADD="${LIBADD} $($(tc-getPKG_CONFIG) --libs parmetis)" - ord="${ord} -Dparmetis" - elif use metis; then - sed -i \ - -e "s;#\s*\(LMETIS\s*=\).*;\1$($(tc-getPKG_CONFIG) --libs metis);" \ - -e "s;#\s*\(IMETIS\s*=\).*;\1$($(tc-getPKG_CONFIG) --cflags metis);" \ - Makefile.inc || die - LIBADD="${LIBADD} $($(tc-getPKG_CONFIG) --libs metis)" - ord="${ord} -Dmetis" - fi - if use scotch && use mpi; then - sed -i \ - -e "s;#\s*\(LSCOTCH\s*=\).*;\1-lptesmumps -lptscotch -lptscotcherr;" \ - -e "s;#\s*\(ISCOTCH\s*=\).*;\1-I${ESYSROOT}/usr/include/scotch;" \ - Makefile.inc || die - LIBADD="${LIBADD} -lptesmumps -lptscotch -lptscotcherr" - ord="${ord} -Dptscotch" - elif use scotch; then - sed -i \ - -e "s;#\s*\(LSCOTCH\s*=\).*;\1-lesmumps -lscotch -lscotcherr;" \ - -e "s;#\s*\(ISCOTCH\s*=\).*;\1-I${ESYSROOT}/usr/include/scotch;" \ - Makefile.inc || die - LIBADD="${LIBADD} -lesmumps -lscotch -lscotcherr" - ord="${ord} -Dscotch" - fi - if use mpi; then - sed -i \ - -e "s;^\(CC\s*=\).*;\1mpicc;" \ - -e "s;^\(FC\s*=\).*;\1mpif90;" \ - -e "s;^\(FL\s*=\).*;\1mpif90;" \ - -e "s;^\(SCALAP\s*=\).*;\1$($(tc-getPKG_CONFIG) --libs scalapack);" \ - Makefile.inc || die - export LINK=mpif90 - LIBADD="${LIBADD} $($(tc-getPKG_CONFIG) --libs scalapack)" - else - sed -i \ - -e 's;-Llibseq;-L$(topdir)/libseq;' \ - -e 's;PAR);SEQ);g' \ - -e "s;^\(SCALAP\s*=\).*;\1;" \ - -e 's;^LIBSEQNEEDED =;LIBSEQNEEDED = libseqneeded;g' \ - Makefile.inc || die - export LINK="$(tc-getFC)" - fi - sed -i -e "s;^\s*\(ORDERINGSF\s*=\).*;\1 ${ord};" Makefile.inc || die -} - -src_compile() { - # Workaround #462602 - export FAKEROOTKEY=1 - - emake alllib PIC="-fPIC" - if ! use mpi; then - #$(tc-getAR) crs lib/libmumps_common.a libseq/*.o || die - LIBADD+=" -Llibseq -lmpiseq" - static_to_shared libseq/libmpiseq.a - fi - - static_to_shared lib/libpord.a ${LIBADD} - static_to_shared lib/libmumps_common.a ${LIBADD} - - local i - for i in c d s z; do - static_to_shared lib/lib${i}mumps.a -Llib -lmumps_common ${LIBADD} - done - - if use static-libs; then - emake clean - emake alllib - fi -} - -src_test() { - emake all - - local dotest - if use mpi; then - dotest="mpirun -np 2" - else - export LD_LIBRARY_PATH="${S}/libseq:${LD_LIBRARY_PATH}" - fi - - cd examples - ${dotest} ./ssimpletest < input_simpletest_real || die - ${dotest} ./dsimpletest < input_simpletest_real || die - ${dotest} ./csimpletest < input_simpletest_cmplx || die - ${dotest} ./zsimpletest < input_simpletest_cmplx || die - einfo "The solutions should be close to (1,2,3,4,5)" - ${dotest} ./c_example || die - einfo "The solution should be close to (1,2)" - emake clean -} - -src_install() { - dolib.so lib/lib*$(get_libname)* - use static-libs && dolib.a lib/lib*.a - insinto /usr - - doins -r include - if ! use mpi; then - dolib.so libseq/lib*$(get_libname)* - insinto /usr/include/mpiseq - doins libseq/*.h - use static-libs && dolib.a libseq/libmpiseq.a - fi - - dodoc README ChangeLog VERSION - use doc && dodoc doc/*.pdf - if use examples; then - dodoc -r examples - fi -} -- cgit v1.2.3