commit:     cc1b8b7f53de06cfda807177fcc3a76640f61c19
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 27 08:33:14 2022 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Tue Sep 27 08:36:49 2022 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cc1b8b7f

dev-util/mingw64-toolchain: drop 10.0.0-r2

Not seeing a motivation to keep/maintain old gcc/binutils
with this package for very long. If regression testing is
really needed, there's crossdev.

Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>

 dev-util/mingw64-toolchain/Manifest                |   2 -
 .../files/gcc-11.3.0-musl-calloc.patch             |  33 ---
 .../mingw64-toolchain-10.0.0-r2.ebuild             | 302 ---------------------
 3 files changed, 337 deletions(-)

diff --git a/dev-util/mingw64-toolchain/Manifest 
b/dev-util/mingw64-toolchain/Manifest
index 9bedc4e54451..ec14b3eba767 100644
--- a/dev-util/mingw64-toolchain/Manifest
+++ b/dev-util/mingw64-toolchain/Manifest
@@ -1,5 +1,3 @@
-DIST binutils-2.37.tar.xz 22916924 BLAKE2B 
f5a374fdf0300f7734d1e462333296b16c9d5ed6eba167e1742a4da7082f4388c929e286bf76c3933b3e434937380340732a31790723654b491ea0c8ab5b9ba5
 SHA512 
5c11aeef6935860a6819ed3a3c93371f052e52b4bdc5033da36037c1544d013b7f12cb8d561ec954fe7469a68f1b66f1a3cd53d5a3af7293635a90d69edd15e7
 DIST binutils-2.39.tar.xz 25167756 BLAKE2B 
ac6a5296c6586d53eaadcbffc5c399a6d79edf72450b9bb8b3525ce525129cef3d2eb90c85ef3bb3270b5a03b0e1ffb8f0b705f028158726f9777ebb8685066f
 SHA512 
68e038f339a8c21faa19a57bbc447a51c817f47c2e06d740847c6e9cc3396c025d35d5369fa8c3f8b70414757c89f0e577939ddc0d70f283182504920f53b0a3
-DIST gcc-11.3.0.tar.xz 81141364 BLAKE2B 
7e562d25446ca4ab9fe8cdb714866f66aba3744d78bf84f31bfb097c1a981e4c7f990cb1e6bcfec5ae6671836a4984e2b70eb8fed81dcef5e244f88da8623469
 SHA512 
f0be5ad705c73b84477128a69c047f57dd47002f375eb60e1e842e08cf2009a509e92152bca345823926d550b7395ae6d4de7db51d1ee371c2dc37313881fca7
 DIST gcc-12.2.0.tar.xz 84645292 BLAKE2B 
715574af9ad678f9dc8cfd19c866bf910c7edfd479e7e9681337feaa9b54e5d304ddb85483816b8d89754d502405823ae2eff0d1e444538763f40be8e428d8da
 SHA512 
e9e857bd81bf7a370307d6848c81b2f5403db8c7b5207f54bce3f3faac3bde63445684092c2bc1a2427cddb6f7746496d9fbbef05fbbd77f2810b2998f1f9173
 DIST mingw-w64-v10.0.0.tar.bz2 9620291 BLAKE2B 
451372403289c492ca939d65bb4d9f6e9fa6bdd6b32d79d6438d858e106e8cc291712ada1f3f7b951a4c6908e7d0385d485ca76920af39bcf86effa48408e330
 SHA512 
3c0827af7c40809a867758f6cd9ef3ff0c988b43082345bf725e03949af95968d634ace99a7ffae323189549221dcb5d861de9e801f1fbc7904e446641b60516

diff --git a/dev-util/mingw64-toolchain/files/gcc-11.3.0-musl-calloc.patch 
b/dev-util/mingw64-toolchain/files/gcc-11.3.0-musl-calloc.patch
deleted file mode 100644
index 71602df60cca..000000000000
--- a/dev-util/mingw64-toolchain/files/gcc-11.3.0-musl-calloc.patch
+++ /dev/null
@@ -1,33 +0,0 @@
-https://bugs.gentoo.org/855002
-https://gcc.gnu.org/PR104799
-https://gcc.gnu.org/PR106102
---- a/gcc/gcc/cp/mapper-client.cc
-+++ b/gcc/gcc/cp/mapper-client.cc
-@@ -29,2 +29,3 @@
- #define INCLUDE_MAP
-+#include <pthread.h>
- #include "system.h"
---- a/gcc/gcc/cp/mapper-resolver.cc
-+++ b/gcc/gcc/cp/mapper-resolver.cc
-@@ -27,2 +27,3 @@
- #define INCLUDE_MAP
-+#include <pthread.h>
- #include "system.h"
---- a/gcc/gcc/cp/module.cc
-+++ b/gcc/gcc/cp/module.cc
-@@ -206,2 +206,3 @@
- #define INCLUDE_VECTOR
-+#include <pthread.h>
- #include "system.h"
---- a/gcc/libcc1/libcc1plugin.cc
-+++ b/gcc/libcc1/libcc1plugin.cc
-@@ -19,2 +19,3 @@
- 
-+#include <pthread.h>
- #include <cc1plugin-config.h>
---- a/gcc/libcc1/libcp1plugin.cc
-+++ b/gcc/libcc1/libcp1plugin.cc
-@@ -20,2 +20,3 @@
- 
-+#include <pthread.h>
- #include <cc1plugin-config.h>

