commit:     2fa21fd6ae2fa715e69e07582fcf70c007e155b2
Author:     NP-Hardass <NP-Hardass <AT> gentoo <DOT> org>
AuthorDate: Sat Sep 30 17:53:28 2017 +0000
Commit:     NP Hardass <np-hardass <AT> gentoo <DOT> org>
CommitDate: Sat Sep 30 19:35:02 2017 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2fa21fd6

app-emulation/wine-vanilla: Backport freetype-2.8.1 support

Bug: https://bugs.gentoo.org/631376
Bug: https://bugs.gentoo.org/631676

Package-Manager: Portage-2.3.10, Repoman-2.3.3

 app-emulation/wine-vanilla/Manifest                |  1 +
 .../wine-vanilla/files/builtin_ms_va_list.c        |  9 ----
 app-emulation/wine-vanilla/files/pr66838.c         | 36 -------------
 app-emulation/wine-vanilla/files/pr69140.c         | 37 --------------
 .../wine-vanilla/files/wine-1.5.26-winegcc.patch   | 59 ----------------------
 .../wine-vanilla/files/wine-1.6-memset-O3.patch    | 21 --------
 .../files/wine-1.9.5-multilib-portage.patch        | 31 ------------
 .../files/wine-2.0-multislot-apploader.patch       | 14 -----
 ...nilla-2.2.ebuild => wine-vanilla-2.0-r1.ebuild} | 45 +++++++++++------
 ...a-2.0.1.ebuild => wine-vanilla-2.0.1-r1.ebuild} | 45 +++++++++++------
 .../wine-vanilla/wine-vanilla-2.0.1.ebuild         | 39 +++++++++-----
 ...a-2.0.1.ebuild => wine-vanilla-2.0.2-r1.ebuild} | 45 +++++++++++------
 .../wine-vanilla/wine-vanilla-2.0.2.ebuild         | 39 +++++++++-----
 app-emulation/wine-vanilla/wine-vanilla-2.0.ebuild | 39 +++++++++-----
 app-emulation/wine-vanilla/wine-vanilla-2.1.ebuild | 43 +++++++++++-----
 .../wine-vanilla/wine-vanilla-2.10.ebuild          | 43 +++++++++++-----
 .../wine-vanilla/wine-vanilla-2.11.ebuild          | 43 +++++++++++-----
 .../wine-vanilla/wine-vanilla-2.12.ebuild          | 43 +++++++++++-----
 .../wine-vanilla/wine-vanilla-2.13.ebuild          | 43 +++++++++++-----
 .../wine-vanilla/wine-vanilla-2.14.ebuild          | 43 +++++++++++-----
 .../wine-vanilla/wine-vanilla-2.15.ebuild          | 43 +++++++++++-----
 .../wine-vanilla/wine-vanilla-2.16.ebuild          | 43 +++++++++++-----
 .../wine-vanilla/wine-vanilla-2.17.ebuild          | 43 +++++++++++-----
 .../wine-vanilla/wine-vanilla-2.18.ebuild          | 40 ++++++++++-----
 app-emulation/wine-vanilla/wine-vanilla-2.2.ebuild | 43 +++++++++++-----
 app-emulation/wine-vanilla/wine-vanilla-2.3.ebuild | 43 +++++++++++-----
 app-emulation/wine-vanilla/wine-vanilla-2.4.ebuild | 43 +++++++++++-----
 app-emulation/wine-vanilla/wine-vanilla-2.5.ebuild | 43 +++++++++++-----
 app-emulation/wine-vanilla/wine-vanilla-2.6.ebuild | 43 +++++++++++-----
 app-emulation/wine-vanilla/wine-vanilla-2.7.ebuild | 43 +++++++++++-----
 app-emulation/wine-vanilla/wine-vanilla-2.8.ebuild | 43 +++++++++++-----
 app-emulation/wine-vanilla/wine-vanilla-2.9.ebuild | 43 +++++++++++-----
 .../wine-vanilla/wine-vanilla-9999.ebuild          | 47 ++++++++++-------
 33 files changed, 715 insertions(+), 563 deletions(-)

