commit:     99ef76018adf18ba73dcc7ae4cd34b5e0cf655fe
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Thu Dec 29 16:20:37 2022 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Thu Dec 29 20:28:52 2022 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=99ef7601

app-emulation/wine-staging: drop 7.20, 7.21-r1

Both versions had several quirks and shouldn't be worthwhile
to keep, try 7.19 instead if 7.22 is not suitable (7.19 was
before some more major changes).

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

 app-emulation/wine-staging/Manifest                |   4 -
 .../files/wine-staging-7.21-crossflags.patch       |  29 --
 .../files/wine-staging-7.21-opengl32.patch         |  73 -----
 .../wine-staging/wine-staging-7.20.ebuild          | 351 --------------------
 .../wine-staging/wine-staging-7.21-r1.ebuild       | 358 ---------------------
 5 files changed, 815 deletions(-)

diff --git a/app-emulation/wine-staging/Manifest 
b/app-emulation/wine-staging/Manifest
index ece56f286ed3..f3dbaed773c9 100644
--- a/app-emulation/wine-staging/Manifest
+++ b/app-emulation/wine-staging/Manifest
@@ -1,8 +1,4 @@
 DIST wine-7.19.tar.xz 28502612 BLAKE2B 
b7b270656955c7a1e1d84e8bbc7e3e8abff5aedadb5e8a458f0b1109d746875a359f3d2f53b1c9c6caae65d17fd1d205466cd3a884034a8bad6afe9456f13b5d
 SHA512 
f76dbda97cccad4c0f249b5dd4e8d48afa832134f1704ae228650bb73ee82823e628b23bd53a3f8729e06a8933597ff2fffa5551f156fc9c9181b67c066747d5
-DIST wine-7.20.tar.xz 28534920 BLAKE2B 
2e0cd49a7820f0c885a2a6dbcded6ebbdb5e1ea5576b03dedb7ee066f74f8c675193450cdd45bf5e0224bd588a890138e47a15f513edbfde1eabf1b65c9abe31
 SHA512 
6e2e65fba2336985df93165050f0f46b752d6aa94fc1581451c58969e2003748378be4b9e16b647ca2922fbdff77920311b12a17bda630a7bccfc7ee8f03b453
-DIST wine-7.21.tar.xz 28703308 BLAKE2B 
8902ded32b9e635f8ccf659ca4055e9ad45d3659f3ad48d0c218dc5a7a334df456ea0e9441dcaff58e8cac0bbd65140b20e61180acaa06230bc70e28a8382c7e
 SHA512 
15c0c9efda972b84890886fd4b1fb18dd462373ba490f5e607004a5436caba9823f643369ceb5abbc2d2d0e26d7ce002e00136299d9984c0a27f729f3ac129c1
 DIST wine-7.22.tar.xz 28974052 BLAKE2B 
c86466964817b916ee8f7b687f193eda8bdd3fb17152ab1565971e36f43b12b540033ac1c5fa5d15576041febd32cf1ea2955732c5386debcbda46fb3acca0f1
 SHA512 
bf58a5b98bef5b291aff1eca3f94c28da95990e4c8da9af5e9e28b9480d57163d088b501b0c1bca5b568bf586dd9933cdc1ea1f371b78d95c94e2d25d0a65efc
 DIST wine-staging-7.19.tar.gz 9523048 BLAKE2B 
e53fd47af493cbdc4542f908a39557324d70ad67ff2e06c80296c006a63518e43988750cab2f4d3d9197fc9c8a1e61ed4d96bcc310b82b6cfc8ec12b941f1c5c
 SHA512 
c51cb18c4ae00eccf414f5edda18ebf363674ba7cfa95da135b3a43b7c012c086d454d6ac32b22d98e611bb87e55c3e1ee95571a4a0c9713028b5ac38e8aed3f
-DIST wine-staging-7.20.tar.gz 9521481 BLAKE2B 
5a264460e72ac96d50d23492100c465eeb0b933306200710aa085bd37bb79df3c6ef03aeb5ba2c4c196befb231938457aa9584b9edf938edfd754d06e7cdb574
 SHA512 
538bf60e760254f3130fe8b6bf07598287e567c0f34d6be2ed04fde10007283d4c675a6f27a0a13d3ce77e833559d5ef853a89f2f96dc5f8cc818bdc3570474a
-DIST wine-staging-7.21.tar.gz 9530737 BLAKE2B 
a80476dbc957a9cda1554262777c63276f9b66a5ccd1389a006327810b0b960a600f78dfabc0d8df4ce816cdd7c4c3c29c26bea9b63219fa90dff60142d41da1
 SHA512 
1261267fe82a25d74dbf3f8cd1926339356eac3cd432667517c2ca65656c1b733c2866a48c1e4ad116ac8094d9079366a07f6a7814b8bde27246d654a792e9ec
 DIST wine-staging-7.22.tar.gz 9528424 BLAKE2B 
e41f24f924117259715505f4f9998ef23a657bca5b0e285feb7f9fd732e6b566a495f48ec59af09b1d4d51db522b051028f6cbba748256e939929fbf978f0e44
 SHA512 
5fdac19ec290c67767fac71abe07d9350ec431919c67a0f2d2df18ced20f1d3dddb921b3d5586d03add187c6281e1a691cc220e8d2d5ad4eeb94015721479d65

