commit:     02848e7dcd672f653df141391632e53b1947033d
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Dec  5 13:08:30 2023 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Dec  5 14:32:37 2023 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=02848e7d

sci-mathematics/z3: Bump to 4.12.3

Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>

 sci-mathematics/z3/Manifest         |   1 +
 sci-mathematics/z3/z3-4.12.3.ebuild | 111 ++++++++++++++++++++++++++++++++++++
 2 files changed, 112 insertions(+)

diff --git a/sci-mathematics/z3/Manifest b/sci-mathematics/z3/Manifest
index 05c33c5e88c0..2195887b9d44 100644
--- a/sci-mathematics/z3/Manifest
+++ b/sci-mathematics/z3/Manifest
@@ -1 +1,2 @@
 DIST z3-4.12.2.tar.gz 5401038 BLAKE2B 
e83bc4067360888da1be20dffbbd4b060118080e1f8a1b0424c169ad1aaaccf5ab645960418db7ce544829c7831da90edb0e38003d7a0261df699c9bd69ab1f0
 SHA512 
375477cbbc9837b44e752c89916409d07bf6a73830b52878aab4f376f08b37dd5ab485da225744d394ab15f2a7e1014edc3be5eb9962934c440a8d55259317e2
+DIST z3-4.12.3.tar.gz 5471745 BLAKE2B 
ce14a13a0af651b414cd164658b5953d5ea398201fc299e5073690caa9625b23ffbdce33a2f220f1420570b1b21ace6be48486c2c333251325b7acb5ca6e0d43
 SHA512 
06d667b86e2d941e8cbcafe508392f5ef9307354a97428107e26ac7ef86246a86a0096fbf92034f2a3e47efe41f95ddc74460c2c4797aadec79e14020737afcb

diff --git a/sci-mathematics/z3/z3-4.12.3.ebuild 
b/sci-mathematics/z3/z3-4.12.3.ebuild
new file mode 100644
index 000000000000..c3662f566d02
--- /dev/null
+++ b/sci-mathematics/z3/z3-4.12.3.ebuild
@@ -0,0 +1,111 @@
+# Copyright 1999-2023 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+PYTHON_COMPAT=( python3_{10..12} )
+
+inherit cmake-multilib java-pkg-opt-2 python-single-r1
+
+DESCRIPTION="An efficient theorem prover"
+HOMEPAGE="https://github.com/Z3Prover/z3/";
+SRC_URI="https://github.com/Z3Prover/z3/archive/${P}.tar.gz";
+S=${WORKDIR}/z3-${P}
+
+SLOT="0/$(ver_cut 1-2)"
+LICENSE="MIT"
+KEYWORDS="~amd64 ~arm ~arm64 ~loong ~ppc ~ppc64 ~riscv ~sparc ~x86"
+IUSE="doc examples gmp isabelle java python"
+REQUIRED_USE="${PYTHON_REQUIRED_USE}"
+
+RDEPEND="
+       ${PYTHON_DEPS}
+       gmp? ( dev-libs/gmp:0=[cxx(+),${MULTILIB_USEDEP}] )
+"
+DEPEND="
+       ${RDEPEND}
+       java? ( >=virtual/jdk-1.8 )
+"
+BDEPEND="
+       doc? ( app-doc/doxygen[dot] )
+"
+
+CMAKE_BUILD_TYPE=RelWithDebInfo
+
+src_prepare() {
+       # https://github.com/Z3Prover/z3/pull/7042
+       sed -e 's:importlib_resources:importlib.resources:' \
+               -i scripts/update_api.py || die
+
+       cmake_src_prepare
+       java-pkg-opt-2_src_prepare
+}
+
+multilib_src_configure() {
+       local mycmakeargs=(
+               -DCMAKE_INSTALL_DOCDIR="${EPREFIX}/usr/share/doc/${PF}"
+               -DZ3_USE_LIB_GMP=$(usex gmp)
+               -DZ3_ENABLE_EXAMPLE_TARGETS=OFF
+               -DZ3_BUILD_DOCUMENTATION=$(multilib_native_usex doc)
+               -DZ3_BUILD_PYTHON_BINDINGS=$(multilib_native_usex python)
+               -DZ3_BUILD_JAVA_BINDINGS=$(multilib_native_usex java)
+               -DZ3_INCLUDE_GIT_DESCRIBE=OFF
+               -DZ3_INCLUDE_GIT_HASH=OFF
+       )
+
+       multilib_is_native_abi && use java && mycmakeargs+=( 
-DJAVA_HOME="$(java-config -g JAVA_HOME )" )
+
+       cmake_src_configure
+}
+
+multilib_src_test() {
+       cmake_build test-z3
+       set -- "${BUILD_DIR}"/test-z3 /a
+       echo "${@}" >&2
+       "${@}" || die
+}
+
+multilib_src_install_all() {
+       dodoc README.md
+       use examples && dodoc -r examples
+       use python && python_optimize
+
+       if use isabelle; then
+               insinto /usr/share/Isabelle/contrib/${P}/etc
+               newins - settings <<-EOF
+                       Z3_COMPONENT="\$COMPONENT"
+                       Z3_HOME="${EPREFIX}/usr/bin"
+                       Z3_SOLVER="${EPREFIX}/usr/bin/z3"
+                       Z3_REMOTE_SOLVER="z3"
+                       Z3_VERSION="${PV}"
+                       Z3_INSTALLED="yes"
+                       Z3_NON_COMMERCIAL="yes"
+               EOF
+       fi
+}
+
+pkg_postinst() {
+       if use isabelle; then
+               if [[ -f ${ROOT}/etc/isabelle/components ]]; then
+                       sed -e "/contrib\/${PN}-[0-9.]*/d" \
+                               -i "${ROOT}/etc/isabelle/components" || die
+                       cat <<-EOF >> "${ROOT}/etc/isabelle/components" || die
+                               contrib/${P}
+                       EOF
+               fi
+       fi
+}
+
+pkg_postrm() {
+       if use isabelle; then
+               if [[ ! ${REPLACING_VERSIONS} ]]; then
+                       if [[ -f "${ROOT}/etc/isabelle/components" ]]; then
+                               # Note: this sed should only match the version 
of this ebuild
+                               # Which is what we want as we do not want to 
remove the line
+                               # of a new Isabelle component being installed 
during an upgrade.
+                               sed -e "/contrib\/${P}/d" \
+                                       -i "${ROOT}/etc/isabelle/components" || 
die
+                       fi
+               fi
+       fi
+}

Reply via email to