diff --git a/app-emulation/wine-vanilla/Manifest 
b/app-emulation/wine-vanilla/Manifest
index 14fcc0025fa..6ce2882b142 100644
--- a/app-emulation/wine-vanilla/Manifest
+++ b/app-emulation/wine-vanilla/Manifest
@@ -1,3 +1,4 @@
+DIST gentoo-wine-patches-20170830.tar.xz 58456 SHA256 
fb7781d0ae360cbc3860c2d2e81527a1b903da824c01f5d5040e95aaf99a3970 SHA512 
5e5159e3252b246bba0ef7fdba345db3ab1071c5b8b8b625f98eda18779d4024c5b76bdbf49ce7bd5c6b01b422807adf76820beddb2b4a6ee9e67d13052cc575
 WHIRLPOOL 
a79be264bab3fcdeee06fef47efd28e6e1125254ac7f82300cb6ba2591ef69cd76b5fed8f778b1849a0659e680e9fc785f0273d55cb2ed95648a74dffa5e22d2
 DIST wine-2.0.1.tar.xz 18845444 SHA256 
6cfb4eaae566dc7afb7ac0f1f2db2c0d69969952acab0debf084ee8f7b071583 SHA512 
b32d07443655898768383b7409c21093b60c028fef166a596dad5dfab5a329b9fce4552e612c6d182e4f67eb1f28ed497fe2ed6af55d0000d3e96a124547722d
 WHIRLPOOL 
0fbaf53504e4e40db6227f45f5b92ac388c2bf23d4f573e4d3b60ccaaadeeccb5a696226d1bd4aa8b245f21c8d6a13aac423ead3f4692ebc1e8e613714168501
 DIST wine-2.0.2.tar.xz 18854952 SHA256 
f71884f539928877f4b415309f582825d3d3c9976104e43d566944c710713c9a SHA512 
3f37080a951819304cd3475f6012f1d6b5a94879b137cdf816cac4c8fde68ddc777905e92277ec5dce96437d8c32c43d55d3750b582781a9f9774b118f1a5b90
 WHIRLPOOL 
cf21a899c60749c37353abc4ba974b3d6cc369769ace70fde899ff1cb5ac8a97828165cf2dbfbcf0915f5196ac58974948fe3e5b2c9854296a5eea75f8023ae5
 DIST wine-2.0.tar.bz2 23662707 SHA256 
9756f5a2129b6a83ba701e546173cbff86caa671b0af73eb8f72c03b20c066c6 SHA512 
b0a57ba8202d9fc396e5bfb7a7718d6bababbed8f3351e7fdc36afa37f35a871e04903757618f73427aeb71a52b2d323977d79e48f8b38d636f23fd404441186
 WHIRLPOOL 
fa9f774d87dae73c7d1f3b86dc3b03ea27065eb6140f1cac13c82fe16f7ebff8f8365ed447220cf5c2788b9f4aae7c482e4f9e2e69f47e5435209e148f5dbdfe

diff --git a/app-emulation/wine-vanilla/files/builtin_ms_va_list.c 
b/app-emulation/wine-vanilla/files/builtin_ms_va_list.c
deleted file mode 100644
index f36fc2609a0..00000000000
--- a/app-emulation/wine-vanilla/files/builtin_ms_va_list.c
+++ /dev/null
@@ -1,9 +0,0 @@
-/* Taken from Wine's configure script. LGPL 2.1+ */
-
-#include <stdarg.h>
-
-int main(void)
-{
-    void func(__builtin_ms_va_list *args);
-    return 0;
-}

diff --git a/app-emulation/wine-vanilla/files/pr66838.c 
b/app-emulation/wine-vanilla/files/pr66838.c
deleted file mode 100644
index cd616859427..00000000000
--- a/app-emulation/wine-vanilla/files/pr66838.c
+++ /dev/null
@@ -1,36 +0,0 @@
-/* From gcc svn, 
/branches/gcc-5-branch/gcc/testsuite/gcc.target/i386/pr66838.c */
-/* Copyrighted and distributed under the same terms as gcc */
-
-void abort (void);
-
-char global;
-
-__attribute__((sysv_abi, noinline, noclone))
-void sysv_abi_func(char const *desc, void *local)
-{
-  register int esi asm ("esi");
-  register int edi asm ("edi");
-  
-  if (local != &global)
-    abort ();
-
-  /* Clobber some of the extra SYSV ABI registers.  */
-  asm volatile ("movl\t%2, %0\n\tmovl\t%2, %1"
-               : "=r" (esi), "=r" (edi)
-               : "i" (0xdeadbeef));
-}
-
-__attribute__((ms_abi, noinline, noclone))
-void ms_abi_func ()
-{
-  sysv_abi_func ("1st call", &global);
-  sysv_abi_func ("2nd call", &global);
-  sysv_abi_func ("3rd call", &global);
-}
-
-int
-main(void)
-{
-  ms_abi_func();
-  return 0;
-}