diff --git 
a/app-emulation/wine-staging/files/wine-staging-7.21-crossflags.patch 
b/app-emulation/wine-staging/files/wine-staging-7.21-crossflags.patch
deleted file mode 100644
index bdf5aeefb5bf..000000000000
--- a/app-emulation/wine-staging/files/wine-staging-7.21-crossflags.patch
+++ /dev/null
@@ -1,29 +0,0 @@
-Restore CROSSLDFLAGS and ensure tested flags are saved in
-{arch}_*FLAGS (e.g. -fno-strict-aliasing)
-
-quickfix, odds are this will be revamped upstream
---- a/configure.ac
-+++ b/configure.ac
-@@ -919,9 +919,9 @@
-     saved_CC=$CC
-     saved_CFLAGS=$CFLAGS
-+    saved_LDFLAGS=$LDFLAGS
- 
-     CFLAGS=${CROSSCFLAGS:-"-g -O2"}
-+    LDFLAGS=${CROSSLDFLAGS:-}
-     AS_VAR_COPY([CC],[${wine_arch}_CC])
--    AS_VAR_COPY([${wine_arch}_CFLAGS],[CFLAGS])
--    AS_VAR_COPY([${wine_arch}_LDFLAGS],[LDFLAGS])
-     AS_VAR_SET([${wine_arch}_EXTRACFLAGS],["-D__WINE_PE_BUILD -Wall"])
- 
-@@ -1052,6 +1052,10 @@
-                                           
AS_VAR_APPEND([${wine_arch}_LDFLAGS],[" -Wl,--build-id"])])
- 
-+    AS_VAR_COPY([${wine_arch}_CFLAGS],[CFLAGS])
-+    AS_VAR_COPY([${wine_arch}_LDFLAGS],[LDFLAGS])
-+
-     CC=$saved_CC
-     CFLAGS=$saved_CFLAGS
-+    LDFLAGS=$saved_LDFLAGS
- done
- 