diff --git a/dev-util/mingw64-toolchain/mingw64-toolchain-10.0.0-r2.ebuild 
b/dev-util/mingw64-toolchain/mingw64-toolchain-10.0.0-r2.ebuild
deleted file mode 100644
index a7fc75296ccc..000000000000
--- a/dev-util/mingw64-toolchain/mingw64-toolchain-10.0.0-r2.ebuild
+++ /dev/null
@@ -1,302 +0,0 @@
-# Copyright 2022 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI=8
-
-MULTILIB_COMPAT=( abi_x86_{32,64} )
-inherit edo flag-o-matic multilib-build toolchain-funcs
-
-# Pick versions known to work for Wine and use vanilla for simplicity,
-# ideally update only on mingw64-runtime bumps or if there's known issues
-# (please report) to avoid rebuilding the entire toolchain too often.
-# Do _p1++ rather than revbump if changing without bumping mingw64 itself.
-BINUTILS_PV=2.37 # 2.38 needs bug #838106
-GCC_PV=11.3.0
-MINGW_PV=$(ver_cut 1-3)
-
-DESCRIPTION="All-in-one mingw64 toolchain intended for building Wine without 
crossdev"
-HOMEPAGE="
-       https://www.mingw-w64.org/
-       https://gcc.gnu.org/
-       https://sourceware.org/binutils/";
-SRC_URI="
-       
mirror://sourceforge/mingw-w64/mingw-w64/mingw-w64-release/mingw-w64-v${MINGW_PV}.tar.bz2
-       mirror://gnu/gcc/gcc-${GCC_PV}/gcc-${GCC_PV}.tar.xz
-       mirror://gnu/binutils/binutils-${BINUTILS_PV}.tar.xz"
-S="${WORKDIR}"
-
-# l1:binutils+gcc, l2:gcc(libraries), l3:mingw64-runtime
-LICENSE="
-       GPL-3+
-       LGPL-3+ || ( GPL-3+ libgcc libstdc++ gcc-runtime-library-exception-3.1 )
-       ZPL BSD BSD-2 ISC LGPL-2+ LGPL-2.1+ MIT public-domain"
-SLOT="0"
-KEYWORDS="-* amd64 x86"
-IUSE="+abi_x86_32 custom-cflags debug"
-
-RDEPEND="
-       dev-libs/gmp:=
-       dev-libs/mpc:=
-       dev-libs/mpfr:=
-       sys-libs/zlib:=
-       virtual/libiconv"
-DEPEND="${RDEPEND}"
-
-PATCHES=(
-       "${FILESDIR}"/mingw64-runtime-10.0.0-tmp-files-clash.patch
-       "${FILESDIR}"/gcc-11.3.0-plugin-objdump.patch
-       "${FILESDIR}"/gcc-11.3.0-musl-calloc.patch
-)
-
-pkg_pretend() {
-       [[ ${MERGE_TYPE} == binary ]] && return
-
-       tc-is-cross-compiler &&
-               die "cross-compilation of the toolchain itself is unsupported"
-}
-
-src_prepare() {
-       # rename directories to simplify both patching and the ebuild
-       mv binutils{-${BINUTILS_PV},} || die
-       mv gcc{-${GCC_PV},} || die
-       mv mingw-w64-v${MINGW_PV} mingw64 || die
-
-       default
-}
-
-src_compile() {
-       # not great but do everything in src_compile given bootstrapping
-       # process needs to be done in steps of configure+compile+install
-       # (done modular to have most package-specific things in one place)
-
-       CTARGET=$(usex x86 i686 x86_64)-w64-mingw32
-
-       MWT_D=${T}/root # use ${T} to respect VariableScope for ${D}
-       local mwtdir=/usr/lib/${PN}
-       local prefix=${EPREFIX}${mwtdir}
-       local sysroot=${MWT_D}${prefix}
-       local -x PATH=${sysroot}/bin:${PATH}
-
-       use custom-cflags || strip-flags # fancy flags are not realistic here
-
-       local multilib=false
-       use abi_x86_32 && use abi_x86_64 && multilib=true
-
-       # global configure flags
-       local conf=(
-               --build=${CBUILD:-${CHOST}}
-               --target=${CTARGET}
-               --{doc,info,man}dir=/.skip # let individual packages handle docs
-       )
-
-       # binutils
-       local conf_binutils=(
-               --prefix="${prefix}"
-               --host=${CHOST}
-               --disable-cet
-               --disable-nls
-               --disable-shared
-               --with-system-zlib
-               --without-debuginfod
-       )
-       mwt-binutils() {
-               # symlink gcc's lto plugin for AR (bug #854516)
-               ln -s ../../libexec/gcc/${CTARGET}/${GCC_PV}/liblto_plugin.so \
-                       "${sysroot}"/lib/bfd-plugins || die
-       }
-
-       # gcc (minimal -- if need more, disable only in stage1 / enable in 
stage3)
-       local conf_gcc=(
-               --prefix="${prefix}"
-               --host=${CHOST}
-               --disable-bootstrap
-               --disable-cet
-               --disable-gcov #843989
-               --disable-gomp
-               --disable-libquadmath
-               --disable-libsanitizer
-               --disable-libssp
-               --disable-libvtv
-               --disable-shared
-               --disable-werror
-               --with-system-zlib
-               --without-isl
-               --without-zstd
-       )
-       ${multilib} || conf_gcc+=( --disable-multilib )
-
-       local conf_gcc_stage1=(
-               --enable-languages=c
-               --disable-libatomic
-               --with-sysroot="${sysroot}"
-       )
-       local -n conf_gcc_stage2=conf_gcc_stage1
-
-       local conf_gcc_stage3=(
-               --enable-languages=c,c++
-               --enable-threads=posix # needs stage3, and is required for 
dxvk/vkd3d
-               --with-sysroot="${prefix}"
-               --with-build-sysroot="${sysroot}"
-       )
-
-       # mingw64-runtime (split in several parts, 3 needed for gcc stages)
-       local conf_mingw64=(
-               --prefix="${prefix}"/${CTARGET}
-               --host=${CTARGET}
-               --with-sysroot=no
-               --without-{crt,headers}
-
-               # mingw .dll aren't used by wine and packages wouldn't find them
-               # at runtime, use crossdev if need dll and proper search paths
-               --disable-shared
-       )
-
-       local conf_mingw64_headers=(
-               --enable-idl
-               --with-headers
-       )
-       mwt-mingw64_headers() { ln -s ${CTARGET} "${sysroot}"/mingw || die; } 
#419601
-
-       local conf_mingw64_runtime=( --with-crt )
-       ${multilib} ||
-               conf_mingw64_runtime+=( $(usex x86 --disable-lib64 
--disable-lib32 ) )
-
-       local conf_mingw64_libraries=( --with-libraries )
-       local conf_mingw64_libraries32=(
-               --libdir="${prefix}"/${CTARGET}/lib32
-               --with-libraries
-               CC="${CTARGET}-gcc -m32"
-               RCFLAGS="--target=pe-i386 ${RCFLAGS}"
-       )
-
-       # mingw64-runtime's idl compiler (useful not to depend on wine for widl)
-       local conf_widl=( --prefix="${prefix}" )
-
-       # mwt-build [-x] <path/package-name> [stage-name]
-       # -> ./configure && make && make install && mwt-package() && 
mwt-package_stage()
-       # passes conf, conf_package, and conf_package_stage arrays to 
configure, and
-       # users can add options through environment with e.g.
-       #       MWT_BINUTILS_CONF="--some-option"
-       #       MWT_GCC_STAGE1_CONF="--some-gcc-stage1-only-option"
-       #       MWT_WIDL_CONF="--some-other-option"
-       #       EXTRA_ECONF="--global-option" (generic naming for if not 
reading this)
-       mwt-build() {
-               if [[ ${1} == -x ]]; then
-                       (
-                               # cross-compiling, cleanup and let ./configure 
handle it
-                               unset AR AS CC CPP CXX LD NM OBJCOPY OBJDUMP 
RANLIB RC STRIP
-                               CHOST=${CTARGET}
-                               filter-flags '-fstack-protector*' #870136
-                               filter-flags '-fuse-ld=*'
-                               strip-unsupported-flags
-                               mwt-build "${@:2}"
-                       )
-                       return
-               fi
-
-               local id=${1##*/}
-               local build_dir=${WORKDIR}/${1}${2+_${2}}-build
-
-               # econf is not allowed in src_compile and its defaults are
-               # mostly unused here, so use configure directly
-               local conf=( "${WORKDIR}/${1}"/configure "${conf[@]}" )
-
-               local -n conf_id=conf_${id} conf_id2=conf_${id}_${2}
-               [[ ${conf_id@a} == *a* ]] && conf+=( "${conf_id[@]}" )
-               [[ ${2} && ${conf_id2@a} == *a* ]] && conf+=( "${conf_id2[@]}" )
-
-               local -n extra_id=MWT_${id^^}_CONF 
extra_id2=MWT_${id^^}_${2^^}_CONF
-               conf+=( ${EXTRA_ECONF} ${extra_id} ${2+${extra_id2}} )
-
-               einfo "Building ${id}${2+ ${2}} in ${build_dir} ..."
-
-               mkdir "${build_dir}" || die
-               pushd "${build_dir}" >/dev/null || die
-
-               edo "${conf[@]}"
-               emake
-               emake DESTDIR="${MWT_D}" install
-
-               declare -f mwt-${id} >/dev/null && edo mwt-${id}
-               declare -f mwt-${id}_${2} >/dev/null && edo mwt-${id}_${2}
-
-               popd >/dev/null || die
-       }
-
-       # build with same ordering that crossdev would do + stage3 for pthreads
-       mwt-build binutils
-       mwt-build mingw64 headers
-       mwt-build gcc stage1
-       mwt-build -x mingw64 runtime
-       mwt-build gcc stage2
-       ${multilib} && mwt-build -x mingw64 libraries32
-       mwt-build -x mingw64 libraries
-       mwt-build gcc stage3
-       mwt-build mingw64/mingw-w64-tools/widl
-       # note: /could/ system-bootstrap if already installed, but gcc and
-       # libraries will use the system's older mingw64 headers/static-libs
-       # and make this potentially fragile without more workarounds/stages
-
-       if ${multilib}; then
-               # Like system's gcc, `x86_64-w64-mingw32-gcc -m32` can build 
for x86,
-               # but packages expect crossdev's i686-w64-mingw32-gcc which is 
the same
-               # just without 64bit support and would rather not build the 
toolchain
-               # twice. Dirty but wrap to allow simple interoperability with 
crossdev.
-               mwt-i686_wrapper() {
-                       printf "#!/usr/bin/env sh\nexec 
\"${prefix}/bin/${bin}\" ${*} "'"${@}"\n' \
-                               > ${bin32} || die
-                       chmod +x ${bin32} || die
-               }
-               pushd "${sysroot}"/bin >/dev/null || die
-               local bin bin32
-               for bin in ${CTARGET}-*; do
-                       bin32=${bin/x86_64-w64/i686-w64}
-                       case ${bin#${CTARGET}-} in
-                               gcc|gcc-${GCC_PV}|g++|widl) mwt-i686_wrapper 
-m32;;
-                               ld|ld.bfd) mwt-i686_wrapper -m i386pe;;
-                               windres) mwt-i686_wrapper --target=pe-i386;;
-                               *) ln -s ${bin} ${bin32} || die;;
-                       esac
-               done
-               popd >/dev/null || die
-       fi
-
-       # portage doesn't know the right strip executable to use for CTARGET
-       # and it can lead to .a mangling, notably with 32bit (breaks toolchain)
-       dostrip -x ${mwtdir}/{${CTARGET}/lib{,32},lib/gcc/${CTARGET}}
-
-       # ... and instead do it here given this saves ~60MB
-       if use !debug; then
-               einfo "Stripping ${CTARGET} static libraries ..."
-               find "${sysroot}"/{,lib/gcc/}${CTARGET} -type f -name '*.a' \
-                       -exec ${CTARGET}-strip --strip-unneeded {} + || die
-       fi
-}
-
-src_install() {
-       # use mv over copying given it's ~370MB
-       mv "${MWT_D}${EPREFIX}"/* "${ED}" || die
-
-       # gcc handles static libs internally without needing .la
-       find "${ED}" -type f -name '*.la' -delete || die
-}
-
-pkg_postinst() {
-       if [[ ! ${REPLACING_VERSIONS} ]]; then
-               elog "Note that this package is primarily intended for Wine and 
related"
-               elog "packages to depend on without needing a manual crossdev 
setup."
-               elog
-               elog "Settings are oriented only for what these need and 
simplicity."
-               elog "Use sys-devel/crossdev if need full 
toolchain/customization:"
-               elog "    https://wiki.gentoo.org/wiki/Mingw";
-               elog "    https://wiki.gentoo.org/wiki/Crossdev";
-       fi
-
-       local cross_gcc=cross-$(usex x86 i686 x86_64)-w64-mingw32/gcc
-       if has_version ${cross_gcc}; then
-               # encourage cleanup given users may not realize if switch by 
default
-               ewarn "${cross_gcc} is installed, note that ${PN}"
-               ewarn "is redundant with the 
*-w64-mingw32/{binutils,gcc,mingw64-runtime}"
-               ewarn "packages and optionally only one needs to be kept."
-       fi
-}

Reply via email to