commit:     4db94422e4714ed4301aebe7a29ba0ccd24f8ccf
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Mon Mar 31 16:57:05 2025 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue Apr  1 13:58:01 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4db94422

dev-java/asm: add 9.8

Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>

 dev-java/asm/Manifest       |  1 +
 dev-java/asm/asm-9.8.ebuild | 97 +++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 98 insertions(+)

diff --git a/dev-java/asm/Manifest b/dev-java/asm/Manifest
index dcec05010889..749f510e495f 100644
--- a/dev-java/asm/Manifest
+++ b/dev-java/asm/Manifest
@@ -1,2 +1,3 @@
 DIST asm-ASM_9_7_1.tar.bz2 1378103 BLAKE2B 
f7da3a9c1bcf76398c9e9b9b86d60f8854e5248632a8b2d76605851e29ee1807713fb28c9e76012ec8f9444c44e3a151ed409cd120c34ab8d3495fdc9c84edcb
 SHA512 
77ae76464eec97dbc8129c4a746d13f0d286d2033f909b65e0e34858e1785616b7bee22faa92128b91eb39cbd849e262efe574b73ed2859920add457d6422dd0
+DIST asm-ASM_9_8.tar.bz2 1378904 BLAKE2B 
8ace6a729e28569d21b3b2104d6256836ce552f9e571f62fbf994675ca5dcda846abbaa80ec5cede0ab06e519abfaa6745679733f6780be4d16f3e266651e850
 SHA512 
61142b14a3e1b9873a71057ef649dce3f40cf7553cf536213bee373ddc3320d4e183290adec5274f31562262845dab4505b16f64ba1be3c9893b6a11d1169370
 DIST asm-cc341b5f0c24ea6688f615faff597612f0d596fb.tar.bz2 1380914 BLAKE2B 
f60f866ea14d63ae763212aebed715294eef3019f9878ebbbc80a63283e5176a446a90419c09e8a9210359e481a7aabb1977716d6467b77af0d3166c669c3676
 SHA512 
ce9adbf3e9c4d7f947e7ca63f51983c6d9bb4d4af73934c6779802caa242bc4d7f552069a8b835c16d8d32027fb4e634236adfd10f27a5563ed80fdc81b1a53d

diff --git a/dev-java/asm/asm-9.8.ebuild b/dev-java/asm/asm-9.8.ebuild
new file mode 100644
index 000000000000..28ed404f256f
--- /dev/null
+++ b/dev-java/asm/asm-9.8.ebuild
@@ -0,0 +1,97 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+# tests not enabled because of missing eclass support of junit-jupiter
+JAVA_PKG_IUSE="doc source"
+MAVEN_PROVIDES="
+       org.ow2.asm:asm-bom:${PV}
+       org.ow2.asm:asm:${PV}
+       org.ow2.asm:asm-analysis:${PV}
+       org.ow2.asm:asm-commons:${PV}
+       org.ow2.asm:asm-tree:${PV}
+       org.ow2.asm:asm-util:${PV}
+"
+
+inherit java-pkg-2 java-pkg-simple
+
+DESCRIPTION="Bytecode manipulation framework for Java"
+HOMEPAGE="https://asm.ow2.io";
+MY_P="ASM_${PV//./_}"
+SRC_URI="https://gitlab.ow2.org/asm/asm/-/archive/${MY_P}/asm-${MY_P}.tar.bz2";
+S="${WORKDIR}/asm-${MY_P}"
+
+LICENSE="BSD"
+SLOT="0"
+KEYWORDS="~amd64 ~arm64 ~ppc64 ~x64-macos"
+
+DEPEND=">=virtual/jdk-11:*"
+RDEPEND=">=virtual/jre-1.8:*"
+
+ASM_MODULES=( "asm" "asm-tree" "asm-analysis" "asm-commons" "asm-util" )
+JAVADOC_SRC_DIRS=(
+       asm/src/main/java
+       asm-tree/src/main/java
+       asm-analysis/src/main/java
+       asm-commons/src/main/java
+       asm-util/src/main/java
+)
+
+src_prepare() {
+       default
+       local module
+       touch asm.module || die
+       for module in "${ASM_MODULES[@]}"; do
+               module=${module/-/.}
+               cat > ${module/./-}/src/main/java/module-info.java <<-EOF || die
+                       open module 
org.objectweb.${module/analysis/tree.analysis} {
+                               $(cat asm.module)
+                               requires java.base;
+                               exports 
org.objectweb.${module/analysis/tree.analysis};
+                       }
+               EOF
+               echo "requires transitive 
org.objectweb.${module/analysis/tree.analysis};" \
+                       >> asm.module || die
+       done
+       sed -e '/^$/d' \
+               -e '/asm;/p;s:\(asm\)\(;\):\1.signature\2:' \
+               -i  asm/src/main/java/module-info.java || die
+       sed -e '/analysis/d' \
+               -i  asm-commons/src/main/java/module-info.java || die
+       sed -e '/commons/d' \
+               -i  asm-util/src/main/java/module-info.java || die
+}
+
+src_compile() {
+       local module
+       for module in "${ASM_MODULES[@]}"; do
+               einfo "Compiling ${module}"
+               JAVA_JAR_FILENAME="${module}.jar"
+               JAVA_SRC_DIR="${module}/src/main/java"
+               java-pkg-simple_src_compile
+               JAVA_GENTOO_CLASSPATH_EXTRA+=":${module}.jar"
+               rm -r target || die
+       done
+
+       if use doc; then
+               einfo "Compiling javadocs"
+               for module in "${ASM_MODULES[@]}"; do
+                       rm "${module}/src/main/java/module-info.java" || die
+                       JAVA_SRC_DIR+=("${module}/src/main/java")
+               done
+               ejavadoc
+       fi
+}
+
+src_install() {
+       JAVA_JAR_FILENAME="asm.jar"
+       java-pkg-simple_src_install
+       local module
+       for module in asm-{analysis,commons,tree,util}; do
+               java-pkg_dojar ${module}.jar
+               if use source; then
+                       java-pkg_dosrc "${module}/src/main/java/*"
+               fi
+       done
+}

Reply via email to