diff --git a/app-emulation/wine-vanilla/files/pr69140.c 
b/app-emulation/wine-vanilla/files/pr69140.c
deleted file mode 100644
index 7c9e001f301..00000000000
--- a/app-emulation/wine-vanilla/files/pr69140.c
+++ /dev/null
@@ -1,37 +0,0 @@
-/* { dg-do compile { target lp64 } } */
-/* { dg-options "-O2 -mincoming-stack-boundary=3" } */
-
-typedef struct {
-  unsigned int buf[4];
-  unsigned char in[64];
-} MD4_CTX;
-
-static void
-MD4Transform (unsigned int buf[4], const unsigned int in[16])
-{
-  unsigned int a, b, c, d;
-  (b) += ((((c)) & ((d))) | ((~(c)) & ((a)))) + (in[7]);
-  (a) += ((((b)) & ((c))) | ((~(b)) & ((d)))) + (in[8]);
-  (d) += ((((a)) & ((b))) | ((~(a)) & ((c)))) + (in[9]);
-  buf[3] += d;
-}
-
-void __attribute__((ms_abi))
-MD4Update (MD4_CTX *ctx, const unsigned char *buf)
-{
-  MD4Transform( ctx->buf, (unsigned int *)ctx->in);
-  MD4Transform( ctx->buf, (unsigned int *)ctx->in);
-}
-
-int
-main(void)
-{
-       MD4_CTX ctx_test = 
-    {
-        { 0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476 },
-        { 0, 0 }
-    };
-       unsigned char   buf[64];
-
-       MD4Update(&ctx_test, (const unsigned char *) &buf);
-}

diff --git a/app-emulation/wine-vanilla/files/wine-1.5.26-winegcc.patch 
b/app-emulation/wine-vanilla/files/wine-1.5.26-winegcc.patch
deleted file mode 100644
index 2045e343401..00000000000
--- a/app-emulation/wine-vanilla/files/wine-1.5.26-winegcc.patch
+++ /dev/null
@@ -1,59 +0,0 @@
-http://bugs.gentoo.org/260726
-
-diff --git a/tools/winebuild/main.c b/tools/winebuild/main.c
-index 16b4165..5c77267 100644
---- a/tools/winebuild/main.c
-+++ b/tools/winebuild/main.c
-@@ -48,10 +48,13 @@ int link_ext_symbols = 0;
- int force_pointer_size = 0;
- int unwind_tables = 0;
- 
-+#undef FORCE_POINTER_SIZE
- #ifdef __i386__
- enum target_cpu target_cpu = CPU_x86;
-+#define FORCE_POINTER_SIZE
- #elif defined(__x86_64__)
- enum target_cpu target_cpu = CPU_x86_64;
-+#define FORCE_POINTER_SIZE
- #elif defined(__powerpc__)
- enum target_cpu target_cpu = CPU_POWERPC;
- #elif defined(__arm__)
-@@ -611,6 +614,10 @@ int main(int argc, char **argv)
-     signal( SIGTERM, exit_on_signal );
-     signal( SIGINT, exit_on_signal );
- 
-+#ifdef FORCE_POINTER_SIZE
-+    force_pointer_size = sizeof(size_t);
-+#endif
-+
-     output_file = stdout;
-     argv = parse_options( argc, argv, spec );
- 
-diff --git a/tools/winegcc/winegcc.c b/tools/winegcc/winegcc.c
-index 06aa200..c44d2e3 100644
---- a/tools/winegcc/winegcc.c
-+++ b/tools/winegcc/winegcc.c
-@@ -213,10 +213,13 @@ struct options
-     strarray* files;
- };
- 
-+#undef FORCE_POINTER_SIZE
- #ifdef __i386__
- static const enum target_cpu build_cpu = CPU_x86;
-+#define FORCE_POINTER_SIZE
- #elif defined(__x86_64__)
- static const enum target_cpu build_cpu = CPU_x86_64;
-+#define FORCE_POINTER_SIZE
- #elif defined(__powerpc__)
- static const enum target_cpu build_cpu = CPU_POWERPC;
- #elif defined(__arm__)
-@@ -1258,6 +1261,9 @@ int main(int argc, char **argv)
-     opts.linker_args = strarray_alloc();
-     opts.compiler_args = strarray_alloc();
-     opts.winebuild_args = strarray_alloc();
-+#ifdef FORCE_POINTER_SIZE
-+    opts.force_pointer_size = sizeof(size_t);
-+#endif
- 
-     /* determine the processor type */
-     if (strendswith(argv[0], "winecpp")) opts.processor = proc_cpp;

