commit:     8634659b0403f663819078f71936e259f0e7e159
Author:     Takuya Wakazono <pastalian46 <AT> gmail <DOT> com>
AuthorDate: Mon Nov 20 15:46:10 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Dec 15 06:20:29 2023 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8634659b

app-arch/rpm: add 4.19.1

- switch from autotools to cmake
- add rpm-sequoia as a new dependency
- remove USE flags that do not have proper compile options
- remove old patches and workarounds

Closes: https://bugs.gentoo.org/917034
Signed-off-by: Takuya Wakazono <pastalian46 <AT> gmail.com>
Closes: https://github.com/gentoo/gentoo/pull/33742
Signed-off-by: Sam James <sam <AT> gentoo.org>

 app-arch/rpm/Manifest                      |   1 +
 app-arch/rpm/files/rpm-4.19.0-libdir.patch |  13 +++
 app-arch/rpm/metadata.xml                  |  12 ++-
 app-arch/rpm/rpm-4.19.1.ebuild             | 132 +++++++++++++++++++++++++++++
 4 files changed, 157 insertions(+), 1 deletion(-)

diff --git a/app-arch/rpm/Manifest b/app-arch/rpm/Manifest
index fe632121d059..dfd3723ff544 100644
--- a/app-arch/rpm/Manifest
+++ b/app-arch/rpm/Manifest
@@ -1,2 +1,3 @@
 DIST rpm-4.18.0.tar.bz2 6600013 BLAKE2B 
127c3b1427884d04c3db4fc73eb73a978a58241bc740620e3e46c7557d99833092866b5d9c8b4fdf72cd106668d9e5f5cb8c4b918decf1513a82d10258975116
 SHA512 
c218b811c0c2db368a2919f60742904a4a5abf09dc20804d649eb42f1853d1c21d121086d6014cd210b2040643c37b5d86b53052958cf702ae2e54fe65f1c0ec
 DIST rpm-4.18.1.tar.bz2 6396363 BLAKE2B 
4bc582bdc34a89d83346a8e18133c4f1846f2e8741c85ae2d0fd3398166e5a5d81ed86869e34700d3ea414fbf8ccf6c918692e865b956b1e6b70830b64cd323e
 SHA512 
0ede2138b9b4c3b50d7e914cf82655507fcc207ba67804c749ea17560002976cb26b95801e9138a51589b60459494a991213a1131dbef5af2eca9b5050a4f29c
+DIST rpm-4.19.1.tar.bz2 5940447 BLAKE2B 
b40de875d79a48d0c54aef86bb8b3cb0312cbb4eb5b1382fcc147669c5d559c9a91fcfb3b4160fe1ad34595bc553132d1af34fe70a45f868b7f06a1635c3fe1e
 SHA512 
12e6c7294a98032418ec9a0510a8183658483fe713d67e6890a9c0da44748371df45a26af6055d08470b85b5dec0cf94795d17c5b3e11db08b20ef07e8e06642

diff --git a/app-arch/rpm/files/rpm-4.19.0-libdir.patch 
b/app-arch/rpm/files/rpm-4.19.0-libdir.patch
new file mode 100644
index 000000000000..9899827c985e
--- /dev/null
+++ b/app-arch/rpm/files/rpm-4.19.0-libdir.patch
@@ -0,0 +1,13 @@
+diff --git a/CMakeLists.txt b/CMakeLists.txt
+index c164e9c52..5738c821f 100644
+--- a/CMakeLists.txt
++++ b/CMakeLists.txt
+@@ -32,7 +32,7 @@ option(WITH_FSVERITY "Build with fsverity support" OFF)
+ option(WITH_IMAEVM "Build with IMA support" OFF)
+ option(WITH_FAPOLICYD "Build with fapolicyd support" ON)
+ 
+-set(RPM_CONFIGDIR "${CMAKE_INSTALL_PREFIX}/lib/rpm" CACHE PATH "rpm home")
++set(RPM_CONFIGDIR "${CMAKE_INSTALL_PREFIX}/libexec/rpm" CACHE PATH "rpm home")
+ set(RPM_VENDOR "vendor" CACHE STRING "rpm vendor string")
+ 
+ # Emulate libtool versioning. Before a public release:

diff --git a/app-arch/rpm/metadata.xml b/app-arch/rpm/metadata.xml
index 43a5b10a145b..8e808eda79fe 100644
--- a/app-arch/rpm/metadata.xml
+++ b/app-arch/rpm/metadata.xml
@@ -1,8 +1,18 @@
 <?xml version="1.0" encoding="UTF-8"?>
 <!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd";>
 <pkgmetadata>
-       <!-- maintainer-needed -->
+       <maintainer type="person" proxied="yes">
+               <email>[email protected]</email>
+               <name>Takuya Wakazono</name>
+       </maintainer>
+       <maintainer type="project" proxied="proxy">
+               <email>[email protected]</email>
+               <name>Proxy Maintainers</name>
+       </maintainer>
        <upstream>
                <remote-id type="github">rpm-software-management/rpm</remote-id>
        </upstream>
+       <use>
+               <flag name="sequoia">Use <pkg>app-crypt/rpm-sequoia</pkg> 
instead of the deprecated internal parser</flag>
+       </use>
 </pkgmetadata>

