commit:     beb74c3cee856531f1d65dc4864127444734e43f
Author:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 27 18:44:02 2022 +0000
Commit:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
CommitDate: Tue Dec 27 18:44:02 2022 +0000
URL:        https://gitweb.gentoo.org/repo/proj/prefix.git/commit/?id=beb74c3c

sys-apps/coreutils: sync with gx86

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

 sys-apps/coreutils/Manifest                        |   4 +-
 sys-apps/coreutils/coreutils-8.32.ebuild           | 251 -------------------
 sys-apps/coreutils/coreutils-9.1-r2.ebuild         | 274 +++++++++++++++++++++
 .../coreutils-9.1-fix-rename-simple-backups.patch  |  38 +++
 4 files changed, 315 insertions(+), 252 deletions(-)

diff --git a/sys-apps/coreutils/Manifest b/sys-apps/coreutils/Manifest
index b0fcebe2bb..1905016f71 100644
--- a/sys-apps/coreutils/Manifest
+++ b/sys-apps/coreutils/Manifest
@@ -1,4 +1,6 @@
 DIST coreutils-8.28-cygwin-8.26-3.patch 36792 BLAKE2B 
f494be97595ff9532f57ca3d5386d185d813647fb07480dc1b22434fa5eecfa22acb6940b82cc733ae4448757e5f69cf2c7c746a5752409fe4aa11dd47482e63
 SHA512 
53d05262118a0063a0b3992b80dcda28256516da4d077a691117384ea808e5468488443d9c4b0e38a4d5148e5e721e733dcb0562dcf23a1370d4090251458951
 DIST coreutils-8.30-patches-01.tar.xz 5788 BLAKE2B 
a41511ce39ac570cb14b7f12d125eebef92217469a9490808719fa0665f5e5c0adb96fbd02c4bac4d280d1502295669575790a81dbc01afe2ca3a9d384cbefb0
 SHA512 
b1e1933637de4581d5f8c6ede4e80a012435d13f0cf5550a76ab5bbe9441e3c15ce19ef3f78a7ea3b8368d5e9a3bb17c1207c471d26171b59786f38adeba0454
-DIST coreutils-8.32.tar.xz 5547836 BLAKE2B 
0ad99c176c19ec214fcfd0845523e5362f0151827707c759bd46c0fe8d2501c6ad1c29c5b71266f6525857bc0d56c472db0d7fe29953b6c65e2e6c76bdf3c515
 SHA512 
1c8f3584efd61b4b02e7ac5db8e103b63cfb2063432caaf1e64cb2dcc56d8c657d1133bbf10bd41468d6a1f31142e6caa81d16ae68fa3e6e84075c253613a145
 DIST coreutils-9.0.tar.xz 5612752 BLAKE2B 
59617cd25fd4c70f51bfbef851bd83e73f9c9ba5c11eb539f7f75c0184d55832e004b28e9268fb8064db145cb071ead2b9c0c3346bc35a11934ffe1b15bf17ac
 SHA512 
9be08212891dbf48e5b22e7689dc27dac50df4631ebf29313470b72b7921f0b2aa5242917d05587785358495ca56e3b21f5b3ca81043d53cab92354da6c53a03
+DIST coreutils-9.0_p20220409-patches-01.tar.xz 6244 BLAKE2B 
8ca9855680719660782931467ec70095c826e66b9850890b8cf456963f8114f63940707386b97c766172d01e55e17b7db2aa1c329208a873a76e2293b29f565f
 SHA512 
4b43c25832122d241f33e6b4eff24bc1fa045b9ca5af45a49d22ecb1fa282986c4e4a045ef24c34b3d94fd9a2247247c42c344261e3f464d881969e6f3351d3f
+DIST coreutils-9.1.tar.xz 5712104 BLAKE2B 
f5654e4935535275615d44a56c071d1c0746af36cf4615fcc0a5a0d387af9c9023adac31f31a52e16b3d1105b9d4c0fb7ebff9b2862498849f867a866049dd6e
 SHA512 