diff --git a/app-emulation/wine-vanilla/files/wine-1.6-memset-O3.patch 
b/app-emulation/wine-vanilla/files/wine-1.6-memset-O3.patch
deleted file mode 100644
index 75372f86914..00000000000
--- a/app-emulation/wine-vanilla/files/wine-1.6-memset-O3.patch
+++ /dev/null
@@ -1,21 +0,0 @@
-Avoid "undefined reference to `memset'" error when building with
-USE=custom-cflags and -O3 in CFLAGS with gcc-4.8.
-
-See:
-
-http://gcc.gnu.org/bugzilla/show_bug.cgi?id=56888
-http://bugs.winehq.org/show_bug.cgi?id=33521
-https://bugs.gentoo.org/show_bug.cgi?id=480508
-
-diff --git a/configure.ac b/configure.ac
-index d8033cf..fe7cc7d 100644
---- a/configure.ac
-+++ b/configure.ac
-@@ -1767,6 +1767,7 @@ then
- 
-   dnl Check for some compiler flags
-   WINE_TRY_CFLAGS([-fno-builtin],[AC_SUBST(BUILTINFLAG,"-fno-builtin")])
-+  WINE_TRY_CFLAGS([-fno-tree-loop-distribute-patterns])
-   WINE_TRY_CFLAGS([-fno-strict-aliasing])
-   dnl clang needs to be told to fail on unknown options
-   saved_CFLAGS=$CFLAGS

