commit:     261359213e88e955ee307d44f2acdb08cf7a45d6
Author:     Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 22 20:22:43 2024 +0000
Commit:     Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
CommitDate: Thu Aug 22 20:23:28 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=26135921

sys-libs/binutils-libs: add 2.43-r1, patchlevel 2, identical to upstream 2.43.1

Signed-off-by: Andreas K. Hüttel <dilfridge <AT> gentoo.org>

 sys-libs/binutils-libs/Manifest                    |   1 +
 .../binutils-libs/binutils-libs-2.43-r1.ebuild     | 172 +++++++++++++++++++++
 2 files changed, 173 insertions(+)

diff --git a/sys-libs/binutils-libs/Manifest b/sys-libs/binutils-libs/Manifest
index 369104ad39c9..50140aa1f072 100644
--- a/sys-libs/binutils-libs/Manifest
+++ b/sys-libs/binutils-libs/Manifest
@@ -18,4 +18,5 @@ DIST binutils-2.42-patches-3.tar.xz 34768 BLAKE2B 
e4bfaf3b42147408a8a3dcb00f5037
 DIST binutils-2.42-patches-6.tar.xz 50664 BLAKE2B 
f13b65a761cfba80caf2e4740c6383b40305558365b950fba22aca95a104e799e8bd476082f36fb9288de4f224b09f317792c1444e549c40d15a4b64cdf61989
 SHA512 
1203eca0a9e622411eac377509de8fd0db3ffcb282ac38ab7a0369b166cc1091197daad85b51b145b34a4832f1a1a4d573c8254e8d67aeb22f35adb1ab3ece1f
 DIST binutils-2.42.tar.xz 27567160 BLAKE2B 
e67a5c028fba70e70088fd11b38ec8c9c4ed5a019badefda25abeb6275997b16f0891e7ff3424c4b82bbfae92e8992669826920dd53df61cd48469d8f7cd5bd1
 SHA512 
155f3ba14cd220102f4f29a4f1e5cfee3c48aa03b74603460d05afb73c70d6657a9d87eee6eb88bf13203fe6f31177a5c9addc04384e956e7da8069c8ecd20a6
 DIST binutils-2.43-patches-1.tar.xz 11644 BLAKE2B 
578ee67c3c5e67f9191a31a5c83ffcc781f757f8aaee3eea14d052db427cdd2bc769977dba16e9a8c653dcc4a94f11c149898683945d5035d0beeac128045b1a
 SHA512 
e6db4eaf4fbea366e607a7e9a56e20851fcc34664532fd6aa1f0818271c3e2687eada3daca482e211a2b3e36be85e7e0b23158caaa0fdf9785d13a9156e8c734
+DIST binutils-2.43-patches-2.tar.xz 35184 BLAKE2B 
fa35c9f182c7ae0fed28614f47618d1563a58f223fd1805f348b618c1fbf039a444e44d88f46d040b6971e481e0da882e5c4492fd167d17bf39579d87a446434
 SHA512 
a7e167d3f6a2c08f19af4685d90a6160a1a52f1a87f5660fb6d80ec664033829c0eacad0d77b1306620e50ff89d1f9f63a7c2b064ad9775400f0cb0eba3159a4
 DIST binutils-2.43.tar.xz 28175768 BLAKE2B 
28b0a04a28273b76eab2d00e00160be889f155f77f5a9d8759ef8dce505c97e97641bf7ec70b92b731b520570a02b06e04e8215b068fcb1bb2573e9ef24732d9
 SHA512 
93e063163e54d6a6ee2bd48dc754270bf757a3635b49a702ed6b310e929e94063958512d191e66beaf44275f7ea60865dbde138b624626739679fcc306b133bb

