# Copyright 1999-2021 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 EAPI=7 PYTHON_COMPAT=( python3_{8..10} ) inherit 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 )" LICENSE="GPL-3" SLOT="0" KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86 ~x86-linux" IUSE="acl caps gmp hostname kill multicall nls 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] ) 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} ) " RDEPEND+=" hostname? ( !sys-apps/net-tools[hostname] ) kill? ( !sys-apps/util-linux[kill] !sys-process/procps[kill] ) !app-misc/realpath ! 2.1.1-r3 kmodv="${kmodv//zfs-kmod-}" kmodv="${kmodv%%-gentoo}" minver="$(ver_cut 2 ${kmodv})" local diemsg=$(cat <<-EOF Attempted installation of ${P} on unsupported version of zfs-kmod! Please reboot to a newer version of zfs-kmod first: zfs-kmod >=2.0.7 or zfs-kmod >=2.1.1-r3 Using ${P} with running version of zfs-kmod of can lead to data loss while using cp command on some configurations. See https://github.com/openzfs/zfs/issues/11900 for details. EOF ) case "${minver}" in # 2.0.x 0) ver_test "${kmodv}" -lt 2.0.7 && die "${diemsg}" ;; # 2.1.x 1) ver_test "${kmodv}" -lt 2.1.1-r3 && die "${diemsg}" ;; # 0.8.x/9999 *) # We can't really cover this case realistically # 9999 is too hard to check and 0.8.x isn't being supported anymore. ;; esac fi } pkg_setup() { if use test ; then python-any-r1_pkg_setup fi } src_prepare() { local PATCHES=( ) if ! use vanilla ; then PATCHES+=( "${WORKDIR}"/patch ) PATCHES+=( "${FILESDIR}"/${PN}-8.32-sandbox-env-test.patch ) fi default # 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) ) 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 -j1 -k check } 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" }