commit:     cc89415d5e977958f847c3f653d34806c3188308
Author:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Sat Apr  5 14:43:41 2025 +0000
Commit:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
CommitDate: Sat Apr  5 14:43:59 2025 +0000
URL:        https://gitweb.gentoo.org/repo/proj/prefix.git/commit/?id=cc89415d

app-arch/tar: import for Prefix fix

Signed-off-by: Fabian Groffen <grobian <AT> gentoo.org>

 app-arch/tar/Manifest                     |   2 +
 app-arch/tar/files/rmt                    |   8 ++
 app-arch/tar/files/tar-1.35-libintl.patch |  24 ++++++
 app-arch/tar/metadata.xml                 |  14 ++++
 app-arch/tar/tar-1.35.ebuild              | 120 ++++++++++++++++++++++++++++++
 5 files changed, 168 insertions(+)

diff --git a/app-arch/tar/Manifest b/app-arch/tar/Manifest
new file mode 100644
index 0000000000..4194bdb915
--- /dev/null
+++ b/app-arch/tar/Manifest
@@ -0,0 +1,2 @@
+DIST tar-1.35.tar.xz 2317208 BLAKE2B 
e1a200d21f433cd7d917dd979db16919a9167056ae62cf7d038a6118e56b2fe419cd4a396eee66f1f4dc13a8dc380e23f6ffd7ee0ca84e5dd9ad9411f60e002c
 SHA512 
8b84ed661e6c878fa33eb5c1808d20351e6f40551ac63f96014fb0d0b9c72d5d94d8865d39e36bcb184fd250f84778a3b271bbd8bd2ceb69eece0c3568577510
+DIST tar-1.35.tar.xz.sig 95 BLAKE2B 
8501b55b700bc99b81f04519db1cd8f7bc3d87dd5bfefa25a3d979b23359f02dfb770f3dd66dca275baa70a99612cb85c1019faaf3a1f0bcf50c9815b8e32eca
 SHA512 
00e5c95bf8015f75f59556a82ed7f50bddefe89754c7ff3c19411aee2f37626a5d65c33e18b87f7f8f96388d3f175fd095917419a3ad1c0fc9d6188088bac944

diff --git a/app-arch/tar/files/rmt b/app-arch/tar/files/rmt
new file mode 100644
index 0000000000..15ed6aa91f
--- /dev/null
+++ b/app-arch/tar/files/rmt
@@ -0,0 +1,8 @@
+#!/bin/sh
+#
+# This is not a mistake.  This shell script (/etc/rmt) has been provided
+# for compatibility with other Unix-like systems, some of which have
+# utilities that expect to find (and execute) rmt in the /etc directory
+# on remote systems.
+#
+exec rmt "$@"

diff --git a/app-arch/tar/files/tar-1.35-libintl.patch 
b/app-arch/tar/files/tar-1.35-libintl.patch
new file mode 100644
index 0000000000..e433aa6ead
--- /dev/null
+++ b/app-arch/tar/files/tar-1.35-libintl.patch
@@ -0,0 +1,24 @@
+From 8632df398b2f548465ebe68b8f494c0d6f8d913d Mon Sep 17 00:00:00 2001
+From: Sergey Poznyakoff <[email protected]>
+Date: Tue, 18 Jul 2023 17:02:23 +0300
+Subject: Fix savannah bug #64441
+
+* src/Makefile.am (tar_LDADD): Add libiconv libraries.
+---
+ src/Makefile.am | 3 ++-
+ 1 file changed, 2 insertions(+), 1 deletion(-)
+
+diff --git a/src/Makefile.am b/src/Makefile.am
+index 36c9543..e2ec58d 100644
+--- a/src/Makefile.am
++++ b/src/Makefile.am
+@@ -52,4 +52,5 @@ AM_CFLAGS = $(WARN_CFLAGS) $(WERROR_CFLAGS)
+ tar_LDADD = $(LIBS) ../lib/libtar.a ../gnu/libgnu.a\
+  $(LIB_ACL) $(LIB_CLOCK_GETTIME) $(LIB_EACCESS)\
+  $(LIB_GETRANDOM) $(LIB_HARD_LOCALE) $(FILE_HAS_ACL_LIB) $(LIB_MBRTOWC)\
+- $(LIB_SELINUX) $(LIB_SETLOCALE_NULL)
++ $(LIB_SELINUX) $(LIB_SETLOCALE_NULL) \
++ $(LIBINTL) $(LIBICONV)
+-- 
+cgit v1.1
+

diff --git a/app-arch/tar/metadata.xml b/app-arch/tar/metadata.xml
new file mode 100644
index 0000000000..8cbd50a677
--- /dev/null
+++ b/app-arch/tar/metadata.xml
@@ -0,0 +1,14 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd";>
+<pkgmetadata>
+<maintainer type="project">
+       <email>[email protected]</email>
+       <name>Gentoo Base System</name>
+</maintainer>
+<use>
+       <flag name="minimal">just install `tar`</flag>
+</use>
+<upstream>
+       <remote-id type="cpe">cpe:/a:gnu:tar</remote-id>
+</upstream>
+</pkgmetadata>