diff --git a/app-emulation/wine-vanilla/files/wine-1.9.5-multilib-portage.patch 
b/app-emulation/wine-vanilla/files/wine-1.9.5-multilib-portage.patch
deleted file mode 100644
index c19d0d8a0b0..00000000000
--- a/app-emulation/wine-vanilla/files/wine-1.9.5-multilib-portage.patch
+++ /dev/null
@@ -1,31 +0,0 @@
-https://bugs.gentoo.org/show_bug.cgi?id=395615
-
-Explicitly add the required -m32/m64 to *FLAGS; this overrides any 
-arch-specific -m* flags that may have been appended by multilib-portage.
-
-Even though -m32/m64 is now added to *FLAGS, -m32/m64 still has to be
-explicitly added to CC and CXX due to wine's build system. For example,
-winegcc saves the build-time value of CC and uses it at runtime.
-
---- a/configure.ac     2016-03-05 20:53:50.574628728 -0500
-+++ b/configure.ac     2016-03-05 20:57:54.945617833 -0500
-@@ -141,6 +141,9 @@
-     then
-       CC="$CC -m32"
-       CXX="$CXX -m32"
-+      CFLAGS="$CFLAGS -m32"
-+      LDFLAGS="$LDFLAGS -m32"
-+      CXXFLAGS="$CXXFLAGS -m32"
-       AC_MSG_CHECKING([whether $CC works])
-       AC_LINK_IFELSE([AC_LANG_PROGRAM()],AC_MSG_RESULT([yes]),
-                      [AC_MSG_RESULT([no])
-@@ -160,6 +163,9 @@
-       fi
-       CC="$CC -m64"
-       CXX="$CXX -m64"
-+      CFLAGS="$CFLAGS -m64"
-+      LDFLAGS="$LDFLAGS -m64"
-+      CXXFLAGS="$CXXFLAGS -m64"
-       host_cpu="x86_64"
-       notice_platform="64-bit "
-       AC_SUBST(TARGETFLAGS,"-m64")

diff --git 
a/app-emulation/wine-vanilla/files/wine-2.0-multislot-apploader.patch 
b/app-emulation/wine-vanilla/files/wine-2.0-multislot-apploader.patch
deleted file mode 100644
index b336c4f51e8..00000000000
--- a/app-emulation/wine-vanilla/files/wine-2.0-multislot-apploader.patch
+++ /dev/null
@@ -1,14 +0,0 @@
-diff --git a/tools/wineapploader.in b/tools/wineapploader.in
-index f48d552..14001a0 100755
---- a/tools/wineapploader.in
-+++ b/tools/wineapploader.in
-@@ -20,7 +20,8 @@
- #
- 
- # determine the app Winelib library name
--appname=`basename "$0" .exe`.exe
-+appname=${0##*/}
-+appname="${appname%%-*}.exe"
- 
- # first try explicit WINELOADER
- if [ -x "$WINELOADER" ]; then exec "$WINELOADER" "$appname" "$@"; fi

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.2.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.0-r1.ebuild
similarity index 92%
copy from app-emulation/wine-vanilla/wine-vanilla-2.2.ebuild
copy to app-emulation/wine-vanilla/wine-vanilla-2.0-r1.ebuild
index e5940fa17ff..697e0f31fb0 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.2.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.0-r1.ebuild
@@ -12,25 +12,25 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
        #KEYWORDS=""
 else
        MAJOR_V=$(get_version_component_range 1)
-       SRC_URI="https://dl.winehq.org/wine/source/${MAJOR_V}.x/${MY_P}.tar.xz";
+       SRC_URI="https://dl.winehq.org/wine/source/${MAJOR_V}.x/${MY_P}.tar.bz2";
        KEYWORDS="-* ~amd64 ~x86 ~x86-fbsd"
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -131,6 +131,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -158,7 +159,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +175,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +191,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +290,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +328,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.0.1.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.0.1-r1.ebuild
similarity index 92%
copy from app-emulation/wine-vanilla/wine-vanilla-2.0.1.ebuild
copy to app-emulation/wine-vanilla/wine-vanilla-2.0.1-r1.ebuild
index 3956ec1c0a3..72ca9065ccc 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.0.1.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.0.1-r1.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -20,17 +20,17 @@ if [[ ${PV} == "9999" ]] ; then
 else
        MAJOR_V=$(get_version_component_range 1)
        SRC_URI="https://dl.winehq.org/wine/source/${MAJOR_V}.0/${MY_P}.tar.xz";
-       KEYWORDS="-* amd64 x86 ~x86-fbsd"
+       KEYWORDS="-* ~amd64 ~x86 ~x86-fbsd"
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -131,6 +131,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -158,7 +159,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +175,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +191,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +290,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +328,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.0.1.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.0.1.ebuild
index 3956ec1c0a3..4024b479135 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.0.1.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.0.1.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -158,7 +158,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +174,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +190,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +289,26 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+       )
+       local PATCHES_BIN=(
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +324,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.0.1.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.0.2-r1.ebuild
similarity index 92%
copy from app-emulation/wine-vanilla/wine-vanilla-2.0.1.ebuild
copy to app-emulation/wine-vanilla/wine-vanilla-2.0.2-r1.ebuild
index 3956ec1c0a3..72ca9065ccc 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.0.1.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.0.2-r1.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -20,17 +20,17 @@ if [[ ${PV} == "9999" ]] ; then
 else
        MAJOR_V=$(get_version_component_range 1)
        SRC_URI="https://dl.winehq.org/wine/source/${MAJOR_V}.0/${MY_P}.tar.xz";
-       KEYWORDS="-* amd64 x86 ~x86-fbsd"
+       KEYWORDS="-* ~amd64 ~x86 ~x86-fbsd"
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -131,6 +131,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -158,7 +159,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +175,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +191,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +290,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +328,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.0.2.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.0.2.ebuild
index 3956ec1c0a3..4024b479135 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.0.2.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.0.2.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -158,7 +158,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +174,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +190,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +289,26 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+       )
+       local PATCHES_BIN=(
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +324,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.0.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.0.ebuild
index 442e17cd864..3ebfd211d13 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.0.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.0.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -158,7 +158,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +174,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +190,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +289,26 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+       )
+       local PATCHES_BIN=(
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +324,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.1.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.1.ebuild
index e5940fa17ff..5d4299bca59 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.1.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.1.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -131,6 +131,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -158,7 +159,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +175,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +191,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +290,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +328,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.10.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.10.ebuild
index 39a904b169a..b79fd64dd9a 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.10.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.10.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -132,6 +132,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -159,7 +160,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -175,7 +176,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -191,7 +192,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -290,15 +291,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -314,8 +329,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.11.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.11.ebuild
index 39a904b169a..b79fd64dd9a 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.11.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.11.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -132,6 +132,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -159,7 +160,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -175,7 +176,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -191,7 +192,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -290,15 +291,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -314,8 +329,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.12.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.12.ebuild
index 39a904b169a..b79fd64dd9a 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.12.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.12.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -132,6 +132,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -159,7 +160,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -175,7 +176,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -191,7 +192,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -290,15 +291,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -314,8 +329,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.13.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.13.ebuild
index 39a904b169a..b79fd64dd9a 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.13.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.13.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -132,6 +132,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -159,7 +160,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -175,7 +176,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -191,7 +192,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -290,15 +291,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -314,8 +329,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.14.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.14.ebuild
index 08531aba8cd..ef68ed71111 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.14.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.14.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -132,6 +132,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -159,7 +160,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -175,7 +176,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -191,7 +192,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -290,15 +291,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -314,8 +329,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.15.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.15.ebuild
index 08531aba8cd..ef68ed71111 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.15.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.15.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -132,6 +132,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -159,7 +160,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -175,7 +176,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -191,7 +192,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -290,15 +291,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -314,8 +329,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.16.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.16.ebuild
index 08531aba8cd..ef68ed71111 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.16.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.16.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -132,6 +132,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -159,7 +160,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -175,7 +176,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -191,7 +192,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -290,15 +291,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -314,8 +329,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.17.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.17.ebuild
index 08531aba8cd..ef68ed71111 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.17.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.17.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -132,6 +132,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -159,7 +160,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -175,7 +176,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -191,7 +192,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -290,15 +291,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -314,8 +329,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.18.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.18.ebuild
index 08531aba8cd..8851cfc5ac4 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.18.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.18.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -132,6 +132,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -159,7 +160,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -175,7 +176,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -191,7 +192,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -290,15 +291,26 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+       )
+       local PATCHES_BIN=(
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -314,8 +326,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.2.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.2.ebuild
index e5940fa17ff..5d4299bca59 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.2.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.2.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -131,6 +131,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -158,7 +159,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +175,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +191,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +290,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +328,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.3.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.3.ebuild
index e5940fa17ff..5d4299bca59 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.3.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.3.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -131,6 +131,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -158,7 +159,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +175,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +191,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +290,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +328,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.4.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.4.ebuild
index eedca27e1d2..757d3e9e857 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.4.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.4.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -131,6 +131,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -158,7 +159,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +175,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +191,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +290,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +328,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.5.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.5.ebuild
index eedca27e1d2..757d3e9e857 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.5.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.5.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -131,6 +131,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -158,7 +159,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +175,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +191,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +290,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +328,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.6.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.6.ebuild
index eedca27e1d2..757d3e9e857 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.6.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.6.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -131,6 +131,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -158,7 +159,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +175,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +191,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +290,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +328,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.7.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.7.ebuild
index eedca27e1d2..757d3e9e857 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.7.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.7.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -131,6 +131,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -158,7 +159,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +175,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +191,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +290,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +328,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.8.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.8.ebuild
index eedca27e1d2..757d3e9e857 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.8.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.8.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -131,6 +131,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -158,7 +159,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -174,7 +175,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -190,7 +191,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -289,15 +290,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -313,8 +328,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-2.9.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-2.9.ebuild
index 39a904b169a..b79fd64dd9a 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-2.9.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-2.9.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -132,6 +132,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -159,7 +160,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -175,7 +176,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -191,7 +192,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -290,15 +291,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -314,8 +329,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }

diff --git a/app-emulation/wine-vanilla/wine-vanilla-9999.ebuild 
b/app-emulation/wine-vanilla/wine-vanilla-9999.ebuild
index 08531aba8cd..757d3e9e857 100644
--- a/app-emulation/wine-vanilla/wine-vanilla-9999.ebuild
+++ b/app-emulation/wine-vanilla/wine-vanilla-9999.ebuild
@@ -12,7 +12,7 @@ MY_PN="${PN%%-*}"
 MY_P="${MY_PN}-${PV}"
 
 if [[ ${PV} == "9999" ]] ; then
-       EGIT_REPO_URI="https://source.winehq.org/git/wine.git 
http://source.winehq.org/git/wine.git";
+       EGIT_REPO_URI="https://source.winehq.org/git/wine.git";
        EGIT_BRANCH="master"
        inherit git-r3
        SRC_URI=""
@@ -24,13 +24,13 @@ else
 fi
 S="${WORKDIR}/${MY_P}"
 
-WDC_V="20150204"
-WINE_DESKTOP_COMMON_P="wine-desktop-common-${WDC_V}"
+GWP_V="20170830"
+PATCHDIR="${WORKDIR}/gentoo-wine-patches"
 
 DESCRIPTION="Free implementation of Windows(tm) on Unix, without external 
patchsets"
-HOMEPAGE="http://www.winehq.org/";
+HOMEPAGE="https://www.winehq.org/";
 SRC_URI="${SRC_URI}
-       
https://github.com/NP-Hardass/wine-desktop-common/archive/${WDC_V}.tar.gz -> 
${WINE_DESKTOP_COMMON_P}.tar.gz
+       
https://dev.gentoo.org/~np-hardass/distfiles/wine/gentoo-wine-patches-${GWP_V}.tar.xz
 "
 
 LICENSE="LGPL-2.1"
@@ -50,7 +50,6 @@ COMMON_DEPEND="
        X? (
                x11-libs/libXcursor[${MULTILIB_USEDEP}]
                x11-libs/libXext[${MULTILIB_USEDEP}]
-               x11-libs/libXfixes[${MULTILIB_USEDEP}]
                x11-libs/libXrandr[${MULTILIB_USEDEP}]
                x11-libs/libXi[${MULTILIB_USEDEP}]
                x11-libs/libXxf86vm[${MULTILIB_USEDEP}]
@@ -118,7 +117,7 @@ RDEPEND="${COMMON_DEPEND}
        !app-emulation/wine:0
        dos? ( >=games-emulation/dosbox-0.74_p20160629 )
        gecko? ( app-emulation/wine-gecko:2.47[abi_x86_32?,abi_x86_64?] )
-       mono? ( app-emulation/wine-mono:4.7.1 )
+       mono? ( app-emulation/wine-mono:4.7.0 )
        perl? (
                dev-lang/perl
                dev-perl/XML-Simple
@@ -132,6 +131,7 @@ RDEPEND="${COMMON_DEPEND}
 
 # tools/make_requests requires perl
 DEPEND="${COMMON_DEPEND}
+       dev-util/patchbin
        sys-devel/flex
        >=sys-kernel/linux-headers-2.6
        virtual/pkgconfig
@@ -159,7 +159,7 @@ wine_compiler_check() {
                # bug #549768
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) -le 2 ]]; then
                        ebegin "Checking for gcc-5 ms_abi compiler bug"
-                       $(tc-getCC) -O2 "${FILESDIR}"/pr66838.c -o 
"${T}"/pr66838 || die
+                       $(tc-getCC) -O2 "${PATCHDIR}/files/pr66838.c" -o 
"${T}"/pr66838 || die
                        # Run in subshell to prevent "Aborted" message
                        ( "${T}"/pr66838 || false ) >/dev/null 2>&1
                        if ! eend $?; then
@@ -175,7 +175,7 @@ wine_compiler_check() {
                if use abi_x86_64 && [[ $(gcc-major-version) = 5 && 
$(gcc-minor-version) = 3 ]]; then
                        ebegin "Checking for gcc-5-3 stack realignment compiler 
bug"
                        # Compile in subshell to prevent "Aborted" message
-                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${FILESDIR}"/pr69140.c -o "${T}"/pr69140 ) >/dev/null 2>&1
+                       ( $(tc-getCC) -O2 -mincoming-stack-boundary=3 
"${PATCHDIR}/files/pr69140.c" -o "${T}"/pr69140 ) >/dev/null 2>&1
                        if ! eend $?; then
                                eerror "Wine cannot be built with this version 
of gcc-5.3"
                                eerror "due to compiler bugs; please re-emerge 
the latest gcc-5.3.x ebuild,"
@@ -191,7 +191,7 @@ wine_compiler_check() {
        if use abi_x86_64; then
                ebegin "Checking for 64-bit compiler with builtin_ms_va_list 
support"
                # Compile in subshell to prevent "Aborted" message
-               ( $(tc-getCC) -O2 "${FILESDIR}"/builtin_ms_va_list.c -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
+               ( $(tc-getCC) -O2 "${PATCHDIR}/files/builtin_ms_va_list.c" -o 
"${T}"/builtin_ms_va_list >/dev/null 2>&1)
                if ! eend $?; then
                        eerror "This version of $(tc-getCC) does not support 
builtin_ms_va_list, can't enable 64-bit wine"
                        eerror
@@ -290,15 +290,29 @@ src_unpack() {
 }
 
 src_prepare() {
+
+       eapply_bin(){
+               local patch
+               for patch in ${PATCHES_BIN[@]}; do
+                       patchbin --nogit < "${patch}" || die
+               done
+       }
+
        local md5="$(md5sum server/protocol.def)"
        local PATCHES=(
-               "${FILESDIR}"/${MY_PN}-1.5.26-winegcc.patch #260726
-               "${FILESDIR}"/${MY_PN}-1.9.5-multilib-portage.patch #395615
-               "${FILESDIR}"/${MY_PN}-1.6-memset-O3.patch #480508
-               "${FILESDIR}"/${MY_PN}-2.0-multislot-apploader.patch
+               "${PATCHDIR}/patches/${MY_PN}-1.5.26-winegcc.patch" #260726
+               "${PATCHDIR}/patches/${MY_PN}-1.9.5-multilib-portage.patch" 
#395615
+               "${PATCHDIR}/patches/${MY_PN}-1.6-memset-O3.patch" #480508
+               "${PATCHDIR}/patches/${MY_PN}-2.0-multislot-apploader.patch"
+               "${PATCHDIR}/patches/freetype-2.8.1-segfault.patch" #631676
+               "${PATCHDIR}/patches/freetype-2.8.1-drop-glyphs.patch" #631376
+       )
+       local PATCHES_BIN=(
+               "${PATCHDIR}/patches/freetype-2.8.1-patch-fonts.patch" #631376
        )
 
        default
+       eapply_bin
        eautoreconf
 
        # Modification of the server protocol requires regenerating the server 
requests
@@ -314,8 +328,8 @@ src_prepare() {
        # Edit wine.desktop to work for specific variant
        sed -e "/^Exec=/s/wine /wine-${WINE_VARIANT} /" -i loader/wine.desktop 
|| die
 
-       # hi-res default icon, #472990, 
http://bugs.winehq.org/show_bug.cgi?id=24652
-       cp "${WORKDIR}/${WINE_DESKTOP_COMMON_P}/icons/oic_winlogo.ico" 
dlls/user32/resources/ || die
+       # hi-res default icon, #472990, 
https://bugs.winehq.org/show_bug.cgi?id=24652
+       cp "${PATCHDIR}/files/oic_winlogo.ico" dlls/user32/resources/ || die
 
        l10n_get_locales > po/LINGUAS || die # otherwise wine doesn't respect 
LINGUAS
 }
@@ -375,7 +389,6 @@ multilib_src_configure() {
                $(use_with udev)
                $(use_with v4l)
                $(use_with X x)
-               $(use_with X xfixes)
                $(use_with xcomposite)
                $(use_with xinerama)
                $(use_with xml)

Reply via email to