| # Copyright 1999-2023 Gentoo Authors |
| # Distributed under the terms of the GNU General Public License v2 |
| |
| EAPI=7 |
| |
| PYTHON_COMPAT=( python3_{6..11} ) |
| |
| inherit toolchain-funcs libtool flag-o-matic bash-completion-r1 usr-ldscript \ |
| pam python-r1 multilib-minimal multiprocessing systemd |
| |
| MY_PV="${PV/_/-}" |
| MY_P="${PN}-${MY_PV}" |
| |
| if [[ ${PV} == 9999 ]] ; then |
| EGIT_REPO_URI="https://git.kernel.org/pub/scm/utils/util-linux/util-linux.git" |
| inherit autotools git-r3 |
| else |
| VERIFY_SIG_OPENPGP_KEY_PATH="${BROOT}"/usr/share/openpgp-keys/karelzak.asc |
| inherit verify-sig |
| |
| if [[ ${PV} != *_rc* ]] ; then |
| KEYWORDS="*" |
| fi |
| |
| SRC_URI="https://www.kernel.org/pub/linux/utils/util-linux/v${PV:0:4}/${MY_P}.tar.xz" |
| SRC_URI+=" verify-sig? ( https://www.kernel.org/pub/linux/utils/util-linux/v${PV:0:4}/${MY_P}.tar.sign )" |
| fi |
| |
| S="${WORKDIR}/${MY_P}" |
| |
| DESCRIPTION="Various useful Linux utilities" |
| HOMEPAGE="https://www.kernel.org/pub/linux/utils/util-linux/ https://github.com/util-linux/util-linux" |
| |
| LICENSE="GPL-2 GPL-3 LGPL-2.1 BSD-4 MIT public-domain" |
| SLOT="0" |
| IUSE="audit build caps +cramfs cryptsetup fdformat +hardlink kill +logger magic ncurses nls pam python +readline rtas selinux slang static-libs +su +suid systemd test tty-helpers udev unicode" |
| |
| # Most lib deps here are related to programs rather than our libs, |
| # so we rarely need to specify ${MULTILIB_USEDEP}. |
| RDEPEND=" |
| virtual/libcrypt:= |
| audit? ( >=sys-process/audit-2.6:= ) |
| caps? ( sys-libs/libcap-ng ) |
| cramfs? ( sys-libs/zlib:= ) |
| cryptsetup? ( >=sys-fs/cryptsetup-2.1.0 ) |
| hardlink? ( dev-libs/libpcre2:= ) |
| ncurses? ( |
| sys-libs/ncurses:=[unicode(+)?] |
| magic? ( sys-apps/file:0= ) |
| ) |
| nls? ( virtual/libintl[${MULTILIB_USEDEP}] ) |
| pam? ( sys-libs/pam ) |
| python? ( ${PYTHON_DEPS} ) |
| readline? ( sys-libs/readline:0= ) |
| rtas? ( sys-libs/librtas ) |
| selinux? ( >=sys-libs/libselinux-2.2.2-r4[${MULTILIB_USEDEP}] ) |
| slang? ( sys-libs/slang ) |
| !build? ( systemd? ( sys-apps/systemd ) ) |
| udev? ( virtual/libudev:= )" |
| BDEPEND=" |
| virtual/pkgconfig |
| nls? ( sys-devel/gettext ) |
| test? ( sys-devel/bc ) |
| " |
| DEPEND=" |
| ${RDEPEND} |
| virtual/os-headers |
| " |
| RDEPEND+=" |
| hardlink? ( !app-arch/hardlink ) |
| logger? ( !>=app-admin/sysklogd-2.0[logger] ) |
| kill? ( |
| !sys-apps/coreutils[kill] |
| !sys-process/procps[kill] |
| ) |
| su? ( |
| !<sys-apps/shadow-4.7-r2 |
| !>=sys-apps/shadow-4.7-r2[su] |
| ) |
| !net-wireless/rfkill |
| " |
| |
| if [[ ${PV} == 9999 ]] ; then |
| # Required for man-page generation |
| BDEPEND+=" dev-ruby/asciidoctor" |
| else |
| BDEPEND+=" verify-sig? ( sec-keys/openpgp-keys-karelzak )" |
| fi |
| |
| REQUIRED_USE="python? ( ${PYTHON_REQUIRED_USE} ) su? ( pam )" |
| RESTRICT="!test? ( test )" |
| |
| PATCHES=( |
| "${FILESDIR}"/CHROMIUM-mount-no-canonicalize.patch # b/194944898: downstream patch |
| "${FILESDIR}"/CHROMIUM-nsenter-nofollow.patch # b/226186172: downstream patch |
| "${FILESDIR}"/CHROMIUM-umount-no-canonicalize.patch # b/226186168: downstream patch |
| "${FILESDIR}"/CHROMIUM-fincore-support-device-files.patch # b/290167919: patch sent upstream. |
| ) |
| |
| pkg_pretend() { |
| if use su && ! use suid ; then |
| elog "su will be installed as suid despite USE=-suid (bug #832092)" |
| elog "To use su without suid, see e.g. Portage's suidctl feature." |
| fi |
| } |
| |
| src_unpack() { |
| if [[ ${PV} == 9999 ]] ; then |
| git-r3_src_unpack |
| return |
| fi |
| |
| if use verify-sig ; then |
| mkdir "${T}"/verify-sig || die |
| pushd "${T}"/verify-sig &>/dev/null || die |
| |
| # Upstream sign the decompressed .tar |
| # Let's do it separately in ${T} then cleanup to avoid external |
| # effects on normal unpack. |
| cp "${DISTDIR}"/${MY_P}.tar.xz . || die |
| xz -d ${MY_P}.tar.xz || die |
| verify-sig_verify_detached ${MY_P}.tar "${DISTDIR}"/${MY_P}.tar.sign |
| |
| popd &>/dev/null || die |
| rm -r "${T}"/verify-sig || die |
| fi |
| |
| default |
| } |
| |
| src_prepare() { |
| default |
| |
| if use test ; then |
| # Prevent uuidd test failure due to socket path limit, bug #593304 |
| sed -i \ |
| -e "s|UUIDD_SOCKET=\"\$(mktemp -u \"\${TS_OUTDIR}/uuiddXXXXXXXXXXXXX\")\"|UUIDD_SOCKET=\"\$(mktemp -u \"${T}/uuiddXXXXXXXXXXXXX.sock\")\"|g" \ |
| tests/ts/uuid/uuidd || die "Failed to fix uuidd test" |
| |
| # Known-failing tests |
| # TODO: investigate these |
| local known_failing_tests=( |
| # Subtest 'options-maximum-size-8192' fails |
| hardlink/options |
| |
| lsfd/mkfds-symlink |
| lsfd/mkfds-rw-character-device |
| ) |
| |
| local known_failing_test |
| for known_failing_test in "${known_failing_tests[@]}" ; do |
| einfo "Removing known-failing test: ${known_failing_test}" |
| rm tests/ts/${known_failing_test} || die |
| done |
| |
| fi |
| |
| if [[ ${PV} == 9999 ]] ; then |
| po/update-potfiles |
| eautoreconf |
| else |
| elibtoolize |
| fi |
| } |
| |
| lfs_fallocate_test() { |
| # Make sure we can use fallocate with LFS, bug #300307 |
| cat <<-EOF > "${T}/fallocate.${ABI}.c" |
| #define _GNU_SOURCE |
| #include <fcntl.h> |
| main() { return fallocate(0, 0, 0, 0); } |
| EOF |
| |
| append-lfs-flags |
| |
| $(tc-getCC) ${CFLAGS} ${CPPFLAGS} ${LDFLAGS} "${T}/fallocate.${ABI}.c" -o /dev/null >/dev/null 2>&1 \ |
| || export ac_cv_func_fallocate=no |
| rm -f "${T}/fallocate.${ABI}.c" |
| } |
| |
| python_configure() { |
| local myeconfargs=( |
| "${commonargs[@]}" |
| --disable-all-programs |
| --disable-bash-completion |
| --without-systemdsystemunitdir |
| --with-python |
| --enable-libblkid |
| --enable-libmount |
| --enable-pylibmount |
| ) |
| |
| mkdir "${BUILD_DIR}" || die |
| pushd "${BUILD_DIR}" >/dev/null || die |
| ECONF_SOURCE="${S}" econf "${myeconfargs[@]}" |
| popd >/dev/null || die |
| } |
| |
| multilib_src_configure() { |
| lfs_fallocate_test |
| |
| # The scanf test in a run-time test which fails while cross-compiling. |
| # Blindly assume a POSIX setup since we require libmount, and libmount |
| # itself fails when the scanf test fails. bug #531856 |
| tc-is-cross-compiler && export scanf_cv_alloc_modifier=ms |
| |
| # bug #485486 |
| export ac_cv_header_security_pam_misc_h=$(multilib_native_usex pam) |
| # bug #545042 |
| export ac_cv_header_security_pam_appl_h=$(multilib_native_usex pam) |
| |
| # Undo bad ncurses handling by upstream. Fall back to pkg-config. |
| # bug #601530 |
| export NCURSES6_CONFIG=false NCURSES5_CONFIG=false |
| export NCURSESW6_CONFIG=false NCURSESW5_CONFIG=false |
| |
| # Avoid automagic dependency on ppc* |
| export ac_cv_lib_rtas_rtas_get_sysparm=$(usex rtas) |
| |
| # configure args shared by python and non-python builds |
| local commonargs=( |
| --enable-fs-paths-extra="${EPREFIX}/usr/sbin:${EPREFIX}/bin:${EPREFIX}/usr/bin" |
| ) |
| |
| local myeconfargs=( |
| "${commonargs[@]}" |
| --with-bashcompletiondir="$(get_bashcompdir)" |
| --without-python |
| $(multilib_native_use_enable suid makeinstall-chown) |
| $(multilib_native_use_enable suid makeinstall-setuid) |
| $(multilib_native_use_with readline) |
| $(multilib_native_use_with slang) |
| $(multilib_native_use_with systemd) |
| $(multilib_native_use_with udev) |
| $(multilib_native_usex ncurses "$(use_with magic libmagic)" '--without-libmagic') |
| $(multilib_native_usex ncurses "$(use_with unicode ncursesw)" '--without-ncursesw') |
| $(multilib_native_usex ncurses "$(use_with !unicode ncurses)" '--without-ncurses') |
| $(multilib_native_use_with audit) |
| $(tc-has-tls || echo --disable-tls) |
| $(use_enable nls) |
| $(use_enable unicode widechar) |
| $(use_enable static-libs static) |
| $(use_with ncurses tinfo) |
| $(use_with selinux) |
| ) |
| |
| if multilib_is_native_abi ; then |
| myeconfargs+=( |
| --disable-chfn-chsh |
| --disable-login |
| --disable-newgrp |
| --disable-nologin |
| --disable-pylibmount |
| --disable-raw |
| --disable-vipw |
| --enable-agetty |
| --enable-bash-completion |
| --enable-line |
| --enable-partx |
| --enable-rename |
| --enable-rfkill |
| --enable-schedutils |
| --with-systemdsystemunitdir="$(systemd_get_systemunitdir)" |
| $(use_enable caps setpriv) |
| $(use_enable cramfs) |
| $(use_enable fdformat) |
| $(use_enable hardlink) |
| $(use_enable kill) |
| $(use_enable logger) |
| $(use_enable ncurses pg) |
| $(use_enable su) |
| $(use_enable tty-helpers mesg) |
| $(use_enable tty-helpers wall) |
| $(use_enable tty-helpers write) |
| $(use_with cryptsetup) |
| ) |
| if [[ ${PV} == *9999 ]] ; then |
| myeconfargs+=( --enable-asciidoc ) |
| else |
| # Upstream is shipping pre-generated man-pages for releases |
| myeconfargs+=( --disable-asciidoc ) |
| fi |
| else |
| myeconfargs+=( |
| --disable-all-programs |
| --disable-asciidoc |
| --disable-bash-completion |
| --without-systemdsystemunitdir |
| |
| # build libraries |
| --enable-libuuid |
| --enable-libblkid |
| --enable-libsmartcols |
| --enable-libfdisk |
| --enable-libmount |
| ) |
| fi |
| |
| ECONF_SOURCE="${S}" econf "${myeconfargs[@]}" |
| |
| if multilib_is_native_abi && use python ; then |
| python_foreach_impl python_configure |
| fi |
| } |
| |
| python_compile() { |
| pushd "${BUILD_DIR}" >/dev/null || die |
| emake all |
| popd >/dev/null || die |
| } |
| |
| multilib_src_compile() { |
| emake all |
| |
| if multilib_is_native_abi && use python ; then |
| python_foreach_impl python_compile |
| fi |
| } |
| |
| python_test() { |
| pushd "${BUILD_DIR}" >/dev/null || die |
| emake check TS_OPTS="--parallel=$(makeopts_jobs) --nonroot" |
| popd >/dev/null || die |
| } |
| |
| multilib_src_test() { |
| emake check TS_OPTS="--parallel=$(makeopts_jobs) --nonroot" |
| if multilib_is_native_abi && use python ; then |
| python_foreach_impl python_test |
| fi |
| } |
| |
| python_install() { |
| pushd "${BUILD_DIR}" >/dev/null || die |
| emake DESTDIR="${D}" install |
| python_optimize |
| popd >/dev/null || die |
| } |
| |
| multilib_src_install() { |
| if multilib_is_native_abi && use python ; then |
| python_foreach_impl python_install |
| fi |
| |
| # This needs to be called AFTER python_install call, bug #689190 |
| emake DESTDIR="${D}" install |
| |
| if multilib_is_native_abi ; then |
| # Need the libs in / |
| gen_usr_ldscript -a blkid fdisk mount smartcols uuid |
| fi |
| } |
| |
| multilib_src_install_all() { |
| dodoc AUTHORS NEWS README* Documentation/{TODO,*.txt,releases/*} |
| |
| # e2fsprogs-libs didn't install .la files, and .pc work fine |
| find "${ED}" -name "*.la" -delete || die |
| |
| if use pam ; then |
| # See https://github.com/util-linux/util-linux/blob/master/Documentation/PAM-configuration.txt |
| newpamd "${FILESDIR}/runuser.pamd" runuser |
| newpamd "${FILESDIR}/runuser-l.pamd" runuser-l |
| |
| newpamd "${FILESDIR}/su-l.pamd" su-l |
| fi |
| |
| if use su && ! use suid ; then |
| # Always force suid su, even when USE=-suid, as su is useless |
| # for the overwhelming-majority case without suid. |
| # Users who wish to truly have a no-suid su can strip it out |
| # via e.g. Portage's suidctl or some other hook. |
| # See bug #832092 |
| fperms u+s /bin/su |
| fi |
| |
| # Note: |
| # Bash completion for "runuser" command is provided by same file which |
| # would also provide bash completion for "su" command. However, we don't |
| # use "su" command from this package. |
| # This triggers a known QA warning which we ignore for now to magically |
| # keep bash completion for "su" command which shadow package does not |
| # provide. |
| |
| local ver=$(tools/git-version-gen .tarballversion) |
| local major=$(ver_cut 1 ${ver}) |
| local minor=$(ver_cut 2 ${ver}) |
| local release=$(ver_cut 3 ${ver}) |
| export QA_PKGCONFIG_VERSION="${major}.${minor}.${release:-0}" |
| } |
| |
| pkg_postinst() { |
| if ! use tty-helpers ; then |
| elog "The mesg/wall/write tools have been disabled due to USE=-tty-helpers." |
| fi |
| |
| if [[ -z ${REPLACING_VERSIONS} ]] ; then |
| elog "The agetty util now clears the terminal by default. You" |
| elog "might want to add --noclear to your /etc/inittab lines." |
| fi |
| } |