Gentoo Archives: gentoo-commits

From: "Andreas K. Hüttel" <dilfridge@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: sys-devel/binutils/
Date: Tue, 20 Apr 2021 18:39:52
Message-Id: 1618943966.b1dc606b720fdf2ae0c0f1eab93db77704a34ef4.dilfridge@gentoo
1 commit: b1dc606b720fdf2ae0c0f1eab93db77704a34ef4
2 Author: Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
3 AuthorDate: Tue Apr 20 18:32:35 2021 +0000
4 Commit: Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
5 CommitDate: Tue Apr 20 18:39:26 2021 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b1dc606b
7
8 sys-devel/binutils: remove old
9
10 Package-Manager: Portage-3.0.17, Repoman-3.0.2
11 Signed-off-by: Andreas K. Hüttel <dilfridge <AT> gentoo.org>
12
13 sys-devel/binutils/Manifest | 1 -
14 sys-devel/binutils/binutils-2.36.1.ebuild | 450 ------------------------------
15 2 files changed, 451 deletions(-)
16
17 diff --git a/sys-devel/binutils/Manifest b/sys-devel/binutils/Manifest
18 index c54f502fda4..6db5ab7b318 100644
19 --- a/sys-devel/binutils/Manifest
20 +++ b/sys-devel/binutils/Manifest
21 @@ -7,6 +7,5 @@ DIST binutils-2.34-patches-6.tar.xz 103028 BLAKE2B d0e866d0941d2b550c7d7f23530c6
22 DIST binutils-2.34.tar.xz 21637796 BLAKE2B 07dd23916a7d27f71c3f160c8c16abe2bd4fce294c738c665a012a3be6a87dbe8160d0c38740524f9025e01d438e99b2a94bcf9f9f79ee214f5dd033de8aad3d SHA512 2c7976939dcf5e8c5b7374cccd39bfe803b1bec73c6abfa0eb17c24e1942574c6bdb874c66a092a82adc443182eacd8a5a8001c19a76101f0c7ba40c27de0bbd
23 DIST binutils-2.35.2-patches-1.tar.xz 11836 BLAKE2B 0141349c9618992d1ab1e0309f7ed8fbc43b60a58be1dfed05eae8a8fee857241d9e112ae673da6fc9778767675f536ece818cb85567367bb1c8f87a0693623f SHA512 35de5f227c745c5fb800784fe657b2a6216faf43e2498e8481e7b0dc79b0d2f86b3b6a10b896e060319a77a51c61d2e1b7a951ae962b3a6ef8c1a2a261d9bb6c
24 DIST binutils-2.35.2.tar.xz 22056908 BLAKE2B 9c392e0db2b482442f9476f30bd80cf2796321cbf7be79cf21af7bef167b6074c4ae009dcf9b438d2f2f4a23381c935176b2cfa85de1a526ab46e0fd844a7ca5 SHA512 9974ede5978d32e0d68fef23da48fa00bd06b0bff7ec45b00ca075c126d6bbe0cf2defc03ecc3f17bc6cc85b64271a13009c4049d7ba17de26e84e3a6e2c0348
25 -DIST binutils-2.36.1-patches-1.tar.xz 11392 BLAKE2B 8112dda3f000d29952cbf58101f842ca519054bf9de6e22908881fe4d46cc1ea9a26db74ab00c64aedd3746eb058c19a978b8dc025ad8de07b6365c70a1803b2 SHA512 c6f5645b09d0c149f2eef8e992ff7181716dfb961f1155207a1349168f2d2fb76857cc224c27b4d764cfbc4ddec0630ef8c0a91d7bac489896f28de64651b367
26 DIST binutils-2.36.1-patches-3.tar.xz 32720 BLAKE2B 2a5a60168ec5ff612e7e58530092f306460cdb4a963320978dffcc22d73684486a14a5981f6eab2f7fc270def22cdc9954de455d680b2de4befc1ad4916347ba SHA512 e429cc82451675f14715d4e7640fe7b995495c8759a8e919c4291f8ca8358a663012f05c1ec6e60b1261114848379fefc9df723929770462dd676fa04fc7aa54
27 DIST binutils-2.36.1.tar.xz 22772248 BLAKE2B 03fbfbedd6dba2beaa836b1ed254eddd7a54a163d3061fd93edd2b9591cae24ba049b26658c524b5ccecc2f22d431dfa168218d2531aa356945c994fbbe896fa SHA512 cc24590bcead10b90763386b6f96bb027d7594c659c2d95174a6352e8b98465a50ec3e4088d0da038428abe059bbc4ae5f37b269f31a40fc048072c8a234f4e9
28
29 diff --git a/sys-devel/binutils/binutils-2.36.1.ebuild b/sys-devel/binutils/binutils-2.36.1.ebuild
30 deleted file mode 100644
31 index 215e42f2c73..00000000000
32 --- a/sys-devel/binutils/binutils-2.36.1.ebuild
33 +++ /dev/null
34 @@ -1,450 +0,0 @@
35 -# Copyright 1999-2021 Gentoo Authors
36 -# Distributed under the terms of the GNU General Public License v2
37 -
38 -EAPI=7
39 -
40 -inherit eutils libtool flag-o-matic gnuconfig multilib toolchain-funcs
41 -
42 -DESCRIPTION="Tools necessary to build programs"
43 -HOMEPAGE="https://sourceware.org/binutils/"
44 -LICENSE="GPL-3+"
45 -IUSE="cet default-gold doc +gold multitarget +nls +plugins static-libs test vanilla"
46 -REQUIRED_USE="default-gold? ( gold )"
47 -
48 -# Variables that can be set here (ignored for live ebuilds)
49 -# PATCH_VER - the patchset version
50 -# Default: empty, no patching
51 -# PATCH_BINUTILS_VER - the binutils version in the patchset name
52 -# - Default: PV
53 -# PATCH_DEV - Use download URI https://dev.gentoo.org/~{PATCH_DEV}/distfiles/...
54 -# for the patchsets
55 -
56 -PATCH_VER=1
57 -PATCH_DEV=dilfridge
58 -
59 -if [[ ${PV} == 9999* ]]; then
60 - inherit git-r3
61 - SLOT=${PV}
62 -else
63 - PATCH_BINUTILS_VER=${PATCH_BINUTILS_VER:-${PV}}
64 - PATCH_DEV=${PATCH_DEV:-slyfox}
65 - SRC_URI="mirror://gnu/binutils/binutils-${PV}.tar.xz"
66 - [[ -z ${PATCH_VER} ]] || SRC_URI="${SRC_URI}
67 - https://dev.gentoo.org/~${PATCH_DEV}/distfiles/binutils-${PATCH_BINUTILS_VER}-patches-${PATCH_VER}.tar.xz"
68 - SLOT=$(ver_cut 1-2)
69 - KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86"
70 -fi
71 -
72 -#
73 -# The cross-compile logic
74 -#
75 -export CTARGET=${CTARGET:-${CHOST}}
76 -if [[ ${CTARGET} == ${CHOST} ]] ; then
77 - if [[ ${CATEGORY} == cross-* ]] ; then
78 - export CTARGET=${CATEGORY#cross-}
79 - fi
80 -fi
81 -is_cross() { [[ ${CHOST} != ${CTARGET} ]] ; }
82 -
83 -#
84 -# The dependencies
85 -#
86 -RDEPEND="
87 - >=sys-devel/binutils-config-3
88 - sys-libs/zlib
89 -"
90 -DEPEND="${RDEPEND}"
91 -BDEPEND="
92 - doc? ( sys-apps/texinfo )
93 - test? (
94 - dev-util/dejagnu
95 - sys-devel/bc
96 - )
97 - nls? ( sys-devel/gettext )
98 - sys-devel/flex
99 - virtual/yacc
100 -"
101 -
102 -RESTRICT="!test? ( test )"
103 -
104 -PATCHES=("${FILESDIR}"/${PN}-2.35.1-cet.patch)
105 -
106 -MY_BUILDDIR=${WORKDIR}/build
107 -
108 -src_unpack() {
109 - if [[ ${PV} == 9999* ]] ; then
110 - EGIT_REPO_URI="https://anongit.gentoo.org/git/proj/toolchain/binutils-patches.git"
111 - EGIT_CHECKOUT_DIR=${WORKDIR}/patches-git
112 - git-r3_src_unpack
113 - mv patches-git/9999 patch || die
114 -
115 - EGIT_REPO_URI="https://sourceware.org/git/binutils-gdb.git"
116 - S=${WORKDIR}/binutils
117 - EGIT_CHECKOUT_DIR=${S}
118 - git-r3_src_unpack
119 - else
120 - unpack ${P}.tar.xz
121 -
122 - cd "${WORKDIR}" || die
123 - unpack binutils-${PATCH_BINUTILS_VER}-patches-${PATCH_VER}.tar.xz
124 - fi
125 -
126 - cd "${WORKDIR}" || die
127 - mkdir -p "${MY_BUILDDIR}" || die
128 -}
129 -
130 -src_prepare() {
131 - local patchsetname
132 - if [[ ${PV} == 9999* ]] ; then
133 - patchsetname="from git master"
134 - else
135 - patchsetname="${PATCH_BINUTILS_VER}-${PATCH_VER}"
136 - fi
137 -
138 - if [[ ! -z ${PATCH_VER} ]] || [[ ${PV} == 9999* ]] ; then
139 - if ! use vanilla; then
140 - einfo "Applying binutils patchset ${patchsetname}"
141 - eapply "${WORKDIR}/patch"
142 - einfo "Done."
143 - fi
144 - fi
145 -
146 - # This check should probably go somewhere else, like pkg_pretend.
147 - if [[ ${CTARGET} == *-uclibc* ]] ; then
148 - if grep -qs 'linux-gnu' "${S}"/ltconfig ; then
149 - die "sorry, but this binutils doesn't yet support uClibc :("
150 - fi
151 - fi
152 -
153 - # Make sure our explicit libdir paths don't get clobbered. #562460
154 - sed -i \
155 - -e 's:@bfdlibdir@:@libdir@:g' \
156 - -e 's:@bfdincludedir@:@includedir@:g' \
157 - {bfd,opcodes}/Makefile.in || die
158 -
159 - # Fix locale issues if possible #122216
160 - if [[ -e ${FILESDIR}/binutils-configure-LANG.patch ]] ; then
161 - einfo "Fixing misc issues in configure files"
162 - for f in $(find "${S}" -name configure -exec grep -l 'autoconf version 2.13' {} +) ; do
163 - ebegin " Updating ${f/${S}\/}"
164 - patch "${f}" "${FILESDIR}"/binutils-configure-LANG.patch >& "${T}"/configure-patch.log \
165 - || eerror "Please file a bug about this"
166 - eend $?
167 - done
168 - fi
169 -
170 - # Fix conflicts with newer glibc #272594
171 - if [[ -e libiberty/testsuite/test-demangle.c ]] ; then
172 - sed -i 's:\<getline\>:get_line:g' libiberty/testsuite/test-demangle.c
173 - fi
174 -
175 - # Apply things from PATCHES and user dirs
176 - default
177 -
178 - # Run misc portage update scripts
179 - gnuconfig_update
180 - elibtoolize --portage --no-uclibc
181 -}
182 -
183 -toolchain-binutils_bugurl() {
184 - printf "https://bugs.gentoo.org/"
185 -}
186 -toolchain-binutils_pkgversion() {
187 - printf "Gentoo ${PV}"
188 - [[ -n ${PATCH_VER} ]] && printf " p${PATCH_VER}"
189 -}
190 -
191 -src_configure() {
192 - # Setup some paths
193 - LIBPATH=/usr/$(get_libdir)/binutils/${CTARGET}/${PV}
194 - INCPATH=${LIBPATH}/include
195 - DATAPATH=/usr/share/binutils-data/${CTARGET}/${PV}
196 - if is_cross ; then
197 - TOOLPATH=/usr/${CHOST}/${CTARGET}
198 - else
199 - TOOLPATH=/usr/${CTARGET}
200 - fi
201 - BINPATH=${TOOLPATH}/binutils-bin/${PV}
202 -
203 - # Make sure we filter $LINGUAS so that only ones that
204 - # actually work make it through #42033
205 - strip-linguas -u */po
206 -
207 - # Keep things sane
208 - strip-flags
209 -
210 - local x
211 - echo
212 - for x in CATEGORY CBUILD CHOST CTARGET CFLAGS LDFLAGS ; do
213 - einfo "$(printf '%10s' ${x}:) ${!x}"
214 - done
215 - echo
216 -
217 - cd "${MY_BUILDDIR}"
218 - local myconf=()
219 -
220 - if use plugins ; then
221 - myconf+=( --enable-plugins )
222 - fi
223 - # enable gold (installed as ld.gold) and ld's plugin architecture
224 - if use gold ; then
225 - myconf+=( --enable-gold )
226 - if use default-gold; then
227 - myconf+=( --enable-gold=default )
228 - fi
229 - fi
230 -
231 - if use nls ; then
232 - myconf+=( --without-included-gettext )
233 - else
234 - myconf+=( --disable-nls )
235 - fi
236 -
237 - myconf+=( --with-system-zlib )
238 -
239 - # For bi-arch systems, enable a 64bit bfd. This matches
240 - # the bi-arch logic in toolchain.eclass. #446946
241 - # We used to do it for everyone, but it's slow on 32bit arches. #438522
242 - case $(tc-arch) in
243 - ppc|sparc|x86) myconf+=( --enable-64-bit-bfd ) ;;
244 - esac
245 -
246 - use multitarget && myconf+=( --enable-targets=all --enable-64-bit-bfd )
247 -
248 - [[ -n ${CBUILD} ]] && myconf+=( --build=${CBUILD} )
249 -
250 - is_cross && myconf+=(
251 - --with-sysroot="${EPREFIX}"/usr/${CTARGET}
252 - --enable-poison-system-directories
253 - )
254 -
255 - # glibc-2.3.6 lacks support for this ... so rather than force glibc-2.5+
256 - # on everyone in alpha (for now), we'll just enable it when possible
257 - has_version ">=${CATEGORY}/glibc-2.5" && myconf+=( --enable-secureplt )
258 - has_version ">=sys-libs/glibc-2.5" && myconf+=( --enable-secureplt )
259 -
260 - # mips can't do hash-style=gnu ...
261 - if [[ $(tc-arch) != mips ]] ; then
262 - myconf+=( --enable-default-hash-style=gnu )
263 - fi
264 -
265 - myconf+=(
266 - --prefix="${EPREFIX}"/usr
267 - --host=${CHOST}
268 - --target=${CTARGET}
269 - --datadir="${EPREFIX}"${DATAPATH}
270 - --datarootdir="${EPREFIX}"${DATAPATH}
271 - --infodir="${EPREFIX}"${DATAPATH}/info
272 - --mandir="${EPREFIX}"${DATAPATH}/man
273 - --bindir="${EPREFIX}"${BINPATH}
274 - --libdir="${EPREFIX}"${LIBPATH}
275 - --libexecdir="${EPREFIX}"${LIBPATH}
276 - --includedir="${EPREFIX}"${INCPATH}
277 - --enable-obsolete
278 - --enable-shared
279 - --enable-threads
280 - # Newer versions (>=2.27) offer a configure flag now.
281 - --enable-relro
282 - # Newer versions (>=2.24) make this an explicit option. #497268
283 - --enable-install-libiberty
284 - # Available from 2.35 on
285 - --enable-textrel-check=warning
286 - --disable-werror
287 - --with-bugurl="$(toolchain-binutils_bugurl)"
288 - --with-pkgversion="$(toolchain-binutils_pkgversion)"
289 - $(use_enable static-libs static)
290 - ${EXTRA_ECONF}
291 - # Disable modules that are in a combined binutils/gdb tree. #490566
292 - --disable-{gdb,libdecnumber,readline,sim}
293 - # Strip out broken static link flags.
294 - # https://gcc.gnu.org/PR56750
295 - --without-stage1-ldflags
296 - # Change SONAME to avoid conflict across
297 - # {native,cross}/binutils, binutils-libs. #666100
298 - --with-extra-soversion-suffix=gentoo-${CATEGORY}-${PN}-$(usex multitarget mt st)
299 -
300 - # avoid automagic dependency on (currently prefix) systems
301 - # systems with debuginfod library, bug #754753
302 - --without-debuginfod
303 -
304 - # Allow user to opt into CET for host libraries.
305 - # Ideally we would like automagic-or-disabled here.
306 - # But the check does not quite work on i686: bug #760926.
307 - $(use_enable cet)
308 - )
309 - echo ./configure "${myconf[@]}"
310 - "${S}"/configure "${myconf[@]}" || die
311 -
312 - # Prevent makeinfo from running if doc is unset.
313 - if ! use doc ; then
314 - sed -i \
315 - -e '/^MAKEINFO/s:=.*:= true:' \
316 - Makefile || die
317 - fi
318 -}
319 -
320 -src_compile() {
321 - cd "${MY_BUILDDIR}"
322 - # see Note [tooldir hack for ldscripts]
323 - emake tooldir="${EPREFIX}${TOOLPATH}" all
324 -
325 - # only build info pages if the user wants them
326 - if use doc ; then
327 - emake info
328 - fi
329 -
330 - # we nuke the manpages when we're left with junk
331 - # (like when we bootstrap, no perl -> no manpages)
332 - find . -name '*.1' -a -size 0 -delete
333 -}
334 -
335 -src_test() {
336 - cd "${MY_BUILDDIR}"
337 -
338 - # bug 637066
339 - filter-flags -Wall -Wreturn-type
340 -
341 - emake -k check
342 -}
343 -
344 -src_install() {
345 - local x d
346 -
347 - cd "${MY_BUILDDIR}"
348 - # see Note [tooldir hack for ldscripts]
349 - emake DESTDIR="${D}" tooldir="${EPREFIX}${LIBPATH}" install
350 - rm -rf "${ED}"/${LIBPATH}/bin
351 - use static-libs || find "${ED}" -name '*.la' -delete
352 -
353 - # Newer versions of binutils get fancy with ${LIBPATH} #171905
354 - cd "${ED}"/${LIBPATH}
355 - for d in ../* ; do
356 - [[ ${d} == ../${PV} ]] && continue
357 - mv ${d}/* . || die
358 - rmdir ${d} || die
359 - done
360 -
361 - # Now we collect everything intp the proper SLOT-ed dirs
362 - # When something is built to cross-compile, it installs into
363 - # /usr/$CHOST/ by default ... we have to 'fix' that :)
364 - if is_cross ; then
365 - cd "${ED}"/${BINPATH}
366 - for x in * ; do
367 - mv ${x} ${x/${CTARGET}-}
368 - done
369 -
370 - if [[ -d ${ED}/usr/${CHOST}/${CTARGET} ]] ; then
371 - mv "${ED}"/usr/${CHOST}/${CTARGET}/include "${ED}"/${INCPATH}
372 - mv "${ED}"/usr/${CHOST}/${CTARGET}/lib/* "${ED}"/${LIBPATH}/
373 - rm -r "${ED}"/usr/${CHOST}/{include,lib}
374 - fi
375 - fi
376 - insinto ${INCPATH}
377 - local libiberty_headers=(
378 - # Not all the libiberty headers. See libiberty/Makefile.in:install_to_libdir.
379 - demangle.h
380 - dyn-string.h
381 - fibheap.h
382 - hashtab.h
383 - libiberty.h
384 - objalloc.h
385 - splay-tree.h
386 - )
387 - doins "${libiberty_headers[@]/#/${S}/include/}"
388 - if [[ -d ${ED}/${LIBPATH}/lib ]] ; then
389 - mv "${ED}"/${LIBPATH}/lib/* "${ED}"/${LIBPATH}/
390 - rm -r "${ED}"/${LIBPATH}/lib
391 - fi
392 -
393 - # Generate an env.d entry for this binutils
394 - insinto /etc/env.d/binutils
395 - cat <<-EOF > "${T}"/env.d
396 - TARGET="${CTARGET}"
397 - VER="${PV}"
398 - LIBPATH="${EPREFIX}${LIBPATH}"
399 - EOF
400 - newins "${T}"/env.d ${CTARGET}-${PV}
401 -
402 - # Handle documentation
403 - if ! is_cross ; then
404 - cd "${S}"
405 - dodoc README
406 - docinto bfd
407 - dodoc bfd/ChangeLog* bfd/README bfd/PORTING bfd/TODO
408 - docinto binutils
409 - dodoc binutils/ChangeLog binutils/NEWS binutils/README
410 - docinto gas
411 - dodoc gas/ChangeLog* gas/CONTRIBUTORS gas/NEWS gas/README*
412 - docinto gprof
413 - dodoc gprof/ChangeLog* gprof/TEST gprof/TODO gprof/bbconv.pl
414 - docinto ld
415 - dodoc ld/ChangeLog* ld/README ld/NEWS ld/TODO
416 - docinto libiberty
417 - dodoc libiberty/ChangeLog* libiberty/README
418 - docinto opcodes
419 - dodoc opcodes/ChangeLog*
420 - fi
421 -
422 - # Remove shared info pages
423 - rm -f "${ED}"/${DATAPATH}/info/{dir,configure.info,standards.info}
424 -
425 - # Trim all empty dirs
426 - find "${ED}" -depth -type d -exec rmdir {} + 2>/dev/null
427 -}
428 -
429 -pkg_postinst() {
430 - # Make sure this ${CTARGET} has a binutils version selected
431 - [[ -e ${EROOT}/etc/env.d/binutils/config-${CTARGET} ]] && return 0
432 - binutils-config ${CTARGET}-${PV}
433 -}
434 -
435 -pkg_postrm() {
436 - local current_profile=$(binutils-config -c ${CTARGET})
437 -
438 - # If no other versions exist, then uninstall for this
439 - # target ... otherwise, switch to the newest version
440 - # Note: only do this if this version is unmerged. We
441 - # rerun binutils-config if this is a remerge, as
442 - # we want the mtimes on the symlinks updated (if
443 - # it is the same as the current selected profile)
444 - if [[ ! -e ${EPREFIX}${BINPATH}/ld ]] && [[ ${current_profile} == ${CTARGET}-${PV} ]] ; then
445 - local choice=$(binutils-config -l | grep ${CTARGET} | awk '{print $2}')
446 - choice=${choice//$'\n'/ }
447 - choice=${choice/* }
448 - if [[ -z ${choice} ]] ; then
449 - binutils-config -u ${CTARGET}
450 - else
451 - binutils-config ${choice}
452 - fi
453 - elif [[ $(CHOST=${CTARGET} binutils-config -c) == ${CTARGET}-${PV} ]] ; then
454 - binutils-config ${CTARGET}-${PV}
455 - fi
456 -}
457 -
458 -# Note [slotting support]
459 -# -----------------------
460 -# Gentoo's layout for binutils files is non-standard as Gentoo
461 -# supports slotted installation for binutils. Many tools
462 -# still expect binutils to reside in known locations.
463 -# binutils-config package restores symlinks into known locations,
464 -# like:
465 -# /usr/bin/${CTARGET}-<tool>
466 -# /usr/bin/${CHOST}/${CTARGET}/lib/ldscrips
467 -# /usr/include/
468 -#
469 -# Note [tooldir hack for ldscripts]
470 -# ---------------------------------
471 -# Build system does not allow ./configure to tweak every location
472 -# we need for slotting binutils hence all the shuffling in
473 -# src_install(). This note is about SCRIPTDIR define handling.
474 -#
475 -# SCRIPTDIR defines 'ldscripts/' directory location. SCRIPTDIR value
476 -# is set at build-time in ld/Makefile.am as: 'scriptdir = $(tooldir)/lib'
477 -# and hardcoded as -DSCRIPTDIR='"$(scriptdir)"' at compile time.
478 -# Thus we can't just move files around after compilation finished.
479 -#
480 -# Our goal is the following:
481 -# - at build-time set scriptdir to point to symlinked location:
482 -# ${TOOLPATH}: /usr/${CHOST} (or /usr/${CHOST}/${CTARGET} for cross-case)
483 -# - at install-time set scriptdir to point to slotted location:
484 -# ${LIBPATH}: /usr/$(get_libdir)/binutils/${CTARGET}/${PV}