diff --git a/app-arch/tar/tar-1.35.ebuild b/app-arch/tar/tar-1.35.ebuild
new file mode 100644
index 0000000000..dd97d07f8d
--- /dev/null
+++ b/app-arch/tar/tar-1.35.ebuild
@@ -0,0 +1,120 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+VERIFY_SIG_OPENPGP_KEY_PATH=/usr/share/openpgp-keys/tar.asc
+inherit multiprocessing verify-sig autotools
+
+DESCRIPTION="Use this to make tarballs :)"
+HOMEPAGE="https://www.gnu.org/software/tar/";
+SRC_URI="
+       mirror://gnu/tar/${P}.tar.xz
+       https://alpha.gnu.org/gnu/tar/${P}.tar.xz
+       verify-sig? (
+               mirror://gnu/tar/${P}.tar.xz.sig
+               https://alpha.gnu.org/gnu/tar/${P}.tar.xz.sig
+       )
+"
+
+LICENSE="GPL-3+"
+SLOT="0"
+if [[ -z "$(ver_cut 3)" || "$(ver_cut 3)" -lt 90 ]] ; then
+       KEYWORDS="~alpha amd64 arm arm64 hppa ~loong ~m68k ~mips ppc ppc64 
~riscv ~s390 sparc x86 ~amd64-linux ~x86-linux ~arm64-macos ~ppc-macos 
~x64-macos ~x64-solaris"
+fi
+IUSE="acl minimal nls selinux xattr"
+
+RDEPEND="
+       acl? ( virtual/acl )
+       selinux? ( sys-libs/libselinux )
+"
+DEPEND="
+       ${RDEPEND}
+       xattr? ( elibc_glibc? ( sys-apps/attr ) )
+"
+BDEPEND="
+       nls? ( sys-devel/gettext )
+       verify-sig? ( sec-keys/openpgp-keys-tar )
+"
+PDEPEND="
+       app-alternatives/tar
+"
+
+PATCHES=( "${FILESDIR}"/${P}-libintl.patch )
+
+src_prepare() {
+       default
+       eautoreconf
+}
+
+src_configure() {
+       # -fanalyzer doesn't make sense for us in ebuilds, as it's for static 
analysis
+       export gl_cv_warn_c__fanalyzer=no
+
+       local myeconfargs=(
+               --bindir="${EPREFIX}"/bin
+               # Avoid -Werror
+               --disable-gcc-warnings
+               --enable-backup-scripts
+               --libexecdir="${EPREFIX}"/usr/sbin
+               $(use_with acl posix-acls)
+               $(use_enable nls)
+               $(use_with selinux)
+               $(use_with xattr xattrs)
+
+               # autoconf looks for gtar before tar (in configure scripts), 
hence
+               # in Prefix it is important that it is there, otherwise, a gtar 
from
+               # the host system (FreeBSD, Solaris, Darwin) will be found 
instead
+               # of the Prefix provided (GNU) tar
+               --program-prefix=g
+       )
+
+       # Drop CONFIG_SHELL hack after 1.35: 
https://git.savannah.gnu.org/cgit/tar.git/commit/?id=7687bf4acc4dc4554538389383d7fb4c3e6521cd
+       CONFIG_SHELL="${BROOT}"/bin/bash FORCE_UNSAFE_CONFIGURE=1 econf 
"${myeconfargs[@]}"
+}
+
+src_test() {
+       # Drop after 1.35: 
https://git.savannah.gnu.org/cgit/tar.git/commit/?id=18f90676e4695ffcf13413e9fbb24cc0ae2ae9d5
+       local -x XZ_OPT= XZ_DEFAULTS=
+
+       emake check TESTSUITEFLAGS="--jobs=$(get_makeopts_jobs)"
+}
+
+src_install() {
+       default
+
+       # A nasty yet required piece of baggage
+       exeinto /etc
+       doexe "${FILESDIR}"/rmt
+
+       mv "${ED}"/usr/sbin/{gbackup,backup-tar} || die
+       mv "${ED}"/usr/sbin/{grestore,restore-tar} || die
+       mv "${ED}"/usr/sbin/{g,}backup.sh || die
+       mv "${ED}"/usr/sbin/{g,}dump-remind || die
+
+       if use minimal ; then
+               find "${ED}"/etc "${ED}"/*bin/ "${ED}"/usr/*bin/ \
+                       -type f -a '!' -name gtar \
+                       -delete || die
+       fi
+
+       if ! use minimal; then
+               dosym grmt /usr/sbin/rmt
+       fi
+       dosym grmt.8 /usr/share/man/man8/rmt.8
+}
+
+pkg_postinst() {
+       # Ensure to preserve the symlink before app-alternatives/tar
+       # is installed
+       if [[ ! -h ${EROOT}/bin/tar ]]; then
+               if [[ -e ${EROOT}/usr/bin/tar ]] ; then
+                       # bug #904887
+                       ewarn "${EROOT}/usr/bin/tar exists but is not a 
symlink."
+                       ewarn "This is expected during Prefix bootstrap and 
unusual otherwise."
+                       ewarn "Moving away unexpected ${EROOT}/usr/bin/tar to 
.bak."
+                       mv "${EROOT}/usr/bin/tar" "${EROOT}/usr/bin/tar.bak" || 
die
+               fi
+               ln -s gtar "${EROOT}/bin/tar" || die
+       fi
+}

Reply via email to