diff --git a/sys-libs/binutils-libs/binutils-libs-2.43-r1.ebuild 
b/sys-libs/binutils-libs/binutils-libs-2.43-r1.ebuild
new file mode 100644
index 000000000000..60d4f05a620c
--- /dev/null
+++ b/sys-libs/binutils-libs/binutils-libs-2.43-r1.ebuild
@@ -0,0 +1,172 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+PATCH_VER=2
+PATCH_DEV=dilfridge
+
+inherit flag-o-matic libtool toolchain-funcs multilib-minimal
+
+MY_PN="binutils"
+MY_P="${MY_PN}-${PV}"
+PATCH_BINUTILS_VER=${PATCH_BINUTILS_VER:-${PV}}
+PATCH_DEV=${PATCH_DEV:-dilfridge}
+
+DESCRIPTION="Core binutils libraries (libbfd, libopcodes, libiberty) for 
external packages"
+HOMEPAGE="https://sourceware.org/binutils/";
+SRC_URI="mirror://gnu/binutils/${MY_P}.tar.xz
+       https://dev.gentoo.org/~${PATCH_DEV}/distfiles/${MY_P}.tar.xz
+       
https://dev.gentoo.org/~${PATCH_DEV}/distfiles/${MY_PN}-${PATCH_BINUTILS_VER}-patches-${PATCH_VER}.tar.xz";
+
+LICENSE="|| ( GPL-3 LGPL-3 )"
+
+SLOT="0/${PV%_p?}.0"
+
+IUSE="64-bit-bfd cet multitarget nls static-libs test"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~loong ~m68k ~mips ~ppc ~ppc64 
~riscv ~s390 ~sparc ~x86 ~arm64-macos ~x64-macos ~x64-solaris"
+RESTRICT="!test? ( test )"
+
+BDEPEND="
+       nls? ( sys-devel/gettext )
+       test? ( dev-util/dejagnu )
+"
+DEPEND="sys-libs/zlib[${MULTILIB_USEDEP}]"
+# Need a newer binutils-config that'll reset include/lib symlinks for us.
+RDEPEND="${DEPEND}
+       >=sys-devel/binutils-config-5
+"
+
+S="${WORKDIR}/${MY_P%_p?}"
+
+MULTILIB_WRAPPED_HEADERS=(
+       /usr/include/bfd.h
+)
+
+src_prepare() {
+       if [[ -n ${PATCH_VER} ]] ; then
+               einfo "Applying binutils-${PATCH_BINUTILS_VER} patchset 
${PATCH_VER}"
+               eapply "${WORKDIR}/patch"/*.patch
+       fi
+
+       # Fix cross-compile relinking issue, bug #626402
+       elibtoolize
+
+       if [[ ${CHOST} == *-darwin* ]] ; then
+               # somehow libtool/configure is messed up and (custom patch at
+               # upstream?) and misdetects (basically assumes) nm can be called
+               # with -B arg -- can't run eautoreconf (fails), so patch up
+               # manually, this would break any target that needs -B to nm
+               sed -i -e 's/lt_cv_path_NM="$tmp_nm 
-B"/lt_cv_path_NM="$tmp_nm"/' \
+                       libctf/configure || die
+       fi
+
+       # See 
https://www.gnu.org/software/make/manual/html_node/Parallel-Output.html
+       # Avoid really confusing logs from subconfigure spam, makes logs far
+       # more legible.
+       export MAKEOPTS="--output-sync=line ${MAKEOPTS}"
+
+       default
+}
+
+pkgversion() {
+       printf "Gentoo ${PVR}"
+       [[ -n ${PATCHVER} ]] && printf " p${PATCHVER}"
+}
+
+multilib_src_configure() {
+       filter-lto
+
+       # Workaround for lld-17 (bug #914640)
+       # Should be able to drop this w/ >=binutils-2.43
+       append-ldflags $(test-flags-CCLD -Wl,--undefined-version)
+
+       local myconf=(
+               # portage's econf() does not detect presence of --d-d-t
+               # because it greps only top-level ./configure. But not
+               # libiberty's or bfd's configure.
+               --disable-dependency-tracking
+               --disable-silent-rules
+               --enable-obsolete
+               --enable-shared
+               --enable-threads
+               # Newer versions (>=2.24) make this an explicit option. #497268
+               --enable-install-libiberty
+               --disable-werror
+               --with-bugurl="https://bugs.gentoo.org/";
+               --with-pkgversion="$(pkgversion)"
+               $(use_enable static-libs static)
+               # The binutils eclass enables this flag for all bi-arch builds,
+               # but other tools often don't care about that support.  Put it
+               # beyond a flag if people really want it, but otherwise leave
+               # it disabled as it can slow things down on 32bit arches. 
#438522
+               $(use_enable 64-bit-bfd)
+               # This only disables building in the zlib subdir.
+               # For binutils itself, it'll use the system version. #591516
+               --without-zlib
+               --with-system-zlib
+               # We only care about the libs, so disable programs. #528088
+               --disable-{binutils,etc,ld,gas,gold,gprof,gprofng}
+               # Disable modules that are in a combined binutils/gdb tree. 
#490566
+               --disable-{gdb,libdecnumber,readline,sim}
+               # Strip out broken static link flags.
+               # https://gcc.gnu.org/PR56750
+               --without-stage1-ldflags
+               # We pull in all USE-flags that change ABI in an incompatible
+               # way. #666100
+               # USE=multitarget change size of global arrays
+               # USE=64-bit-bfd changes data structures of exported API
+               --with-extra-soversion-suffix=gentoo-${CATEGORY}-${PN}-$(usex 
multitarget mt st)-$(usex 64-bit-bfd 64 def)
+
+               # avoid automagic dependency on (currently prefix) systems
+               # systems with debuginfod library, bug #754753
+               --without-debuginfod
+
+               # Revisit if it's useful, we do have binutils[zstd] though
+               --without-zstd
+
+               # Allow user to opt into CET for host libraries.
+               # Ideally we would like automagic-or-disabled here.
+               # But the check does not quite work on i686: bug #760926.
+               $(use_enable cet)
+       )
+
+       # mips can't do hash-style=gnu ...
+       if [[ $(tc-arch) != mips ]] ; then
+               myconf+=( --enable-default-hash-style=gnu )
+       fi
+
+       use multitarget && myconf+=( --enable-targets=all --enable-64-bit-bfd )
+
+       use nls \
+               && myconf+=( --without-included-gettext ) \
+               || myconf+=( --disable-nls )
+
+       if [[ ${CHOST} == *-darwin* ]] && use nls ; then
+               # fix underlinking in opcodes
+               sed -i -e 's/@SHARED_LDFLAGS@/@SHARED_LDFLAGS@ -lintl/' \
+                       "${S}"/opcodes/Makefile.in || die
+       fi
+
+       ECONF_SOURCE="${S}" econf "${myconf[@]}"
+
+       # Prevent makeinfo from running as we don't build docs here.
+       # bug #622652
+       sed -i \
+               -e '/^MAKEINFO/s:=.*:= true:' \
+               Makefile || die
+}
+
+multilib_src_install() {
+       emake DESTDIR="${D}" install
+
+       # Provided by dev-debug/gdb instead
+       rm "${ED}"/usr/share/info/sframe-spec.info || die
+
+       # Provide libiberty.h directly.
+       dosym libiberty/libiberty.h /usr/include/libiberty.h
+}
+
+multilib_src_install_all() {
+       use static-libs || find "${ED}"/usr -name '*.la' -delete
+}

Reply via email to