diff --git a/app-arch/rpm/rpm-4.19.1.ebuild b/app-arch/rpm/rpm-4.19.1.ebuild
new file mode 100644
index 000000000000..a63e0576b9a7
--- /dev/null
+++ b/app-arch/rpm/rpm-4.19.1.ebuild
@@ -0,0 +1,132 @@
+# Copyright 2023 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+CMAKE_MAKEFILE_GENERATOR=emake
+LUA_COMPAT=( lua5-{3,4} )
+PYTHON_COMPAT=( python3_{10..12} )
+
+inherit cmake lua-single python-single-r1 toolchain-funcs
+
+DESCRIPTION="The RPM Package Manager"
+HOMEPAGE="https://rpm.org/ https://github.com/rpm-software-management/rpm";
+SRC_URI="
+       https://ftp.osuosl.org/pub/rpm/releases/rpm-$(ver_cut 
1-2).x/${P}.tar.bz2
+       http://ftp.rpm.org/releases/rpm-$(ver_cut 1-2).x/${P}.tar.bz2
+"
+
+LICENSE="GPL-2 LGPL-2"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~loong ~mips ~ppc ~ppc64 
~riscv ~s390 ~sparc ~x86 ~amd64-linux ~x86-linux"
+IUSE="acl audit caps +berkdb doc dbus nls openmp python selinux +sequoia 
+sqlite"
+REQUIRED_USE="
+       ${LUA_REQUIRED_USE}
+       python? ( ${PYTHON_REQUIRED_USE} )
+"
+# Tests run against a Fedora container image, which needs to be pulled.
+RESTRICT="test"
+
+DEPEND="
+       ${LUA_DEPS}
+       app-arch/libarchive:=
+       >=app-arch/bzip2-1.0.1
+       app-arch/xz-utils
+       app-arch/zstd:=
+       >=app-crypt/gnupg-1.2
+       >=dev-lang/perl-5.8.8
+       dev-libs/elfutils
+       >=dev-libs/popt-1.7
+       sys-apps/file
+       sys-libs/readline:=
+       >=sys-libs/zlib-1.2.3-r1
+       virtual/libintl
+       acl? ( virtual/acl )
+       audit? ( sys-process/audit )
+       caps? ( >=sys-libs/libcap-2.0 )
+       dbus? ( sys-apps/dbus )
+       sqlite? ( dev-db/sqlite:3 )
+       python? ( ${PYTHON_DEPS} )
+       nls? ( virtual/libintl )
+       sequoia? ( app-crypt/rpm-sequoia )
+       !sequoia? ( dev-libs/libgcrypt:= )
+"
+BDEPEND="
+       virtual/pkgconfig
+       doc? ( app-doc/doxygen )
+       nls? ( sys-devel/gettext )
+"
+RDEPEND="
+       ${DEPEND}
+       selinux? ( sec-policy/selinux-rpm )
+"
+
+PATCHES=(
+       "${FILESDIR}"/${PN}-4.19.0-libdir.patch
+)
+
+pkg_pretend() {
+       [[ ${MERGE_TYPE} != binary ]] && use openmp && tc-check-openmp
+}
+
+pkg_setup() {
+       lua-single_pkg_setup
+
+       use python && python-single-r1_pkg_setup
+
+       # bug #779769
+       [[ ${MERGE_TYPE} != binary ]] && use openmp && tc-check-openmp
+}
+
+src_prepare() {
+       cmake_src_prepare
+}
+
+src_configure() {
+       # rpm no longer supports berkdb, but has readonly support.
+       # 
https://github.com/rpm-software-management/rpm/commit/4290300e24c5ab17c615b6108f38438e31eeb1d0
+       local mycmakeargs=(
+               -DENABLE_TESTSUITE=OFF
+               -DWITH_FAPOLICYD=OFF
+               -DWITH_SELINUX=OFF
+               -DENABLE_BDB_RO=$(usex berkdb)
+               -DENABLE_NLS=$(usex nls)
+               -DENABLE_OPENMP=$(usex openmp)
+               -DENABLE_PYTHON=$(usex python)
+               -DENABLE_SQLITE=$(usex sqlite)
+               -DWITH_ACL=$(usex acl)
+               -DWITH_AUDIT=$(usex audit)
+               -DWITH_CAP=$(usex caps)
+               -DWITH_DBUS=$(usex dbus)
+               -DWITH_INTERNAL_OPENPGP=$(usex sequoia OFF ON)
+               $(cmake_use_find_package doc Doxygen)
+       )
+       cmake_src_configure
+}
+
+src_test() {
+       emake -C "${BUILD_DIR}" check
+}
+
+src_install() {
+       cmake_src_install
+
+       # Remove pre-built API docs.
+       use doc || rm -rf "${ED}/usr/share/doc/${PF}" || die
+
+       dodoc CREDITS README
+
+       keepdir /usr/src/rpm/{SRPMS,SPECS,SOURCES,RPMS,BUILD}
+
+       use python && python_optimize
+}
+
+pkg_postinst() {
+       if [[ -f "${EROOT}"/var/lib/rpm/rpmdb.sqlite ]] ; then
+               einfo "RPM database found... Rebuilding database (may take a 
while)..."
+               "${EROOT}"/usr/bin/rpmdb --rebuilddb --root="${EROOT}/" || die
+       else
+               einfo "No RPM database found... Creating database..."
+               "${EROOT}"/usr/bin/rpmdb --initdb --root="${EROOT}/" || die
+       fi
+}

Reply via email to