git: 9753aee9f0e2 - main - math/parmetis: resurrect
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Sun, 20 Apr 2025 13:05:17 UTC
The branch main has been updated by thierry: URL: https://cgit.FreeBSD.org/ports/commit/?id=9753aee9f0e2d37bd88b64166222de571fb6d8ae commit 9753aee9f0e2d37bd88b64166222de571fb6d8ae Author: Thierry Thomas <thierry@FreeBSD.org> AuthorDate: 2025-04-20 12:49:04 +0000 Commit: Thierry Thomas <thierry@FreeBSD.org> CommitDate: 2025-04-20 13:03:36 +0000 math/parmetis: resurrect --- MOVED | 1 - math/Makefile | 1 + math/parmetis/Makefile | 83 ++++++++++++++++++++++++++++++++ math/parmetis/distinfo | 3 ++ math/parmetis/files/patch-CMakeLists.txt | 13 +++++ math/parmetis/pkg-descr | 9 ++++ math/parmetis/pkg-plist | 9 ++++ 7 files changed, 118 insertions(+), 1 deletion(-) diff --git a/MOVED b/MOVED index f7e73bd09a01..005bf27775c3 100644 --- a/MOVED +++ b/MOVED @@ -4184,7 +4184,6 @@ java/cos||2025-03-01|Has expired: Upstream seems gone since 2024-08-22 sysutils/pass-secrets||2025-03-01|Has expired: Listed as BROKEN and unmaintained for months sysutils/fluxengine||2025-03-01|Has expired: Broken for several months textproc/py-pyjade||2025-03-01|Has expired: Upstream is inactive for almost 8.5 years -math/parmetis||2025-03-01|Has expired: Fails to fetch, unmaintained for years in tree math/pspp||2025-03-01|Has expired: Listed as broken for more than 5 months games/shaaft||2025-03-02|Has expired: Unmaintained upstream for ages, breaks with modern toolchains devel/asmutils||2025-03-02|Has expired: latest upstream release is 19 years ago, replaced by a-Linux, does not build with GCC 14 diff --git a/math/Makefile b/math/Makefile index 353fb30883f1..0f652ce2441b 100644 --- a/math/Makefile +++ b/math/Makefile @@ -872,6 +872,7 @@ SUBDIR += pari_nftables SUBDIR += pari_seadata SUBDIR += paritwine + SUBDIR += parmetis SUBDIR += parmgridgen SUBDIR += pcalc SUBDIR += pdal diff --git a/math/parmetis/Makefile b/math/parmetis/Makefile new file mode 100644 index 000000000000..387717439c10 --- /dev/null +++ b/math/parmetis/Makefile @@ -0,0 +1,83 @@ +PORTNAME= ParMetis +PORTVERSION= 4.0.3 +PORTREVISION= 8 +CATEGORIES= math parallel +MASTER_SITES= http://glaros.dtc.umn.edu/gkhome/fetch/sw/parmetis/ +DISTNAME= ${PORTNAME:tl}-${PORTVERSION} + +MAINTAINER= ports@FreeBSD.org +COMMENT= Package for parallel (MPI) unstructured graph partitioning +WWW= http://glaros.dtc.umn.edu/gkhome/metis/parmetis/overview + +LICENSE= METIS +LICENSE_NAME= University of Minnesota METIS License +LICENSE_FILE= ${WRKSRC}/LICENSE.txt +LICENSE_PERMS= auto-accept + +BROKEN= Unfetchable +DEPRECATED= Fails to fetch, unmaintained for years in tree +EXPIRATION_DATE=2025-02-28 + +USES= cmake:insource,noninja gmake +USE_LDCONFIG= ${PREFIX}/lib/parmetis + +OPTIONS_DEFINE= OPENMPI DOCS STATIC +OPENMPI_DESC= Use openmpi instead of mpich +OPTIONS_SUB= yes + +OPENMPI_USES= mpi:openmpi +OPENMPI_USES_OFF= mpi + +STATIC_DESC= Do not build and install shared library +STATIC_VARS_OFF= SH_FLAG="shared=1" + +CFLAGS+= -fPIC + +.include <bsd.port.options.mk> + +pre-configure: + @${REINPLACE_CMD} -e \ + 's|BUILDDIR =.*|BUILDDIR = build| ; \ + s|make -C|$$(MAKE) -C| ; \ + s|$$(MAKEFLAGS)||' ${WRKSRC}/Makefile + @${REINPLACE_CMD} -e \ + 's|"-O3"|""|' ${WRKSRC}/metis/GKlib/GKlibSystem.cmake +.if ((${ARCH}=="amd64") || (${ARCH}=="aarch64") || (${ARCH}=="ppc64")) + @${REINPLACE_CMD} -e \ + 's|IDXTYPEWIDTH 32|IDXTYPEWIDTH 64|' \ + ${WRKSRC}/metis/include/metis.h +.endif + @${REINPLACE_CMD} -e \ + '/target_link_libraries(.* parmetis)/s/\(parmetis\)/& -lexecinfo/' \ + ${WRKSRC}/programs/CMakeLists.txt + +do-configure: + @cd ${WRKSRC} && ${SETENV} ${MAKE_ENV} ${MAKE_CMD} ${MAKE_FLAGS} \ + ${MAKEFILE} config prefix="${PREFIX}" cc="${MPICC}" cxx="${MPICXX}" ${SH_FLAG} + +do-install: + @${MKDIR} ${STAGEDIR}${PREFIX}/include/parmetis \ + ${STAGEDIR}${PREFIX}/lib/parmetis \ + ${STAGEDIR}${DOCSDIR} + ${INSTALL_DATA} ${WRKSRC}/include/parmetis.h \ + ${WRKSRC}/metis/include/metis.h \ + ${STAGEDIR}${PREFIX}/include/parmetis +.if ${PORT_OPTIONS:MSTATIC} + ${INSTALL_DATA} ${WRKSRC}/build/libmetis/libmetis.a \ + ${STAGEDIR}${PREFIX}/lib/parmetis + ${INSTALL_DATA} ${WRKSRC}/build/libparmetis/libparmetis.a \ + ${STAGEDIR}${PREFIX}/lib/parmetis +.else + ${INSTALL_DATA} ${WRKSRC}/build/libmetis/libmetis.so \ + ${STAGEDIR}${PREFIX}/lib/parmetis/libmetis.so.2 + ${INSTALL_LIB} ${WRKSRC}/build/libparmetis/libparmetis.so \ + ${STAGEDIR}${PREFIX}/lib/parmetis/libparmetis.so.2 + cd ${STAGEDIR}${PREFIX}/lib/parmetis && \ + ${LN} -sf libmetis.so.2 ${STAGEDIR}${PREFIX}/lib/parmetis/libmetis.so && \ + ${LN} -sf libparmetis.so.2 ${STAGEDIR}${PREFIX}/lib/parmetis/libparmetis.so + ${STRIP_CMD} ${STAGEDIR}${PREFIX}/lib/parmetis/libmetis.so.2 +.endif + ${MKDIR} ${STAGEDIR}${DOCSDIR} + ${INSTALL_DATA} ${WRKSRC}/manual/manual.pdf ${STAGEDIR}${DOCSDIR} + +.include <bsd.port.mk> diff --git a/math/parmetis/distinfo b/math/parmetis/distinfo new file mode 100644 index 000000000000..af89bf13cf63 --- /dev/null +++ b/math/parmetis/distinfo @@ -0,0 +1,3 @@ +TIMESTAMP = 1496443330 +SHA256 (parmetis-4.0.3.tar.gz) = f2d9a231b7cf97f1fee6e8c9663113ebf6c240d407d3c118c55b3633d6be6e5f +SIZE (parmetis-4.0.3.tar.gz) = 5567670 diff --git a/math/parmetis/files/patch-CMakeLists.txt b/math/parmetis/files/patch-CMakeLists.txt new file mode 100644 index 000000000000..fbdbe348b487 --- /dev/null +++ b/math/parmetis/files/patch-CMakeLists.txt @@ -0,0 +1,13 @@ +--- CMakeLists.txt.orig 2013-03-30 16:24:50 UTC ++++ CMakeLists.txt +@@ -19,8 +19,10 @@ execute_process(COMMAND ${CMAKE_COMMAND} + # Prepare libraries. + if(SHARED) + set(ParMETIS_LIBRARY_TYPE SHARED) ++ set(METIS_LIBRARY_TYPE SHARED) + else() + set(ParMETIS_LIBRARY_TYPE STATIC) ++ set(METIS_LIBRARY_TYPE STATIC) + endif() + + include(${GKLIB_PATH}/GKlibSystem.cmake) diff --git a/math/parmetis/pkg-descr b/math/parmetis/pkg-descr new file mode 100644 index 000000000000..8c4ec46332f7 --- /dev/null +++ b/math/parmetis/pkg-descr @@ -0,0 +1,9 @@ +ParMETIS is an MPI-based parallel library that implements a variety +of algorithms for partitioning unstructured graphs and for computing +fill-reducing orderings of sparse matrices. ParMETIS extends the +functionality provided by METIS and includes routines that are +especially suited for parallel AMR computations and large scale +numerical simulations. The algorithms implemented in ParMETIS are +based on the parallel multilevel k-way graph-partitioning algorithms +described in [KK95d], [KK96], [KK97], and the adaptive repartitioning +algorithms described in [SKK97a], [SKK97b], [SK+98], and [SKK98]. diff --git a/math/parmetis/pkg-plist b/math/parmetis/pkg-plist new file mode 100644 index 000000000000..a7b45f0eadc1 --- /dev/null +++ b/math/parmetis/pkg-plist @@ -0,0 +1,9 @@ +include/parmetis/metis.h +include/parmetis/parmetis.h +%%STATIC%%lib/parmetis/libmetis.a +%%NO_STATIC%%lib/parmetis/libmetis.so +%%NO_STATIC%%lib/parmetis/libmetis.so.2 +%%STATIC%%lib/parmetis/libparmetis.a +%%NO_STATIC%%lib/parmetis/libparmetis.so +%%NO_STATIC%%lib/parmetis/libparmetis.so.2 +%%DOCSDIR%%/manual.pdf