a6ee2c549140b189e8c1b35e119d4289ec27244ec0ed9da0ac55202f365a7e33778b1dc7c4e64d1669599ff81a8297fe4f5adbcc8a3a2f75c919a43cd4b9bdfa
+DIST coreutils-9.1.tar.xz.sig 833 BLAKE2B 
e9627a066f3c67596feaa8d43d5785076230f440bacea84d8b5736e51a22787c2d5df1f3e2cd8523d01fb7b468933d3c17fce3cb1fbefef322a0e0d820b81842
 SHA512 
9f0766531afd4faa3e2c337730f61db55605cf06729e9c61f644594883732c2e0b1ddb0005b492be309c53e6f45b8ff875398163a48699d52517ea49e9bdbc91

diff --git a/sys-apps/coreutils/coreutils-8.32.ebuild 
b/sys-apps/coreutils/coreutils-8.32.ebuild
deleted file mode 100644
index 2e794c6590..0000000000
--- a/sys-apps/coreutils/coreutils-8.32.ebuild
+++ /dev/null
@@ -1,251 +0,0 @@
-# Copyright 1999-2021 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI="6"
-
-PYTHON_COMPAT=( python3_{6,7,8,9} )
-
-inherit eutils flag-o-matic python-any-r1 toolchain-funcs
-
-PATCH="${PN}-8.30-patches-01"
-DESCRIPTION="Standard GNU utilities (chmod, cp, dd, ls, sort, tr, head, wc, 
who,...)"
-HOMEPAGE="https://www.gnu.org/software/coreutils/";
-SRC_URI="mirror://gnu/${PN}/${P}.tar.xz
-       !vanilla? (
-               mirror://gentoo/${PATCH}.tar.xz
-               https://dev.gentoo.org/~polynomial-c/dist/${PATCH}.tar.xz
-       )
-       elibc_Cygwin? (
-               
https://dev.gentoo.org/~grobian/distfiles/${PN}-8.28-cygwin-8.26-3.patch
-       )
-"
-
-LICENSE="GPL-3"
-SLOT="0"
-KEYWORDS="~x64-cygwin ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos 
~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
-IUSE="acl caps gmp hostname kill multicall nls selinux +split-usr static test 
userland_BSD vanilla xattr"
-RESTRICT="!test? ( test )"
-
-LIB_DEPEND="acl? ( sys-apps/acl[static-libs] )
-       caps? ( sys-libs/libcap )
-       gmp? ( dev-libs/gmp:=[static-libs] )
-       xattr? ( !userland_BSD? ( sys-apps/attr[static-libs] ) )"
-RDEPEND="!static? ( ${LIB_DEPEND//\[static-libs]} )
-       selinux? ( sys-libs/libselinux )
-       nls? ( virtual/libintl )"
-DEPEND="${RDEPEND}
-       static? ( ${LIB_DEPEND} )
-       app-arch/xz-utils
-       test? (
-               dev-lang/perl
-               dev-perl/Expect
-               !userland_BSD? (
-                       dev-util/strace
-               )
-               ${PYTHON_DEPS}
-               $(python_gen_any_dep 'dev-python/pyinotify[${PYTHON_USEDEP}]')
-       )"
-RDEPEND+="
-       hostname? ( !sys-apps/net-tools[hostname] )
-       kill? (
-               !sys-apps/util-linux[kill]
-               !sys-process/procps[kill]
-       )
-       !app-misc/realpath
-       !<sys-apps/util-linux-2.13
-       !<sys-apps/sandbox-2.10-r4
-       !sys-apps/stat
-       !net-mail/base64
-       !sys-apps/mktemp
-       !<app-forensics/tct-1.18-r1
-       !<net-fs/netatalk-2.0.3-r4"
-
-pkg_setup() {
-       if use test ; then
-               python-any-r1_pkg_setup
-       fi
-}
-
-src_prepare() {
-       local PATCHES=(
-               "${FILESDIR}"/coreutils-8.32-ls-restore-8.31-behavior.patch
-       )
-
-       if ! use vanilla ; then
-               PATCHES+=( "${WORKDIR}"/patch )
-               PATCHES+=( "${FILESDIR}"/${PN}-8.32-sandbox-env-test.patch )
-       fi
-
-       if use elibc_Cygwin ; then
-               PATCHES+=( "${DISTDIR}"/${PN}-8.28-cygwin-8.26-3.patch )
-       fi
-
-       default
-
-       # fixup libstdbuf non-libtool stuff
-       if [[ ${CHOST} == *-darwin* ]] ; then
-               if [[ ${CHOST} == *-darwin9* ]] ; then
-                       # we need replacement libs from libcoreutils.a here in 
order
-                       # to finish the linking
-                       sed -i \
-                               -e "/src_libstdbuf_so_LDADD/s:$: 
lib/libcoreutils.a:" \
-                               Makefile.in \
-                               || die
-                       # and we need serial building :(
-                       export MAKEOPTS+=" -j1"
-               fi
-               sed -i \
-                       -e "/src_libstdbuf_so_LDFLAGS = 
-shared/s:-shared:-dynamiclib -install_name 
${EPREFIX}/usr/libexec/coreutils/libstdbuf.dylib:" \
-                       Makefile.in \
-                       || die
-       elif use elibc_Cygwin ; then
-               sed -i -e 's|\(libstdbuf\.so\)$(EXEEXT)|\1|g' Makefile.in || die
-       fi
-       sed -i \
-               -e "s/libstdbuf\\.so/libstdbuf$(get_libname)/" \
-               src/stdbuf.c \
-               Makefile.in \
-               configure \
-               || die
-
-       # Since we've patched many .c files, the make process will try to
-       # re-build the manpages by running `./bin --help`.  When doing a
-       # cross-compile, we can't do that since 'bin' isn't a native bin.
-       # Also, it's not like we changed the usage on any of these things,
-       # so let's just update the timestamps and skip the help2man step.
-       set -- man/*.x
-       touch ${@/%x/1}
-
-       # Avoid perl dep for compiled in dircolors default #348642
-       if ! has_version dev-lang/perl ; then
-               touch src/dircolors.h
-               touch ${@/%x/1}
-       fi
-}
-
-src_configure() {
-       local myconf=(
-               --with-packager="Gentoo"
-               --with-packager-version="${PVR} (p${PATCH_VER:-0})"
-               --with-packager-bug-reports="https://bugs.gentoo.org/";
-               --enable-install-program="arch,$(usev hostname),$(usev kill)"
-               --enable-no-install-program="groups,$(usev !hostname),$(usev 
!kill),su,uptime"
-               --enable-largefile
-               $(usex caps '' --disable-libcap)
-               $(use_enable nls)
-               $(use_enable acl)
-               $(use_enable multicall single-binary)
-               $(use_enable xattr)
-               $(use_with gmp)
-       )
-       if tc-is-cross-compiler && [[ ${CHOST} == *linux* ]] ; then
-               export fu_cv_sys_stat_statfs2_bsize=yes #311569
-               export gl_cv_func_realpath_works=yes #416629
-       fi
-
-       export gl_cv_func_mknod_works=yes #409919
-       use static && append-ldflags -static && sed -i '/elf_sys=yes/s:yes:no:' 
configure #321821
-       use selinux || export 
ac_cv_{header_selinux_{context,flash,selinux}_h,search_setfilecon}=no #301782
-       use userland_BSD && myconf+=( -program-prefix=g 
--program-transform-name=s/stat/nustat/ )
-       # kill/uptime - procps
-       # groups/su   - shadow
-       # hostname    - net-tools
-       econf "${myconf[@]}"
-}
-
-src_test() {
-       # Known to fail with FEATURES=usersandbox (bug #439574):
-       #   -  tests/du/long-from-unreadable.sh} (bug #413621)
-       #   -  tests/rm/deep-2.sh (bug #413621)
-       #   -  tests/dd/no-allocate.sh (bug #629660)
-       if has usersandbox ${FEATURES} ; then
-               ewarn "You are emerging ${P} with 'usersandbox' enabled." \
-                       "Expect some test failures or emerge with 
'FEATURES=-usersandbox'!"
-       fi
-
-       # Non-root tests will fail if the full path isn't
-       # accessible to non-root users
-       chmod -R go-w "${WORKDIR}"
-       chmod a+rx "${WORKDIR}"
-
-       # coreutils tests like to do `mount` and such with temp dirs
-       # so make sure /etc/mtab is writable #265725
-       # make sure /dev/loop* can be mounted #269758
-       mkdir -p "${T}"/mount-wrappers || die
-       mkwrap() {
-               local w ww
-               for w in "${@}" ; do
-                       ww="${T}/mount-wrappers/${w}"
-                       cat <<-EOF > "${ww}"
-                               #!${EPREFIX}/bin/sh
-                               exec env 
SANDBOX_WRITE="\${SANDBOX_WRITE}:/etc/mtab:/dev/loop" $(type -P ${w}) "\$@"
-                       EOF
-                       chmod a+rx "${ww}"
-               done
-       }
-       mkwrap mount umount
-
-       addwrite /dev/full
-       #export RUN_EXPENSIVE_TESTS="yes"
-       #export FETISH_GROUPS="portage wheel"
-       env PATH="${T}/mount-wrappers:${PATH}" \
-       emake -j1 -k check
-}
-
-src_install() {
-       default
-
-       insinto /etc
-       newins src/dircolors.hin DIR_COLORS
-
-       if [[ ${USERLAND} == "GNU" ]] ; then
-               cd "${ED%/}"/usr/bin || die
-               dodir /bin
-               # move critical binaries into /bin (required by FHS)
-               local fhs="cat chgrp chmod chown cp date dd df echo false ln ls
-                          mkdir mknod mv pwd rm rmdir stty sync true uname"
-               mv ${fhs} ../../bin/ || die "could not move fhs bins"
-               if use hostname; then
-                       mv hostname ../../bin/ || die
-               fi
-               if use kill; then
-                       mv kill ../../bin/ || die
-               fi
-               if use split-usr ; then
-                       # move critical binaries into /bin (common scripts)
-                       local com="basename chroot cut dir dirname du env expr 
head mkfifo
-                                  mktemp readlink seq sleep sort tail touch tr 
tty vdir wc yes"
-                       mv ${com} ../../bin/ || die "could not move common bins"
-                       # create a symlink for uname in /usr/bin/ since 
autotools require it
-                       local x
-                       for x in ${com} uname ; do
-                               dosym ../../bin/${x} /usr/bin/${x}
-                       done
-               fi
-       else
-               # For now, drop the man pages, collides with the ones of the 
system.
-               rm -rf "${ED%/}"/usr/share/man
-       fi
-
-       if use elibc_Cygwin ; then
-               ! use kill || mv "${ED}"/bin/{,g}kill || die
-               mv "${ED}"/usr/libexec/${PN}/libstdbuf$(get_libname){.exe,} || 
die
-       fi
-}
-
-pkg_postinst() {
-       ewarn "Make sure you run 'hash -r' in your active shells."
-       ewarn "You should also re-source your shell settings for LS_COLORS"
-       ewarn "  changes, such as: source /etc/profile"
-
-       # Help out users using experimental filesystems
-       if grep -qs btrfs "${EROOT%/}"/etc/fstab /proc/mounts ; then
-               case $(uname -r) in
-               2.6.[12][0-9]|2.6.3[0-7]*)
-                       ewarn "You are running a system with a buggy btrfs 
driver."
-                       ewarn "Please upgrade your kernel to avoid silent 
corruption."
-                       ewarn "See: https://bugs.gentoo.org/353907";
-                       ;;
-               esac
-       fi
-}

diff --git a/sys-apps/coreutils/coreutils-9.1-r2.ebuild 
b/sys-apps/coreutils/coreutils-9.1-r2.ebuild
new file mode 100644
index 0000000000..d376335dc8
--- /dev/null
+++ b/sys-apps/coreutils/coreutils-9.1-r2.ebuild
@@ -0,0 +1,274 @@
+# Copyright 1999-2022 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+# Try to keep an eye on Fedora's packaging: 
https://src.fedoraproject.org/rpms/coreutils
+# The upstream coreutils maintianers also maintain the package in Fedora and 
may
+# backport fixes which we want to pick up.
+
+PYTHON_COMPAT=( python3_{8..10} )
+VERIFY_SIG_OPENPGP_KEY_PATH="${BROOT}"/usr/share/openpgp-keys/coreutils.asc
+inherit flag-o-matic python-any-r1 toolchain-funcs verify-sig
+
+MY_PATCH="${PN}-9.0_p20220409-patches-01"
+DESCRIPTION="Standard GNU utilities (chmod, cp, dd, ls, sort, tr, head, wc, 
who,...)"
+HOMEPAGE="https://www.gnu.org/software/coreutils/";
+
+if [[ ${PV} == *_p* ]] ; then
+       # Note: could put this in devspace, but if it's gone, we don't want
+       # it in tree anyway. It's just for testing.
+       MY_SNAPSHOT="$(ver_cut 1-2).193-54bec"
+       SRC_URI="https://www.pixelbeat.org/cu/coreutils-${MY_SNAPSHOT}.tar.xz 
-> ${P}.tar.xz"
+       SRC_URI+=" verify-sig? ( 
https://www.pixelbeat.org/cu/coreutils-${MY_SNAPSHOT}.tar.xz.sig -> 
${P}.tar.xz.sig )"
+       S="${WORKDIR}"/${PN}-${MY_SNAPSHOT}
+else
+       SRC_URI="mirror://gnu/${PN}/${P}.tar.xz
+               verify-sig? ( mirror://gnu/${PN}/${P}.tar.xz.sig )"
+       KEYWORDS="~x64-cygwin ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos 
~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
+fi
+
+SRC_URI+=" !vanilla? ( 
https://dev.gentoo.org/~sam/distfiles/${CATEGORY}/${PN}/${MY_PATCH}.tar.xz )"
+
+LICENSE="GPL-3+"
+SLOT="0"
+IUSE="acl caps gmp hostname kill multicall nls +openssl selinux +split-usr 
static test vanilla xattr"
+RESTRICT="!test? ( test )"
+
+LIB_DEPEND="acl? ( sys-apps/acl[static-libs] )
+       caps? ( sys-libs/libcap )
+       gmp? ( dev-libs/gmp:=[static-libs] )
+       openssl? ( dev-libs/openssl:=[static-libs] )
+       xattr? ( sys-apps/attr[static-libs] )"
+RDEPEND="!static? ( ${LIB_DEPEND//\[static-libs]} )
+       selinux? ( sys-libs/libselinux )
+       nls? ( virtual/libintl )"
+DEPEND="
+       ${RDEPEND}
+       static? ( ${LIB_DEPEND} )
+"
+BDEPEND="
+       app-arch/xz-utils
+       dev-lang/perl
+       test? (
+               dev-lang/perl
+               dev-perl/Expect
+               dev-util/strace
+               ${PYTHON_DEPS}
+       )
+       verify-sig? ( sec-keys/openpgp-keys-coreutils )
+"
+RDEPEND+="
+       hostname? ( !sys-apps/net-tools[hostname] )
+       kill? (
+               !sys-apps/util-linux[kill]
+               !sys-process/procps[kill]
+       )
+       !app-misc/realpath
+       !<sys-apps/util-linux-2.13
+       !<sys-apps/sandbox-2.10-r4
+       !sys-apps/stat
+       !net-mail/base64
+       !sys-apps/mktemp
+       !<app-forensics/tct-1.18-r1
+       !<net-fs/netatalk-2.0.3-r4"
+
+pkg_setup() {
+       if use test ; then
+               python-any-r1_pkg_setup
+       fi
+}
+
+src_unpack() {
+       if use verify-sig ; then
+               # Needed for downloaded patch (which is unsigned, which is fine)
+               verify-sig_verify_detached "${DISTDIR}"/${P}.tar.xz{,.sig}
+       fi
+
+       default
+}
+
+src_prepare() {
+       local PATCHES=(
+               # Upstream patches
+               "${FILESDIR}"/${P}-fix-rename-simple-backups.patch
+       )
+
+       if ! use vanilla ; then
+               PATCHES+=( "${WORKDIR}"/patch )
+       fi
+
+       default
+
+       # fixup libstdbuf non-libtool stuff
+       if [[ ${CHOST} == *-darwin* ]] ; then
+               # we need replacement libs from libcoreutils.a here in order
+               # to finish the linking (they try to avoid this, but it doesn't
+               # during bootstrap, a re-install is fine though)
+               sed -i \
+                       -e "/src_libstdbuf_so_LDADD/s:$: lib/libcoreutils.a:" \
+                       Makefile.in \
+                       || die
+               # and we need serial building :(
+               export MAKEOPTS+=" -j1"
+               # set a proper install_name
+               sed -i \
+                       -e "/src_libstdbuf_so_LDFLAGS = 
-shared/s:-shared:-dynamiclib -install_name 
${EPREFIX}/usr/libexec/coreutils/libstdbuf.dylib:" \
+                       Makefile.in \
+                       || die
+       fi
+       sed -i \
+               -e "s/libstdbuf\\.so/libstdbuf$(get_libname)/" \
+               src/stdbuf.c \
+               Makefile.in \
+               configure \
+               || die
+
+       # Since we've patched many .c files, the make process will try to
+       # re-build the manpages by running `./bin --help`.  When doing a
+       # cross-compile, we can't do that since 'bin' isn't a native bin.
+       #
+       # Also, it's not like we changed the usage on any of these things,
+       # so let's just update the timestamps and skip the help2man step.
+       set -- man/*.x
+       touch ${@/%x/1} || die
+
+       # Avoid perl dep for compiled in dircolors default (bug #348642)
+       if ! has_version dev-lang/perl ; then
+               touch src/dircolors.h || die
+               touch ${@/%x/1} || die
+       fi
+}
+
+src_configure() {
+       local myconf=(
+               --with-packager="Gentoo"
+               --with-packager-version="${PVR} (p${PATCH_VER:-0})"
+               --with-packager-bug-reports="https://bugs.gentoo.org/";
+               # kill/uptime - procps
+               # groups/su   - shadow
+               # hostname    - net-tools
+               --enable-install-program="arch,$(usev hostname),$(usev kill)"
+               --enable-no-install-program="groups,$(usev !hostname),$(usev 
!kill),su,uptime"
+               --enable-largefile
+               $(usex caps '' --disable-libcap)
+               $(use_enable nls)
+               $(use_enable acl)
+               $(use_enable multicall single-binary)
+               $(use_enable xattr)
+               $(use_with gmp libgmp)
+               $(use_with openssl)
+       )
+
+       if use gmp ; then
+               myconf+=( --with-libgmp-prefix="${ESYSROOT}"/usr )
+       fi
+
+       if tc-is-cross-compiler && [[ ${CHOST} == *linux* ]] ; then
+               # bug #311569
+               export fu_cv_sys_stat_statfs2_bsize=yes
+               # bug #416629
+               export gl_cv_func_realpath_works=yes
+       fi
+
+       # bug #409919
+       export gl_cv_func_mknod_works=yes
+
+       if use static ; then
+               append-ldflags -static
+               # bug #321821
+               sed -i '/elf_sys=yes/s:yes:no:' configure || die
+       fi
+
+       if ! use selinux ; then
+               # bug #301782
+               export 
ac_cv_{header_selinux_{context,flash,selinux}_h,search_setfilecon}=no
+       fi
+
+       econf "${myconf[@]}"
+}
+
+src_test() {
+       # Known to fail with FEATURES=usersandbox (bug #439574):
+       #   -  tests/du/long-from-unreadable.sh} (bug #413621)
+       #   -  tests/rm/deep-2.sh (bug #413621)
+       #   -  tests/dd/no-allocate.sh (bug #629660)
+       if has usersandbox ${FEATURES} ; then
+               ewarn "You are emerging ${P} with 'usersandbox' enabled." \
+                       "Expect some test failures or emerge with 
'FEATURES=-usersandbox'!"
+       fi
+
+       # Non-root tests will fail if the full path isn't
+       # accessible to non-root users
+       chmod -R go-w "${WORKDIR}" || die
+       chmod a+rx "${WORKDIR}" || die
+
+       # coreutils tests like to do `mount` and such with temp dirs,
+       # so make sure:
+       # - /etc/mtab is writable (bug #265725)
+       # - /dev/loop* can be mounted (bug #269758)
+       mkdir -p "${T}"/mount-wrappers || die
+       mkwrap() {
+               local w ww
+               for w in "${@}" ; do
+                       ww="${T}/mount-wrappers/${w}"
+                       cat <<-EOF > "${ww}"
+                               #!${EPREFIX}/bin/sh
+                               exec env 
SANDBOX_WRITE="\${SANDBOX_WRITE}:/etc/mtab:/dev/loop" $(type -P ${w}) "\$@"
+                       EOF
+                       chmod a+rx "${ww}" || die
+               done
+       }
+       mkwrap mount umount
+
+       addwrite /dev/full
+       #export RUN_EXPENSIVE_TESTS="yes"
+       #export FETISH_GROUPS="portage wheel"
+       env PATH="${T}/mount-wrappers:${PATH}" emake -k check VERBOSE=yes
+}
+
+src_install() {
+       default
+
+       insinto /etc
+       newins src/dircolors.hin DIR_COLORS
+
+       if use split-usr ; then
+               cd "${ED}"/usr/bin || die
+               dodir /bin
+
+               # Move critical binaries into /bin (required by FHS)
+               local fhs="cat chgrp chmod chown cp date dd df echo false ln ls
+                          mkdir mknod mv pwd rm rmdir stty sync true uname"
+               mv ${fhs} ../../bin/ || die "Could not move FHS bins!"
+
+               if use hostname ; then
+                       mv hostname ../../bin/ || die
+               fi
+
+               if use kill ; then
+                       mv kill ../../bin/ || die
+               fi
+
+               # Move critical binaries into /bin (common scripts)
+               # (Why are these required for booting?)
+               local com="basename chroot cut dir dirname du env expr head 
mkfifo
+                          mktemp readlink seq sleep sort tail touch tr tty 
vdir wc yes"
+               mv ${com} ../../bin/ || die "Could not move common bins!"
+
+               # Create a symlink for uname in /usr/bin/ since autotools 
require it.
+               # (Other than uname, we need to figure out why we are
+               # creating symlinks for these in /usr/bin instead of leaving
+               # the files there in the first place...)
+               local x
+               for x in ${com} uname ; do
+                       dosym ../../bin/${x} /usr/bin/${x}
+               done
+       fi
+}
+
+pkg_postinst() {
+       ewarn "Make sure you run 'hash -r' in your active shells."
+       ewarn "You should also re-source your shell settings for LS_COLORS"
+       ewarn "  changes, such as: source /etc/profile"
+}

diff --git 
a/sys-apps/coreutils/files/coreutils-9.1-fix-rename-simple-backups.patch 
b/sys-apps/coreutils/files/coreutils-9.1-fix-rename-simple-backups.patch
new file mode 100644
index 0000000000..33b5f391ab
--- /dev/null
+++ b/sys-apps/coreutils/files/coreutils-9.1-fix-rename-simple-backups.patch
@@ -0,0 +1,38 @@
+https://src.fedoraproject.org/rpms/coreutils/raw/f672fec4364e71c6e5a30d4026d6bdb7cf332eed/f/gnulib-simple-backup-fix.patch
+https://bugs.gnu.org/55029
+
+commit 7347caeb9d902d3fca2c11f69a55a3e578d93bfe
+Author: Paul Eggert <[email protected]>
+Date:   Wed Apr 20 19:34:57 2022 -0700
+
+    backupfile: fix bug when renaming simple backups
+    
+    * lib/backupfile.c (backupfile_internal): Fix bug when RENAME
+    and when doing simple backups.  Problem reported by Steve Ward in:
+    https://bugs.gnu.org/55029
+
+--- a/lib/backupfile.c
++++ b/lib/backupfile.c
+@@ -332,7 +332,7 @@ backupfile_internal (int dir_fd, char const *file,
+     return s;
+ 
+   DIR *dirp = NULL;
+-  int sdir = AT_FDCWD;
++  int sdir = dir_fd;
+   idx_t base_max = 0;
+   while (true)
+     {
+@@ -371,10 +371,9 @@ backupfile_internal (int dir_fd, char const *file,
+       if (! rename)
+         break;
+ 
+-      int olddirfd = sdir < 0 ? dir_fd : sdir;
+-      idx_t offset = sdir < 0 ? 0 : base_offset;
++      idx_t offset = backup_type == simple_backups ? 0 : base_offset;
+       unsigned flags = backup_type == simple_backups ? 0 : RENAME_NOREPLACE;
+-      if (renameatu (olddirfd, file + offset, sdir, s + offset, flags) == 0)
++      if (renameatu (sdir, file + offset, sdir, s + offset, flags) == 0)
+         break;
+       int e = errno;
+       if (! (e == EEXIST && extended))
+

Reply via email to