diff options
author | Violet Purcell <vimproved@inventati.org> | 2023-05-08 00:34:02 -0400 |
---|---|---|
committer | Sam James <sam@gentoo.org> | 2023-05-08 14:38:03 +0100 |
commit | 6273f7c0c37bc0fae7071ec6237654796bdcca55 (patch) | |
tree | b08964f834aaae9774176b33646bd7350fe61701 /sys-apps/acl/acl-2.3.1-r2.ebuild | |
parent | sys-devel/gcc: add 12.4.9999, drop 12.3.9999 (diff) | |
download | gentoo-6273f7c0c37bc0fae7071ec6237654796bdcca55.tar.gz gentoo-6273f7c0c37bc0fae7071ec6237654796bdcca55.tar.bz2 gentoo-6273f7c0c37bc0fae7071ec6237654796bdcca55.zip |
sys-apps/acl: Fix build with musl 1.2.4
Closes: https://bugs.gentoo.org/905910
Signed-off-by: Violet Purcell <vimproved@inventati.org>
Closes: https://github.com/gentoo/gentoo/pull/30925
Signed-off-by: Sam James <sam@gentoo.org>
Diffstat (limited to 'sys-apps/acl/acl-2.3.1-r2.ebuild')
-rw-r--r-- | sys-apps/acl/acl-2.3.1-r2.ebuild | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/sys-apps/acl/acl-2.3.1-r2.ebuild b/sys-apps/acl/acl-2.3.1-r2.ebuild new file mode 100644 index 000000000000..887d476d910d --- /dev/null +++ b/sys-apps/acl/acl-2.3.1-r2.ebuild @@ -0,0 +1,83 @@ +# Copyright 1999-2023 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=7 + +inherit flag-o-matic libtool multilib-minimal usr-ldscript + +DESCRIPTION="Access control list utilities, libraries, and headers" +HOMEPAGE="https://savannah.nongnu.org/projects/acl" +SRC_URI="mirror://nongnu/${PN}/${P}.tar.xz" + +LICENSE="LGPL-2.1" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~loong ~m68k ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86 ~amd64-linux ~x86-linux" +IUSE="nls static-libs" + +RDEPEND=" + >=sys-apps/attr-2.4.47-r1[${MULTILIB_USEDEP}] +" +DEPEND="${RDEPEND}" +BDEPEND="nls? ( sys-devel/gettext )" + +PATCHES=( + "${FILESDIR}/${PN}-2.3.1-musl-1.2.4-lfs64-fix.patch" +) + +src_prepare() { + default + + # bug #580792 + elibtoolize +} + +multilib_src_configure() { + # Filter out -flto flags as they break getfacl/setfacl binaries + # bug #667372 + filter-flags -flto* + + # Broken with FORTIFY_SOURCE=3 + # Our toolchain sets F_S=2 by default w/ >= -O2, so we need + # to unset F_S first, then explicitly set 2, to negate any default + # and anything set by the user if they're choosing 3 (or if they've + # modified GCC to set 3). + # + # Refs: + # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=104964 + # https://savannah.nongnu.org/bugs/index.php?62519 + # bug #847280 + if is-flagq '-O[23]' || is-flagq '-Ofast' ; then + # We can't unconditionally do this b/c we fortify needs + # some level of optimisation. + filter-flags -D_FORTIFY_SOURCE=3 + append-cppflags -U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=2 + fi + + local myeconfargs=( + --bindir="${EPREFIX}"/bin + $(use_enable static-libs static) + --libexecdir="${EPREFIX}"/usr/$(get_libdir) + $(use_enable nls) + ) + + ECONF_SOURCE="${S}" econf "${myeconfargs[@]}" +} + +multilib_src_test() { + # Tests call native binaries with an LD_PRELOAD wrapper + # bug #772356 + multilib_is_native_abi && default +} + +multilib_src_install() { + default + + # Move shared libs to / + gen_usr_ldscript -a acl +} + +multilib_src_install_all() { + if ! use static-libs ; then + find "${ED}" -type f -name "*.la" -delete || die + fi +} |