diff --git a/app-emulation/wine-staging/files/wine-staging-7.21-opengl32.patch 
b/app-emulation/wine-staging/files/wine-staging-7.21-opengl32.patch
deleted file mode 100644
index 9411e05e96fd..000000000000
--- a/app-emulation/wine-staging/files/wine-staging-7.21-opengl32.patch
+++ /dev/null
@@ -1,73 +0,0 @@
-Fixes PE opengl32.dll failing to initialize.
-
-https://gitlab.winehq.org/wine/wine/-/commit/34099bba6cb
-From:  RĂ©mi Bernon <[email protected]>
-Date: Mon, 14 Nov 2022 11:55:51 +0100
-Subject: [PATCH] ntdll: Delay loading unixlibs until the functions are
- requested.
-
-Wine-Bug: https://bugs.winehq.org/show_bug.cgi?id=53909
---- a/dlls/ntdll/unix/virtual.c
-+++ b/dlls/ntdll/unix/virtual.c
-@@ -98,6 +98,7 @@ struct builtin_module
-     unsigned int refcount;
-     void        *handle;
-     void        *module;
-+    char        *unix_path;
-     void        *unix_handle;
- };
- 
-@@ -583,6 +584,7 @@ static void add_builtin_module( void *module, void *handle 
)
-     builtin->handle      = handle;
-     builtin->module      = module;
-     builtin->refcount    = 1;
-+    builtin->unix_path   = NULL;
-     builtin->unix_handle = NULL;
-     list_add_tail( &builtin_modules, &builtin->entry );
- }
-@@ -603,6 +605,7 @@ void release_builtin_module( void *module )
-             list_remove( &builtin->entry );
-             if (builtin->handle) dlclose( builtin->handle );
-             if (builtin->unix_handle) dlclose( builtin->unix_handle );
-+            free( builtin->unix_path );
-             free( builtin );
-         }
-         break;
-@@ -652,6 +655,8 @@ static NTSTATUS get_builtin_unix_funcs( void *module, BOOL 
wow, const void **fun
-     LIST_FOR_EACH_ENTRY( builtin, &builtin_modules, struct builtin_module, 
entry )
-     {
-         if (builtin->module != module) continue;
-+        if (builtin->unix_path && !builtin->unix_handle)
-+            builtin->unix_handle = dlopen( builtin->unix_path, RTLD_NOW );
-         if (builtin->unix_handle)
-         {
-             *funcs = dlsym( builtin->unix_handle, ptr_name );
-@@ -669,26 +674,19 @@ static NTSTATUS get_builtin_unix_funcs( void *module, 
BOOL wow, const void **fun
-  */
- NTSTATUS load_builtin_unixlib( void *module, const char *name )
- {
--    void *handle;
-     sigset_t sigset;
--    NTSTATUS status = STATUS_DLL_NOT_FOUND;
-+    NTSTATUS status = STATUS_SUCCESS;
-     struct builtin_module *builtin;
- 
--    if (!(handle = dlopen( name, RTLD_NOW ))) return status;
-     server_enter_uninterrupted_section( &virtual_mutex, &sigset );
-     LIST_FOR_EACH_ENTRY( builtin, &builtin_modules, struct builtin_module, 
entry )
-     {
-         if (builtin->module != module) continue;
--        if (!builtin->unix_handle)
--        {
--            builtin->unix_handle = handle;
--            status = STATUS_SUCCESS;
--        }
-+        if (!builtin->unix_path) builtin->unix_path = strdup( name );
-         else status = STATUS_IMAGE_ALREADY_LOADED;
-         break;
-     }
-     server_leave_uninterrupted_section( &virtual_mutex, &sigset );
--    if (status) dlclose( handle );
-     return status;
- }
- 

diff --git a/app-emulation/wine-staging/wine-staging-7.20.ebuild 
b/app-emulation/wine-staging/wine-staging-7.20.ebuild
deleted file mode 100644
index 4d5a4afb6acc..000000000000
--- a/app-emulation/wine-staging/wine-staging-7.20.ebuild
+++ /dev/null
@@ -1,351 +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 autotools flag-o-matic multilib multilib-build toolchain-funcs wrapper
-
-WINE_GECKO=2.47.3
-WINE_MONO=7.4.0
-
-if [[ ${PV} == *9999 ]]; then
-       inherit git-r3
-       EGIT_REPO_URI="https://github.com/wine-staging/wine-staging.git";
-       WINE_EGIT_REPO_URI="https://gitlab.winehq.org/wine/wine.git";
-else
-       (( $(ver_cut 2) )) && WINE_SDIR=$(ver_cut 1).x || WINE_SDIR=$(ver_cut 
1).0
-       SRC_URI="
-               https://dl.winehq.org/wine/source/${WINE_SDIR}/wine-${PV}.tar.xz
-               
https://github.com/wine-staging/wine-staging/archive/v${PV}.tar.gz -> 
${P}.tar.gz"
-       KEYWORDS="-* ~amd64 ~x86"
-fi
-S="${WORKDIR}/wine-${PV}"
-
-DESCRIPTION="Free implementation of Windows(tm) on Unix, with Wine-Staging 
patchset"
-HOMEPAGE="https://wiki.winehq.org/Wine-Staging";
-
-LICENSE="LGPL-2.1+ BSD-2 IJG MIT ZLIB gsm libpng2 libtiff"
-SLOT="${PV}"
-IUSE="
-       +X +abi_x86_32 +abi_x86_64 +alsa capi crossdev-mingw cups dos
-       llvm-libunwind debug custom-cflags +fontconfig +gecko gphoto2
-       +gstreamer kerberos ldap +mingw +mono netapi nls odbc openal
-       opencl +opengl osmesa pcap perl pulseaudio samba scanner +sdl
-       selinux +ssl +truetype udev udisks +unwind usb v4l +vulkan
-       +xcomposite xinerama"
-REQUIRED_USE="
-       X? ( truetype )
-       crossdev-mingw? ( mingw )" # bug #551124 for truetype
-
-# tests are non-trivial to run, can hang easily, don't play well with
-# sandbox, and several need real opengl/vulkan or network access
-RESTRICT="test"
-
-# `grep WINE_CHECK_SONAME configure.ac` + if not directly linked
-WINE_DLOPEN_DEPEND="
-       X? (
-               x11-libs/libXcursor[${MULTILIB_USEDEP}]
-               x11-libs/libXfixes[${MULTILIB_USEDEP}]
-               x11-libs/libXi[${MULTILIB_USEDEP}]
-               x11-libs/libXrandr[${MULTILIB_USEDEP}]
-               x11-libs/libXrender[${MULTILIB_USEDEP}]
-               x11-libs/libXxf86vm[${MULTILIB_USEDEP}]
-               opengl? (
-                       media-libs/libglvnd[X,${MULTILIB_USEDEP}]
-                       osmesa? ( media-libs/mesa[osmesa,${MULTILIB_USEDEP}] )
-               )
-               xcomposite? ( x11-libs/libXcomposite[${MULTILIB_USEDEP}] )
-               xinerama? ( x11-libs/libXinerama[${MULTILIB_USEDEP}] )
-       )
-       cups? ( net-print/cups[${MULTILIB_USEDEP}] )
-       fontconfig? ( media-libs/fontconfig[${MULTILIB_USEDEP}] )
-       kerberos? ( virtual/krb5[${MULTILIB_USEDEP}] )
-       netapi? ( net-fs/samba[${MULTILIB_USEDEP}] )
-       odbc? ( dev-db/unixODBC[${MULTILIB_USEDEP}] )
-       sdl? ( media-libs/libsdl2[haptic,joystick,${MULTILIB_USEDEP}] )
-       ssl? ( net-libs/gnutls:=[${MULTILIB_USEDEP}] )
-       truetype? ( media-libs/freetype[${MULTILIB_USEDEP}] )
-       udisks? ( sys-apps/dbus[${MULTILIB_USEDEP}] )
-       v4l? ( media-libs/libv4l[${MULTILIB_USEDEP}] )
-       vulkan? ( media-libs/vulkan-loader[${MULTILIB_USEDEP}] )"
-WINE_COMMON_DEPEND="
-       ${WINE_DLOPEN_DEPEND}
-       X? (
-               x11-libs/libX11[${MULTILIB_USEDEP}]
-               x11-libs/libXext[${MULTILIB_USEDEP}]
-       )
-       alsa? ( media-libs/alsa-lib[${MULTILIB_USEDEP}] )
-       capi? ( net-libs/libcapi:=[${MULTILIB_USEDEP}] )
-       gphoto2? ( media-libs/libgphoto2:=[${MULTILIB_USEDEP}] )
-       gstreamer? (
-               dev-libs/glib:2[${MULTILIB_USEDEP}]
-               media-libs/gst-plugins-base:1.0[${MULTILIB_USEDEP}]
-               media-libs/gstreamer:1.0[${MULTILIB_USEDEP}]
-       )
-       ldap? ( net-nds/openldap:=[${MULTILIB_USEDEP}] )
-       openal? ( media-libs/openal[${MULTILIB_USEDEP}] )
-       opencl? ( virtual/opencl[${MULTILIB_USEDEP}] )
-       pcap? ( net-libs/libpcap[${MULTILIB_USEDEP}] )
-       pulseaudio? ( media-libs/libpulse[${MULTILIB_USEDEP}] )
-       scanner? ( media-gfx/sane-backends[${MULTILIB_USEDEP}] )
-       udev? ( virtual/libudev:=[${MULTILIB_USEDEP}] )
-       unwind? (
-               llvm-libunwind? ( sys-libs/llvm-libunwind[${MULTILIB_USEDEP}] )
-               !llvm-libunwind? ( sys-libs/libunwind:=[${MULTILIB_USEDEP}] )
-       )
-       usb? ( dev-libs/libusb:1[${MULTILIB_USEDEP}] )"
-RDEPEND="
-       ${WINE_COMMON_DEPEND}
-       app-emulation/wine-desktop-common
-       dos? ( games-emulation/dosbox )
-       gecko? ( app-emulation/wine-gecko:${WINE_GECKO}[${MULTILIB_USEDEP}] )
-       gstreamer? ( media-plugins/gst-plugins-meta:1.0[${MULTILIB_USEDEP}] )
-       mono? ( app-emulation/wine-mono:${WINE_MONO} )
-       perl? (
-               dev-lang/perl
-               dev-perl/XML-LibXML
-       )
-       samba? ( net-fs/samba[winbind] )
-       selinux? ( sec-policy/selinux-wine )
-       udisks? ( sys-fs/udisks:2 )"
-DEPEND="
-       ${WINE_COMMON_DEPEND}
-       sys-kernel/linux-headers
-       X? ( x11-base/xorg-proto )"
-BDEPEND="
-       dev-lang/perl
-       sys-devel/binutils
-       sys-devel/bison
-       sys-devel/flex
-       virtual/pkgconfig
-       mingw? ( !crossdev-mingw? ( 
dev-util/mingw64-toolchain[${MULTILIB_USEDEP}] ) )
-       nls? ( sys-devel/gettext )"
-IDEPEND=">=app-eselect/eselect-wine-2"
-
-QA_TEXTRELS="usr/lib/*/wine/i386-unix/*.so" # uses -fno-PIC -Wl,-z,notext
-
-PATCHES=(
-       "${FILESDIR}"/${PN}-7.17-noexecstack.patch
-       "${FILESDIR}"/${PN}-7.20-unwind.patch
-)
-
-pkg_pretend() {
-       [[ ${MERGE_TYPE} == binary ]] && return
-
-       if use crossdev-mingw && [[ ! -v MINGW_BYPASS ]]; then
-               local mingw=-w64-mingw32
-               for mingw in $(usev abi_x86_64 x86_64${mingw}) $(usev 
abi_x86_32 i686${mingw}); do
-                       if ! type -P ${mingw}-gcc >/dev/null; then
-                               eerror "With USE=crossdev-mingw, you must 
prepare the MinGW toolchain"
-                               eerror "yourself by installing 
sys-devel/crossdev then running:"
-                               eerror
-                               eerror "    crossdev --target ${mingw}"
-                               eerror
-                               eerror "For more information, please see: 
https://wiki.gentoo.org/wiki/Mingw";
-                               die "USE=crossdev-mingw is enabled, but 
${mingw}-gcc was not found"
-                       fi
-               done
-       fi
-}
-
-src_unpack() {
-       if [[ ${PV} == *9999 ]]; then
-               EGIT_CHECKOUT_DIR=${WORKDIR}/${P}
-               git-r3_src_unpack
-
-               EGIT_COMMIT=$(<"${EGIT_CHECKOUT_DIR}"/staging/upstream-commit) 
|| die
-               EGIT_REPO_URI=${WINE_EGIT_REPO_URI}
-               EGIT_CHECKOUT_DIR=${S}
-               einfo "Fetching Wine commit matching the current patchset by 
default (${EGIT_COMMIT})"
-               git-r3_src_unpack
-       else
-               default
-       fi
-}
-
-src_prepare() {
-       local staging=(
-               ./patchinstall.sh DESTDIR="${S}"
-               --all
-               --backend=eapply
-               --no-autoconf
-               -W winemenubuilder-Desktop_Icon_Path #652176
-               ${MY_WINE_STAGING_CONF}
-       )
-
-       # source patcher in a subshell so can use eapply as a backend
-       ebegin "Running ${staging[*]}"
-       ( cd ../${P}/patches && . "${staging[@]}" )
-       eend ${?} || die "Failed to apply the patchset"
-
-       # sanity check, bumping these has a history of oversights
-       local geckomono=$(sed -En '/^#define (GECKO|MONO)_VER/{s/[^0-9.]//gp}' \
-               dlls/appwiz.cpl/addons.c || die)
-       if [[ ${WINE_GECKO}$'\n'${WINE_MONO} != "${geckomono}" ]]; then
-               local gmfatal=
-               [[ ${PV} == *9999 ]] && gmfatal=nonfatal
-               ${gmfatal} die -n "gecko/mono mismatch in ebuild, has: " 
${geckomono} " (please file a bug)"
-       fi
-
-       default
-
-       # ensure .desktop calls this variant + slot
-       sed -i "/^Exec=/s/wine /${P} /" loader/wine.desktop || die
-
-       # always update for patches (including user's wrt #432348)
-       eautoreconf
-       tools/make_requests || die # perl
-}
-
-src_configure() {
-       WINE_PREFIX=/usr/lib/${P}
-       WINE_DATADIR=/usr/share/${P}
-
-       local conf=(
-               --prefix="${EPREFIX}"${WINE_PREFIX}
-               --datadir="${EPREFIX}"${WINE_DATADIR}
-               --includedir="${EPREFIX}"/usr/include/${P}
-               --libdir="${EPREFIX}"${WINE_PREFIX}
-               --mandir="${EPREFIX}"${WINE_DATADIR}/man
-               $(use_enable gecko mshtml)
-               $(use_enable mono mscoree)
-               --disable-tests
-               $(use_with X x)
-               $(use_with alsa)
-               $(use_with capi)
-               $(use_with cups)
-               $(use_with fontconfig)
-               $(use_with gphoto2 gphoto)
-               $(use_with gstreamer)
-               $(use_with kerberos gssapi)
-               $(use_with kerberos krb5)
-               $(use_with ldap)
-               $(use_with mingw)
-               $(use_with netapi)
-               $(use_with nls gettext)
-               $(use_with openal)
-               $(use_with opencl)
-               $(use_with opengl)
-               $(use_with osmesa)
-               --without-oss # media-sound/oss is not packaged (OSSv4)
-               $(use_with pcap)
-               $(use_with pulseaudio pulse)
-               $(use_with scanner sane)
-               $(use_with sdl)
-               $(use_with ssl gnutls)
-               $(use_with truetype freetype)
-               $(use_with udev)
-               $(use_with udisks dbus) # dbus is only used for udisks
-               $(use_with unwind)
-               $(use_with usb)
-               $(use_with v4l v4l2)
-               $(use_with vulkan)
-               $(use_with xcomposite)
-               $(use_with xinerama)
-               $(usev !odbc ac_cv_lib_soname_odbc=)
-       )
-
-       tc-ld-force-bfd # builds with non-bfd but broken at runtime (bug 
#867097)
-       filter-lto # build failure
-       use mingw || filter-flags -fno-plt # build failure
-       use custom-cflags || strip-flags # can break in obscure ways at runtime
-       use crossdev-mingw || 
PATH=${BROOT}/usr/lib/mingw64-toolchain/bin:${PATH}
-
-       # temporary workaround for tc-ld-force-bfd not yet enforcing with mold
-       # https://github.com/gentoo/gentoo/pull/28355
-       [[ $($(tc-getCC) ${LDFLAGS} -Wl,--version 2>/dev/null) == mold* ]] &&
-               append-ldflags -fuse-ld=bfd
-
-       # build using upstream's way (--with-wine64)
-       # order matters: configure+compile 64->32, install 32->64
-       local -i bits
-       for bits in $(usev abi_x86_64 64) $(usev abi_x86_32 32); do
-       (
-               einfo "Configuring ${PN} for ${bits}bits in 
${WORKDIR}/build${bits} ..."
-
-               mkdir ../build${bits} || die
-               cd ../build${bits} || die
-
-               # CROSSCC_amd64/x86 are unused by Wine, but recognized here for 
users
-               if (( bits == 64 )); then
-                       : "${CROSSCC:=${CROSSCC_amd64:-x86_64-w64-mingw32-gcc}}"
-                       conf+=( --enable-win64 )
-               elif use amd64; then
-                       conf+=(
-                               $(usev abi_x86_64 --with-wine64=../build64)
-                               TARGETFLAGS=-m32 # for widl
-                       )
-                       # _setup is optional, but use over Wine's auto-detect 
(+#472038)
-                       multilib_toolchain_setup x86
-               fi
-               : "${CROSSCC:=${CROSSCC_x86:-i686-w64-mingw32-gcc}}"
-
-               # use *FLAGS for mingw, but strip unsupported (e.g. 
--hash-style=gnu)
-               if use mingw; then
-                       : "${CROSSCFLAGS:=$(
-                               filter-flags '-fstack-clash-protection' #758914
-                               filter-flags '-fstack-protector*' #870136
-                               filter-flags '-mfunction-return=thunk*' #878849
-                               CC=${CROSSCC} test-flags-CC ${CFLAGS:--O2})}"
-                       : "${CROSSLDFLAGS:=$(
-                               filter-flags '-fuse-ld=*'
-                               CC=${CROSSCC} test-flags-CCLD ${LDFLAGS})}"
-                       export CROSS{CC,{C,LD}FLAGS}
-               fi
-
-               ECONF_SOURCE=${S} econf "${conf[@]}"
-       )
-       done
-}
-
-src_compile() {
-       use abi_x86_64 && emake -C ../build64 # do first
-       use abi_x86_32 && emake -C ../build32
-}
-
-src_install() {
-       use abi_x86_32 && emake DESTDIR="${D}" -C ../build32 install
-       use abi_x86_64 && emake DESTDIR="${D}" -C ../build64 install # do last
-
-       # symlink for plain 'wine' and install its man pages if 64bit-only 
#404331
-       if use abi_x86_64 && use !abi_x86_32; then
-               dosym wine64 ${WINE_PREFIX}/bin/wine
-               dosym wine64-preloader ${WINE_PREFIX}/bin/wine-preloader
-               local man
-               for man in ../build64/loader/wine.*man; do
-                       : "${man##*/wine}"
-                       : "${_%.*}"
-                       insinto ${WINE_DATADIR}/man/${_:+${_#.}/}man1
-                       newins ${man} wine.1
-               done
-       fi
-
-       use perl || rm "${ED}"${WINE_DATADIR}/man/man1/wine{dump,maker}.1 \
-               "${ED}"${WINE_PREFIX}/bin/{function_grep.pl,wine{dump,maker}} 
|| die
-
-       # create variant wrappers for eselect-wine
-       local bin
-       for bin in "${ED}"${WINE_PREFIX}/bin/*; do
-               make_wrapper "${bin##*/}-${P#wine-}" "${bin#"${ED}"}"
-       done
-
-       # don't let portage try to strip PE files with the wrong
-       # strip executable and instead handle it here (saves ~120MB)
-       if use mingw; then
-               dostrip -x ${WINE_PREFIX}/wine/{i386,x86_64}-windows
-               use debug ||
-                       find "${ED}"${WINE_PREFIX}/wine/*-windows -regex 
'.*\.\(a\|dll\|exe\)' \
-                               -exec $(usex abi_x86_64 x86_64 
i686)-w64-mingw32-strip --strip-unneeded {} + || die
-       fi
-
-       dodoc ANNOUNCE AUTHORS README* documentation/README*
-}
-
-pkg_postinst() {
-       eselect wine update --if-unset || die
-}
-
-pkg_postrm() {
-       eselect wine update --if-unset || die
-}

diff --git a/app-emulation/wine-staging/wine-staging-7.21-r1.ebuild 
b/app-emulation/wine-staging/wine-staging-7.21-r1.ebuild
deleted file mode 100644
index e8506e11fcba..000000000000
--- a/app-emulation/wine-staging/wine-staging-7.21-r1.ebuild
+++ /dev/null
@@ -1,358 +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 autotools flag-o-matic multilib multilib-build toolchain-funcs wrapper
-
-WINE_GECKO=2.47.3
-WINE_MONO=7.4.0
-
-if [[ ${PV} == *9999 ]]; then
-       inherit git-r3
-       EGIT_REPO_URI="https://github.com/wine-staging/wine-staging.git";
-       WINE_EGIT_REPO_URI="https://gitlab.winehq.org/wine/wine.git";
-else
-       (( $(ver_cut 2) )) && WINE_SDIR=$(ver_cut 1).x || WINE_SDIR=$(ver_cut 
1).0
-       SRC_URI="
-               https://dl.winehq.org/wine/source/${WINE_SDIR}/wine-${PV}.tar.xz
-               
https://github.com/wine-staging/wine-staging/archive/v${PV}.tar.gz -> 
${P}.tar.gz"
-       KEYWORDS="-* ~amd64 ~x86"
-fi
-S="${WORKDIR}/wine-${PV}"
-
-DESCRIPTION="Free implementation of Windows(tm) on Unix, with Wine-Staging 
patchset"
-HOMEPAGE="https://wiki.winehq.org/Wine-Staging";
-
-LICENSE="LGPL-2.1+ BSD-2 IJG MIT ZLIB gsm libpng2 libtiff"
-SLOT="${PV}"
-IUSE="
-       +X +abi_x86_32 +abi_x86_64 +alsa capi crossdev-mingw cups dos
-       llvm-libunwind debug custom-cflags +fontconfig +gecko gphoto2
-       +gstreamer kerberos ldap +mingw +mono netapi nls odbc opencl
-       +opengl osmesa pcap perl pulseaudio samba scanner +sdl selinux
-       +ssl +truetype udev udisks +unwind usb v4l +vulkan +xcomposite
-       xinerama"
-REQUIRED_USE="
-       X? ( truetype )
-       crossdev-mingw? ( mingw )" # bug #551124 for truetype
-
-# tests are non-trivial to run, can hang easily, don't play well with
-# sandbox, and several need real opengl/vulkan or network access
-RESTRICT="test"
-
-# `grep WINE_CHECK_SONAME configure.ac` + if not directly linked
-WINE_DLOPEN_DEPEND="
-       X? (
-               x11-libs/libXcursor[${MULTILIB_USEDEP}]
-               x11-libs/libXfixes[${MULTILIB_USEDEP}]
-               x11-libs/libXi[${MULTILIB_USEDEP}]
-               x11-libs/libXrandr[${MULTILIB_USEDEP}]
-               x11-libs/libXrender[${MULTILIB_USEDEP}]
-               x11-libs/libXxf86vm[${MULTILIB_USEDEP}]
-               opengl? (
-                       media-libs/libglvnd[X,${MULTILIB_USEDEP}]
-                       osmesa? ( media-libs/mesa[osmesa,${MULTILIB_USEDEP}] )
-               )
-               xcomposite? ( x11-libs/libXcomposite[${MULTILIB_USEDEP}] )
-               xinerama? ( x11-libs/libXinerama[${MULTILIB_USEDEP}] )
-       )
-       cups? ( net-print/cups[${MULTILIB_USEDEP}] )
-       fontconfig? ( media-libs/fontconfig[${MULTILIB_USEDEP}] )
-       kerberos? ( virtual/krb5[${MULTILIB_USEDEP}] )
-       netapi? ( net-fs/samba[${MULTILIB_USEDEP}] )
-       odbc? ( dev-db/unixODBC[${MULTILIB_USEDEP}] )
-       sdl? ( media-libs/libsdl2[haptic,joystick,${MULTILIB_USEDEP}] )
-       ssl? ( net-libs/gnutls:=[${MULTILIB_USEDEP}] )
-       truetype? ( media-libs/freetype[${MULTILIB_USEDEP}] )
-       udisks? ( sys-apps/dbus[${MULTILIB_USEDEP}] )
-       v4l? ( media-libs/libv4l[${MULTILIB_USEDEP}] )
-       vulkan? ( media-libs/vulkan-loader[${MULTILIB_USEDEP}] )"
-WINE_COMMON_DEPEND="
-       ${WINE_DLOPEN_DEPEND}
-       X? (
-               x11-libs/libX11[${MULTILIB_USEDEP}]
-               x11-libs/libXext[${MULTILIB_USEDEP}]
-       )
-       alsa? ( media-libs/alsa-lib[${MULTILIB_USEDEP}] )
-       capi? ( net-libs/libcapi:=[${MULTILIB_USEDEP}] )
-       gphoto2? ( media-libs/libgphoto2:=[${MULTILIB_USEDEP}] )
-       gstreamer? (
-               dev-libs/glib:2[${MULTILIB_USEDEP}]
-               media-libs/gst-plugins-base:1.0[${MULTILIB_USEDEP}]
-               media-libs/gstreamer:1.0[${MULTILIB_USEDEP}]
-       )
-       ldap? ( net-nds/openldap:=[${MULTILIB_USEDEP}] )
-       opencl? ( virtual/opencl[${MULTILIB_USEDEP}] )
-       pcap? ( net-libs/libpcap[${MULTILIB_USEDEP}] )
-       pulseaudio? ( media-libs/libpulse[${MULTILIB_USEDEP}] )
-       scanner? ( media-gfx/sane-backends[${MULTILIB_USEDEP}] )
-       udev? ( virtual/libudev:=[${MULTILIB_USEDEP}] )
-       unwind? (
-               llvm-libunwind? ( sys-libs/llvm-libunwind[${MULTILIB_USEDEP}] )
-               !llvm-libunwind? ( sys-libs/libunwind:=[${MULTILIB_USEDEP}] )
-       )
-       usb? ( dev-libs/libusb:1[${MULTILIB_USEDEP}] )"
-RDEPEND="
-       ${WINE_COMMON_DEPEND}
-       app-emulation/wine-desktop-common
-       dos? ( games-emulation/dosbox )
-       gecko? ( app-emulation/wine-gecko:${WINE_GECKO}[${MULTILIB_USEDEP}] )
-       gstreamer? ( media-plugins/gst-plugins-meta:1.0[${MULTILIB_USEDEP}] )
-       mono? ( app-emulation/wine-mono:${WINE_MONO} )
-       perl? (
-               dev-lang/perl
-               dev-perl/XML-LibXML
-       )
-       samba? ( net-fs/samba[winbind] )
-       selinux? ( sec-policy/selinux-wine )
-       udisks? ( sys-fs/udisks:2 )"
-DEPEND="
-       ${WINE_COMMON_DEPEND}
-       sys-kernel/linux-headers
-       X? ( x11-base/xorg-proto )"
-BDEPEND="
-       dev-lang/perl
-       sys-devel/binutils
-       sys-devel/bison
-       sys-devel/flex
-       virtual/pkgconfig
-       mingw? ( !crossdev-mingw? (
-               >=dev-util/mingw64-toolchain-10.0.0_p1-r2[${MULTILIB_USEDEP}]
-       ) )
-       nls? ( sys-devel/gettext )"
-IDEPEND=">=app-eselect/eselect-wine-2"
-
-QA_TEXTRELS="usr/lib/*/wine/i386-unix/*.so" # uses -fno-PIC -Wl,-z,notext
-
-PATCHES=(
-       "${FILESDIR}"/${PN}-7.17-noexecstack.patch
-       "${FILESDIR}"/${PN}-7.20-unwind.patch
-       "${FILESDIR}"/${P}-crossflags.patch
-       "${FILESDIR}"/${P}-opengl32.patch
-)
-
-pkg_pretend() {
-       [[ ${MERGE_TYPE} == binary ]] && return
-
-       if use crossdev-mingw && [[ ! -v MINGW_BYPASS ]]; then
-               local mingw=-w64-mingw32
-               for mingw in $(usev abi_x86_64 x86_64${mingw}) $(usev 
abi_x86_32 i686${mingw}); do
-                       if ! type -P ${mingw}-gcc >/dev/null; then
-                               eerror "With USE=crossdev-mingw, you must 
prepare the MinGW toolchain"
-                               eerror "yourself by installing 
sys-devel/crossdev then running:"
-                               eerror
-                               eerror "    crossdev --target ${mingw}"
-                               eerror
-                               eerror "For more information, please see: 
https://wiki.gentoo.org/wiki/Mingw";
-                               die "USE=crossdev-mingw is enabled, but 
${mingw}-gcc was not found"
-                       fi
-               done
-       fi
-}
-
-src_unpack() {
-       if [[ ${PV} == *9999 ]]; then
-               EGIT_CHECKOUT_DIR=${WORKDIR}/${P}
-               git-r3_src_unpack
-
-               EGIT_COMMIT=$(<"${EGIT_CHECKOUT_DIR}"/staging/upstream-commit) 
|| die
-               EGIT_REPO_URI=${WINE_EGIT_REPO_URI}
-               EGIT_CHECKOUT_DIR=${S}
-               einfo "Fetching Wine commit matching the current patchset by 
default (${EGIT_COMMIT})"
-               git-r3_src_unpack
-       else
-               default
-       fi
-}
-
-src_prepare() {
-       local staging=(
-               ./patchinstall.sh DESTDIR="${S}"
-               --all
-               --backend=eapply
-               --no-autoconf
-               -W winemenubuilder-Desktop_Icon_Path #652176
-               ${MY_WINE_STAGING_CONF}
-       )
-
-       # source patcher in a subshell so can use eapply as a backend
-       ebegin "Running ${staging[*]}"
-       ( cd ../${P}/patches && . "${staging[@]}" )
-       eend ${?} || die "Failed to apply the patchset"
-
-       # sanity check, bumping these has a history of oversights
-       local geckomono=$(sed -En '/^#define (GECKO|MONO)_VER/{s/[^0-9.]//gp}' \
-               dlls/appwiz.cpl/addons.c || die)
-       if [[ ${WINE_GECKO}$'\n'${WINE_MONO} != "${geckomono}" ]]; then
-               local gmfatal=
-               [[ ${PV} == *9999 ]] && gmfatal=nonfatal
-               ${gmfatal} die -n "gecko/mono mismatch in ebuild, has: " 
${geckomono} " (please file a bug)"
-       fi
-
-       default
-
-       # ensure .desktop calls this variant + slot
-       sed -i "/^Exec=/s/wine /${P} /" loader/wine.desktop || die
-
-       # always update for patches (including user's wrt #432348)
-       eautoreconf
-       tools/make_requests || die # perl
-}
-
-src_configure() {
-       WINE_PREFIX=/usr/lib/${P}
-       WINE_DATADIR=/usr/share/${P}
-
-       local conf=(
-               --prefix="${EPREFIX}"${WINE_PREFIX}
-               --datadir="${EPREFIX}"${WINE_DATADIR}
-               --includedir="${EPREFIX}"/usr/include/${P}
-               --libdir="${EPREFIX}"${WINE_PREFIX}
-               --mandir="${EPREFIX}"${WINE_DATADIR}/man
-               $(use_enable gecko mshtml)
-               $(use_enable mono mscoree)
-               --disable-tests
-               $(use_with X x)
-               $(use_with alsa)
-               $(use_with capi)
-               $(use_with cups)
-               $(use_with fontconfig)
-               $(use_with gphoto2 gphoto)
-               $(use_with gstreamer)
-               $(use_with kerberos gssapi)
-               $(use_with kerberos krb5)
-               $(use_with ldap)
-               $(use_with mingw)
-               $(use_with netapi)
-               $(use_with nls gettext)
-               $(use_with opencl)
-               $(use_with opengl)
-               $(use_with osmesa)
-               --without-oss # media-sound/oss is not packaged (OSSv4)
-               $(use_with pcap)
-               $(use_with pulseaudio pulse)
-               $(use_with scanner sane)
-               $(use_with sdl)
-               $(use_with ssl gnutls)
-               $(use_with truetype freetype)
-               $(use_with udev)
-               $(use_with udisks dbus) # dbus is only used for udisks
-               $(use_with unwind)
-               $(use_with usb)
-               $(use_with v4l v4l2)
-               $(use_with vulkan)
-               $(use_with xcomposite)
-               $(use_with xinerama)
-               $(usev !odbc ac_cv_lib_soname_odbc=)
-       )
-
-       tc-ld-force-bfd # builds with non-bfd but broken at runtime (bug 
#867097)
-       filter-lto # build failure
-       use mingw || filter-flags -fno-plt # build failure
-       use custom-cflags || strip-flags # can break in obscure ways at runtime
-       use crossdev-mingw || 
PATH=${BROOT}/usr/lib/mingw64-toolchain/bin:${PATH}
-
-       # temporary workaround for tc-ld-force-bfd not yet enforcing with mold
-       # https://github.com/gentoo/gentoo/pull/28355
-       [[ $($(tc-getCC) ${LDFLAGS} -Wl,--version 2>/dev/null) == mold* ]] &&
-               append-ldflags -fuse-ld=bfd
-
-       # build using upstream's way (--with-wine64)
-       # order matters: configure+compile 64->32, install 32->64
-       local -i bits
-       for bits in $(usev abi_x86_64 64) $(usev abi_x86_32 32); do
-       (
-               einfo "Configuring ${PN} for ${bits}bits in 
${WORKDIR}/build${bits} ..."
-
-               mkdir ../build${bits} || die
-               cd ../build${bits} || die
-
-               pe_arch=i386
-               if (( bits == 64 )); then
-                       pe_arch=x86_64
-                       : "${CROSSCC:=${CROSSCC_amd64:-x86_64-w64-mingw32-gcc}}"
-                       conf+=( --enable-win64 )
-               elif use amd64; then
-                       conf+=(
-                               $(usev abi_x86_64 --with-wine64=../build64)
-                               TARGETFLAGS=-m32 # for widl
-                       )
-                       # _setup is optional, but use over Wine's auto-detect 
(+#472038)
-                       multilib_toolchain_setup x86
-               fi
-               : "${CROSSCC:=${CROSSCC_x86:-i686-w64-mingw32-gcc}}"
-
-               if use mingw; then
-                       # CROSSCC is no longer recognized by Wine, but still 
use for now
-                       # (future handling for CROSS* variables is subject to 
changes)
-                       conf+=( ac_cv_prog_${pe_arch}_CC="${CROSSCC}" )
-
-                       # use *FLAGS for mingw, but strip unsupported
-                       : "${CROSSCFLAGS:=$(
-                               filter-flags '-fstack-clash-protection' #758914
-                               filter-flags '-fstack-protector*' #870136
-                               filter-flags '-mfunction-return=thunk*' #878849
-                               CC=${CROSSCC} test-flags-CC ${CFLAGS:--O2})}"
-                       : "${CROSSLDFLAGS:=$(
-                               filter-flags '-fuse-ld=*'
-                               CC=${CROSSCC} test-flags-CCLD ${LDFLAGS})}"
-                       export CROSS{C,LD}FLAGS
-               fi
-
-               ECONF_SOURCE=${S} econf "${conf[@]}"
-       )
-       done
-}
-
-src_compile() {
-       use abi_x86_64 && emake -C ../build64 # do first
-       use abi_x86_32 && emake -C ../build32
-}
-
-src_install() {
-       use abi_x86_32 && emake DESTDIR="${D}" -C ../build32 install
-       use abi_x86_64 && emake DESTDIR="${D}" -C ../build64 install # do last
-
-       # symlink for plain 'wine' and install its man pages if 64bit-only 
#404331
-       if use abi_x86_64 && use !abi_x86_32; then
-               dosym wine64 ${WINE_PREFIX}/bin/wine
-               dosym wine64-preloader ${WINE_PREFIX}/bin/wine-preloader
-               local man
-               for man in ../build64/loader/wine.*man; do
-                       : "${man##*/wine}"
-                       : "${_%.*}"
-                       insinto ${WINE_DATADIR}/man/${_:+${_#.}/}man1
-                       newins ${man} wine.1
-               done
-       fi
-
-       use perl || rm "${ED}"${WINE_DATADIR}/man/man1/wine{dump,maker}.1 \
-               "${ED}"${WINE_PREFIX}/bin/{function_grep.pl,wine{dump,maker}} 
|| die
-
-       # create variant wrappers for eselect-wine
-       local bin
-       for bin in "${ED}"${WINE_PREFIX}/bin/*; do
-               make_wrapper "${bin##*/}-${P#wine-}" "${bin#"${ED}"}"
-       done
-
-       # don't let portage try to strip PE files with the wrong
-       # strip executable and instead handle it here (saves ~120MB)
-       if use mingw; then
-               dostrip -x ${WINE_PREFIX}/wine/{i386,x86_64}-windows
-               use debug ||
-                       find "${ED}"${WINE_PREFIX}/wine/*-windows -regex 
'.*\.\(a\|dll\|exe\)' \
-                               -exec $(usex abi_x86_64 x86_64 
i686)-w64-mingw32-strip --strip-unneeded {} + || die
-       fi
-
-       dodoc ANNOUNCE AUTHORS README* documentation/README*
-}
-
-pkg_postinst() {
-       eselect wine update --if-unset || die
-}
-
-pkg_postrm() {
-       eselect wine update --if-unset || die
-}

Reply via email to