[arch-commits] Commit in spice-gtk3/repos (12 files)

Sergej Pupykin spupykin at archlinux.org
Tue Oct 31 14:12:23 UTC 2017


    Date: Tuesday, October 31, 2017 @ 14:12:22
  Author: spupykin
Revision: 264913

archrelease: copy trunk to community-i686, community-x86_64

Added:
  spice-gtk3/repos/community-i686/PKGBUILD
    (from rev 264912, spice-gtk3/trunk/PKGBUILD)
  spice-gtk3/repos/community-x86_64/PKGBUILD
    (from rev 264912, spice-gtk3/trunk/PKGBUILD)
Deleted:
  spice-gtk3/repos/community-i686/PKGBUILD
  spice-gtk3/repos/community-i686/debian_843471-clipboard_Fix_crash_by_handling_error.patch
  spice-gtk3/repos/community-i686/ssl-Rework-our-custom-BIO-type.patch
  spice-gtk3/repos/community-i686/ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch
  spice-gtk3/repos/community-i686/ssl-Use-accessors-rather-than-direct-struct-access.patch
  spice-gtk3/repos/community-x86_64/PKGBUILD
  spice-gtk3/repos/community-x86_64/debian_843471-clipboard_Fix_crash_by_handling_error.patch
  spice-gtk3/repos/community-x86_64/ssl-Rework-our-custom-BIO-type.patch
  spice-gtk3/repos/community-x86_64/ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch
  spice-gtk3/repos/community-x86_64/ssl-Use-accessors-rather-than-direct-struct-access.patch

----------------------------------------------------------------------------+
 /PKGBUILD                                                                  |   80 ++++
 community-i686/PKGBUILD                                                    |   56 --
 community-i686/debian_843471-clipboard_Fix_crash_by_handling_error.patch   |   40 --
 community-i686/ssl-Rework-our-custom-BIO-type.patch                        |  121 ------
 community-i686/ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch          |   71 ---
 community-i686/ssl-Use-accessors-rather-than-direct-struct-access.patch    |  193 ----------
 community-x86_64/PKGBUILD                                                  |   56 --
 community-x86_64/debian_843471-clipboard_Fix_crash_by_handling_error.patch |   40 --
 community-x86_64/ssl-Rework-our-custom-BIO-type.patch                      |  121 ------
 community-x86_64/ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch        |   71 ---
 community-x86_64/ssl-Use-accessors-rather-than-direct-struct-access.patch  |  193 ----------
 11 files changed, 80 insertions(+), 962 deletions(-)

Deleted: community-i686/PKGBUILD
===================================================================
--- community-i686/PKGBUILD	2017-10-31 14:12:00 UTC (rev 264912)
+++ community-i686/PKGBUILD	2017-10-31 14:12:22 UTC (rev 264913)
@@ -1,56 +0,0 @@
-# $Id$
-# Maintainer: Sergej Pupykin <pupykin.s+arch at gmail.com>
-# Contributor: Stefano Facchini <stefano.facchini at gmail.com>
-# Contributor: Jonathan Lestrelin <zanko at daemontux.org>
-# Contributor: Lucio Zara <pennega at gmail.com>
-
-pkgname=spice-gtk3
-pkgver=0.34
-pkgrel=1
-pkgdesc="Gtk client and libraries for SPICE remote desktop servers (gtk3 version)"
-arch=('i686' 'x86_64')
-url="https://www.spice-space.org"
-license=('LGPL2.1')
-depends=('celt0.5.1' 'dbus-glib' 'gtk3' 'libcacard' 'libpulse' 'usbredir' 'libsoup' 'spice-glib')
-makedepends=('gobject-introspection' 'intltool' 'python2-pyparsing' 'spice-protocol' 'usbutils'
-	     'vala' 'sdl' 'python2-six')
-options=('!emptydirs')
-source=("https://www.spice-space.org/download/gtk/spice-gtk-$pkgver.tar.bz2"
-        debian_843471-clipboard_Fix_crash_by_handling_error.patch
-        ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch
-        ssl-Rework-our-custom-BIO-type.patch
-        ssl-Use-accessors-rather-than-direct-struct-access.patch)
-sha256sums=('e9720e01165f8451c9f3f58ad50e3afb990993b81cc2db86b3661b7ac5b976ee'
-            '31cacbfce3de9c7599f3cca5b45ed76cf5e3997072aae64b4107676b0b9a2f7b'
-            '0e0d553992ea08a29b14439061c6e831ce4ba4bd7bb5e53d7e7e1306aa6ba0fa'
-            '91bbb28dc5a8968c0eea57919d9a4a86384a62909014b53b05b5e721afa8142d'
-            '0e65852f94849c3efe0c21c01f4be7b804641d7d178b12a22eb62f08db70371e')
-
-prepare() {
-  cd "$srcdir/spice-gtk-$pkgver"
-#  patch -Np1 -i ../debian_843471-clipboard_Fix_crash_by_handling_error.patch
-#  patch -Np1 -i ../ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch
-#  patch -Np1 -i ../ssl-Rework-our-custom-BIO-type.patch
-#  patch -Np1 -i ../ssl-Use-accessors-rather-than-direct-struct-access.patch
-}
-
-build() {
-  cd "$srcdir/spice-gtk-$pkgver"
-  PYTHON=python2 ./configure --prefix=/usr \
-    --disable-static --enable-vala --with-gtk=3.0 \
-    --with-audio=pulse \
-    --with-coroutine=gthread --sbindir=/usr/bin \
-    --enable-smartcard
-  sed -i -e 's/ -shared / -Wl,-O1,--as-needed\0/g' libtool
-  make
-}
-
-package() {
-  cd "$srcdir/spice-gtk-$pkgver"
-  make DESTDIR="$pkgdir/" install
-  pacman -Ql spice-glib | cut -f2 -d' ' | while read f; do
-    [ -f "$pkgdir"/$f ] && rm -f "$pkgdir"/$f || true
-    f=$(echo $f | sed 's|.gz$||')
-    [ -f "$pkgdir"/$f ] && rm -f "$pkgdir"/$f || true
-  done
-}

Copied: spice-gtk3/repos/community-i686/PKGBUILD (from rev 264912, spice-gtk3/trunk/PKGBUILD)
===================================================================
--- community-i686/PKGBUILD	                        (rev 0)
+++ community-i686/PKGBUILD	2017-10-31 14:12:22 UTC (rev 264913)
@@ -0,0 +1,40 @@
+# $Id$
+# Maintainer: Sergej Pupykin <pupykin.s+arch at gmail.com>
+# Contributor: Stefano Facchini <stefano.facchini at gmail.com>
+# Contributor: Jonathan Lestrelin <zanko at daemontux.org>
+# Contributor: Lucio Zara <pennega at gmail.com>
+
+pkgname=spice-gtk3
+pkgver=0.34
+pkgrel=2
+pkgdesc="Gtk client and libraries for SPICE remote desktop servers (gtk3 version)"
+arch=('i686' 'x86_64')
+url="https://www.spice-space.org"
+license=('LGPL2.1')
+depends=('celt0.5.1' 'dbus-glib' 'gtk3' 'libcacard' 'libpulse' 'usbredir' 'libsoup' 'spice-glib')
+makedepends=('gobject-introspection' 'intltool' 'python2-pyparsing' 'spice-protocol' 'usbutils'
+	     'vala' 'sdl' 'python2-six')
+options=('!emptydirs')
+source=("https://www.spice-space.org/download/gtk/spice-gtk-$pkgver.tar.bz2")
+sha256sums=('e9720e01165f8451c9f3f58ad50e3afb990993b81cc2db86b3661b7ac5b976ee')
+
+build() {
+  cd "$srcdir/spice-gtk-$pkgver"
+  PYTHON=python2 ./configure --prefix=/usr \
+    --disable-static --enable-vala --with-gtk=3.0 \
+    --with-audio=pulse \
+    --with-coroutine=gthread --sbindir=/usr/bin \
+    --enable-smartcard
+  sed -i -e 's/ -shared / -Wl,-O1,--as-needed\0/g' libtool
+  make
+}
+
+package() {
+  cd "$srcdir/spice-gtk-$pkgver"
+  make DESTDIR="$pkgdir/" install
+  pacman -Ql spice-glib | cut -f2 -d' ' | while read f; do
+    [ -f "$pkgdir"/$f ] && rm -f "$pkgdir"/$f || true
+    f=$(echo $f | sed 's|.gz$||')
+    [ -f "$pkgdir"/$f ] && rm -f "$pkgdir"/$f || true
+  done
+}

Deleted: community-i686/debian_843471-clipboard_Fix_crash_by_handling_error.patch
===================================================================
--- community-i686/debian_843471-clipboard_Fix_crash_by_handling_error.patch	2017-10-31 14:12:00 UTC (rev 264912)
+++ community-i686/debian_843471-clipboard_Fix_crash_by_handling_error.patch	2017-10-31 14:12:22 UTC (rev 264913)
@@ -1,40 +0,0 @@
-commit 03c016bea939ee4a26e90d80fa1012a993a8ea47
-Author: Victor Toso <me at victortoso.com>
-Origin: upstream, https://cgit.freedesktop.org/spice/spice-gtk/commit/?id=03c016bea939ee4a26e90d80fa1012a993a8ea47
-Bug-Debian: https://bugs.debian.org/843471
-Date:   Fri Oct 14 18:12:01 2016 +0200
-
-    clipboard: Fix crash by handling error
-    
-    As manual states below, text could be NULL for different reasons and
-    we should handle that. I've included a debug message to help
-    identifying possible regressions from wayland's clipboard.
-    
-    This crash is a regression from 7b0de6217670e0f668aff2949f
-    
-     "The text parameter to callback will contain the resulting text if
-     the request succeeded, or NULL if it failed. This could happen for
-     various reasons, in particular if the clipboard was empty or if the
-     contents of the clipboard could not be converted into text form."
-    
-    Resolves: rhbz#1384676
-    
-    Signed-off-by: Victor Toso <victortoso at redhat.com>
-    Acked-by: Pavel Grunt <pgrunt at redhat.com>
-
-diff --git a/src/spice-gtk-session.c b/src/spice-gtk-session.c
-index 3ff4e9a..3e0ec74 100644
---- a/src/spice-gtk-session.c
-+++ b/src/spice-gtk-session.c
-@@ -945,6 +945,11 @@ static void clipboard_received_text_cb(GtkClipboard *clipboard,
-     if (self == NULL)
-         return;
- 
-+    if (text == NULL) {
-+        SPICE_DEBUG("Failed to retrieve clipboard text");
-+        return;
-+    }
-+
-     g_return_if_fail(SPICE_IS_GTK_SESSION(self));
- 
-     selection = get_selection_from_clipboard(self->priv, clipboard);

Deleted: community-i686/ssl-Rework-our-custom-BIO-type.patch
===================================================================
--- community-i686/ssl-Rework-our-custom-BIO-type.patch	2017-10-31 14:12:00 UTC (rev 264912)
+++ community-i686/ssl-Rework-our-custom-BIO-type.patch	2017-10-31 14:12:22 UTC (rev 264913)
@@ -1,121 +0,0 @@
-From: Sebastian Andrzej Siewior <sebastian at breakpoint.cc>
-Date: Wed, 26 Oct 2016 17:31:27 +0200
-Origin: upstream, https://cgit.freedesktop.org/spice/spice-gtk/commit/?id=498f5369203d73026e9fb3929fd19a358d76a152
-Bug-Debian: https://bugs.debian.org/851127
-Subject: ssl: Rework our custom BIO type
-
-This commit changes to an actual new BIO method rather than reusing an
-existing BIO method, and overriding only the fields that we need.
-The approach before this commit would be causing issues with OpenSSL
-1.1.0 as some of the fields we access have become opaque.
----
- src/bio-gio.c | 57 ++++++++++++++++++++++++++++-----------------------------
- 1 file changed, 28 insertions(+), 29 deletions(-)
-
-diff --git a/src/bio-gio.c b/src/bio-gio.c
-index b310c97..0f8b415 100644
---- a/src/bio-gio.c
-+++ b/src/bio-gio.c
-@@ -23,21 +23,22 @@
- #include "spice-util.h"
- #include "bio-gio.h"
- 
--typedef struct bio_gsocket_method {
--    BIO_METHOD method;
--    GIOStream *stream;
--} bio_gsocket_method;
--
--#define BIO_GET_GSOCKET(bio)  (((bio_gsocket_method*)bio->method)->gsocket)
--#define BIO_GET_ISTREAM(bio)  (g_io_stream_get_input_stream(((bio_gsocket_method*)bio->method)->stream))
--#define BIO_GET_OSTREAM(bio)  (g_io_stream_get_output_stream(((bio_gsocket_method*)bio->method)->stream))
-+static long bio_gio_ctrl(G_GNUC_UNUSED BIO *b,
-+                         int cmd,
-+                         G_GNUC_UNUSED long num,
-+                         G_GNUC_UNUSED void *ptr)
-+{
-+    return (cmd == BIO_CTRL_FLUSH);
-+}
- 
- static int bio_gio_write(BIO *bio, const char *in, int inl)
- {
-+    GOutputStream *stream;
-     gssize ret;
-     GError *error = NULL;
- 
--    ret = g_pollable_output_stream_write_nonblocking(G_POLLABLE_OUTPUT_STREAM(BIO_GET_OSTREAM(bio)),
-+    stream = g_io_stream_get_output_stream(bio->ptr);
-+    ret = g_pollable_output_stream_write_nonblocking(G_POLLABLE_OUTPUT_STREAM(stream),
-                                                      in, inl, NULL, &error);
-     BIO_clear_retry_flags(bio);
- 
-@@ -53,10 +54,12 @@ static int bio_gio_write(BIO *bio, const char *in, int inl)
- 
- static int bio_gio_read(BIO *bio, char *out, int outl)
- {
-+    GInputStream *stream;
-     gssize ret;
-     GError *error = NULL;
- 
--    ret = g_pollable_input_stream_read_nonblocking(G_POLLABLE_INPUT_STREAM(BIO_GET_ISTREAM(bio)),
-+    stream = g_io_stream_get_input_stream(bio->ptr);
-+    ret = g_pollable_input_stream_read_nonblocking(G_POLLABLE_INPUT_STREAM(stream),
-                                                    out, outl, NULL, &error);
-     BIO_clear_retry_flags(bio);
- 
-@@ -70,17 +73,6 @@ static int bio_gio_read(BIO *bio, char *out, int outl)
-     return ret;
- }
- 
--static int bio_gio_destroy(BIO *bio)
--{
--    if (bio == NULL || bio->method == NULL)
--        return 0;
--
--    SPICE_DEBUG("bio gsocket destroy");
--    g_clear_pointer(&bio->method, g_free);
--
--    return 1;
--}
--
- static int bio_gio_puts(BIO *bio, const char *str)
- {
-     int n, ret;
-@@ -91,23 +83,30 @@ static int bio_gio_puts(BIO *bio, const char *str)
-     return ret;
- }
- 
-+#define BIO_TYPE_START 128
-+
- G_GNUC_INTERNAL
- BIO* bio_new_giostream(GIOStream *stream)
- {
--    // TODO: make an actual new BIO type, or just switch to GTls already...
--    BIO *bio = BIO_new_socket(-1, BIO_NOCLOSE);
-+    BIO *bio;
-+    static BIO_METHOD bio_gio_method;
- 
--    bio_gsocket_method *bio_method = g_new(bio_gsocket_method, 1);
--    bio_method->method = *bio->method;
--    bio_method->stream = stream;
-+    if (bio_gio_method.name == NULL) {
-+        bio_gio_method.type = BIO_TYPE_START | BIO_TYPE_SOURCE_SINK;
-+        bio_gio_method.name = "gio stream";
-+    }
- 
--    bio->method->destroy(bio);
--    bio->method = (BIO_METHOD*)bio_method;
-+    bio = BIO_new(&bio_gio_method);
-+    if (!bio)
-+        return NULL;
- 
-     bio->method->bwrite = bio_gio_write;
-     bio->method->bread = bio_gio_read;
-     bio->method->bputs = bio_gio_puts;
--    bio->method->destroy = bio_gio_destroy;
-+    bio->method->ctrl = bio_gio_ctrl;
-+
-+    bio->init = 1;
-+    bio->ptr = stream;
- 
-     return bio;
- }

Deleted: community-i686/ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch
===================================================================
--- community-i686/ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch	2017-10-31 14:12:00 UTC (rev 264912)
+++ community-i686/ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch	2017-10-31 14:12:22 UTC (rev 264913)
@@ -1,71 +0,0 @@
-From: Sebastian Andrzej Siewior <sebastian at breakpoint.cc>
-Date: Wed, 26 Oct 2016 12:55:03 +0200
-Origin: upstream, https://cgit.freedesktop.org/spice/spice-gtk/commit/?id=3ec02a76ea5e0bea4aa3d3cc81846a9063c26d7a
-Bug-Debian: https://bugs.debian.org/851127
-Subject: ssl: Stop creating our own X509_LOOKUP_METHOD
-
-OpenSSL 1.1.0 does not seem to provide API to do that anymore.
-
-There is no need to create a custom lookup to begin with. This method
-here has no callbacks implemented and is doing nothing. The way I
-understand it, it is used to retrieve a `lookup' object which provides a
-certificate store.  The SSL ctx provides also such a store.
-
-Acked-by: Christophe Fergeau <cfergeau at redhat.com>
-Acked-by: Pavel Grunt <pgrunt at redhat.com>
----
- src/spice-channel.c | 13 ++++---------
- 1 file changed, 4 insertions(+), 9 deletions(-)
-
-diff --git a/src/spice-channel.c b/src/spice-channel.c
-index 95662f3..6a911a6 100644
---- a/src/spice-channel.c
-+++ b/src/spice-channel.c
-@@ -2352,17 +2352,12 @@ static gboolean spice_channel_delayed_unref(gpointer data)
-     return FALSE;
- }
- 
--static X509_LOOKUP_METHOD spice_x509_mem_lookup = {
--    "spice_x509_mem_lookup",
--    0
--};
--
- static int spice_channel_load_ca(SpiceChannel *channel)
- {
-     SpiceChannelPrivate *c = channel->priv;
-     STACK_OF(X509_INFO) *inf;
-     X509_INFO *itmp;
--    X509_LOOKUP *lookup;
-+    X509_STORE *store;
-     BIO *in;
-     int i, count = 0;
-     guint8 *ca;
-@@ -2372,13 +2367,13 @@ static int spice_channel_load_ca(SpiceChannel *channel)
- 
-     g_return_val_if_fail(c->ctx != NULL, 0);
- 
--    lookup = X509_STORE_add_lookup(c->ctx->cert_store, &spice_x509_mem_lookup);
-     ca_file = spice_session_get_ca_file(c->session);
-     spice_session_get_ca(c->session, &ca, &size);
- 
-     CHANNEL_DEBUG(channel, "Load CA, file: %s, data: %p", ca_file, ca);
- 
-     if (ca != NULL) {
-+        store = SSL_CTX_get_cert_store(c->ctx);
-         in = BIO_new_mem_buf(ca, size);
-         inf = PEM_X509_INFO_read_bio(in, NULL, NULL, NULL);
-         BIO_free(in);
-@@ -2386,11 +2381,11 @@ static int spice_channel_load_ca(SpiceChannel *channel)
-         for (i = 0; i < sk_X509_INFO_num(inf); i++) {
-             itmp = sk_X509_INFO_value(inf, i);
-             if (itmp->x509) {
--                X509_STORE_add_cert(lookup->store_ctx, itmp->x509);
-+                X509_STORE_add_cert(store, itmp->x509);
-                 count++;
-             }
-             if (itmp->crl) {
--                X509_STORE_add_crl(lookup->store_ctx, itmp->crl);
-+                X509_STORE_add_crl(store, itmp->crl);
-                 count++;
-             }
-         }

Deleted: community-i686/ssl-Use-accessors-rather-than-direct-struct-access.patch
===================================================================
--- community-i686/ssl-Use-accessors-rather-than-direct-struct-access.patch	2017-10-31 14:12:00 UTC (rev 264912)
+++ community-i686/ssl-Use-accessors-rather-than-direct-struct-access.patch	2017-10-31 14:12:22 UTC (rev 264913)
@@ -1,193 +0,0 @@
-From: Sebastian Andrzej Siewior <sebastian at breakpoint.cc>
-Date: Wed, 30 Nov 2016 16:34:59 +0100
-Origin: upstream, https://cgit.freedesktop.org/spice/spice-gtk/commit/?id=97bd84313597d7c37c637c29e75f8862fcab1940
-Bug-Debian: https://bugs.debian.org/851127
-Subject: ssl: Use accessors rather than direct struct access
-
-In OpenSSL 1.1.0, the struct fields are private so we can no longer
-directly access them.
-
-The accessors are not available in previous OpenSSL releases, so we need
-to add compat helpers.
----
- src/bio-gio.c       | 106 ++++++++++++++++++++++++++++++++++++++++++++--------
- src/spice-channel.c |  11 +++++-
- 2 files changed, 100 insertions(+), 17 deletions(-)
-
-diff --git a/src/bio-gio.c b/src/bio-gio.c
-index 0f8b415..9358fae 100644
---- a/src/bio-gio.c
-+++ b/src/bio-gio.c
-@@ -23,6 +23,75 @@
- #include "spice-util.h"
- #include "bio-gio.h"
- 
-+#if OPENSSL_VERSION_NUMBER < 0x10100000
-+static BIO_METHOD one_static_bio;
-+
-+static int BIO_meth_set_read(BIO_METHOD *biom,
-+                             int (*bread) (BIO *, char *, int))
-+{
-+    biom->bread = bread;
-+    return 1;
-+}
-+
-+static int BIO_meth_set_write(BIO_METHOD *biom,
-+                              int (*bwrite) (BIO *, const char *, int))
-+{
-+    biom->bwrite = bwrite;
-+    return 1;
-+}
-+
-+static int BIO_meth_set_puts(BIO_METHOD *biom,
-+                             int (*bputs) (BIO *, const char *))
-+{
-+    biom->bputs = bputs;
-+    return 1;
-+}
-+
-+static int BIO_meth_set_ctrl(BIO_METHOD *biom,
-+                             long (*ctrl) (BIO *, int, long, void *))
-+{
-+    biom->ctrl = ctrl;
-+    return 1;
-+}
-+
-+#define BIO_TYPE_START 128
-+
-+static int BIO_get_new_index(void)
-+{
-+    static int bio_index = BIO_TYPE_START;
-+    return bio_index++;
-+}
-+
-+static void BIO_set_init(BIO *a, int init)
-+{
-+	a->init = init;
-+}
-+
-+static void BIO_set_data(BIO *a, void *ptr)
-+{
-+    a->ptr = ptr;
-+}
-+
-+static void *BIO_get_data(BIO *a)
-+{
-+    return a->ptr;
-+}
-+
-+static BIO_METHOD *BIO_meth_new(int type, const char *name)
-+{
-+    BIO_METHOD *biom = &one_static_bio;
-+
-+    biom->type = type;
-+    biom->name = name;
-+    return biom;
-+}
-+
-+static void BIO_meth_free(BIO_METHOD *biom)
-+{
-+}
-+
-+#endif
-+
- static long bio_gio_ctrl(G_GNUC_UNUSED BIO *b,
-                          int cmd,
-                          G_GNUC_UNUSED long num,
-@@ -37,7 +106,7 @@ static int bio_gio_write(BIO *bio, const char *in, int inl)
-     gssize ret;
-     GError *error = NULL;
- 
--    stream = g_io_stream_get_output_stream(bio->ptr);
-+    stream = g_io_stream_get_output_stream(BIO_get_data(bio));
-     ret = g_pollable_output_stream_write_nonblocking(G_POLLABLE_OUTPUT_STREAM(stream),
-                                                      in, inl, NULL, &error);
-     BIO_clear_retry_flags(bio);
-@@ -58,7 +127,7 @@ static int bio_gio_read(BIO *bio, char *out, int outl)
-     gssize ret;
-     GError *error = NULL;
- 
--    stream = g_io_stream_get_input_stream(bio->ptr);
-+    stream = g_io_stream_get_input_stream(BIO_get_data(bio));
-     ret = g_pollable_input_stream_read_nonblocking(G_POLLABLE_INPUT_STREAM(stream),
-                                                    out, outl, NULL, &error);
-     BIO_clear_retry_flags(bio);
-@@ -83,30 +152,35 @@ static int bio_gio_puts(BIO *bio, const char *str)
-     return ret;
- }
- 
--#define BIO_TYPE_START 128
-+static BIO_METHOD *bio_gio_method;
- 
- G_GNUC_INTERNAL
- BIO* bio_new_giostream(GIOStream *stream)
- {
-     BIO *bio;
--    static BIO_METHOD bio_gio_method;
- 
--    if (bio_gio_method.name == NULL) {
--        bio_gio_method.type = BIO_TYPE_START | BIO_TYPE_SOURCE_SINK;
--        bio_gio_method.name = "gio stream";
-+    if (!bio_gio_method) {
-+        bio_gio_method = BIO_meth_new(BIO_get_new_index() |
-+                                      BIO_TYPE_SOURCE_SINK,
-+                                      "gio stream");
-+        if (!bio_gio_method)
-+            return NULL;
-+
-+        if (!BIO_meth_set_write(bio_gio_method, bio_gio_write) ||
-+            !BIO_meth_set_read(bio_gio_method, bio_gio_read) ||
-+            !BIO_meth_set_puts(bio_gio_method, bio_gio_puts) ||
-+            !BIO_meth_set_ctrl(bio_gio_method, bio_gio_ctrl)) {
-+            BIO_meth_free(bio_gio_method);
-+            bio_gio_method = NULL;
-+            return NULL;
-+        }
-     }
- 
--    bio = BIO_new(&bio_gio_method);
-+    bio = BIO_new(bio_gio_method);
-     if (!bio)
-         return NULL;
- 
--    bio->method->bwrite = bio_gio_write;
--    bio->method->bread = bio_gio_read;
--    bio->method->bputs = bio_gio_puts;
--    bio->method->ctrl = bio_gio_ctrl;
--
--    bio->init = 1;
--    bio->ptr = stream;
--
-+    BIO_set_init(bio, 1);
-+    BIO_set_data(bio, stream);
-     return bio;
- }
-diff --git a/src/spice-channel.c b/src/spice-channel.c
-index 6a911a6..6556db3 100644
---- a/src/spice-channel.c
-+++ b/src/spice-channel.c
-@@ -55,6 +55,15 @@ static void spice_channel_reset_capabilities(SpiceChannel *channel);
- static void spice_channel_send_migration_handshake(SpiceChannel *channel);
- static gboolean channel_connect(SpiceChannel *channel, gboolean tls);
- 
-+#if OPENSSL_VERSION_NUMBER < 0x10100000
-+static RSA *EVP_PKEY_get0_RSA(EVP_PKEY *pkey)
-+{
-+    if (pkey->type != EVP_PKEY_RSA) {
-+        return NULL;
-+    }
-+    return pkey->pkey.rsa;
-+}
-+#endif
- /**
-  * SECTION:spice-channel
-  * @short_description: the base channel class
-@@ -1161,7 +1170,7 @@ static SpiceChannelEvent spice_channel_send_spice_ticket(SpiceChannel *channel)
-     pubkey = d2i_PUBKEY_bio(bioKey, NULL);
-     g_return_val_if_fail(pubkey != NULL, ret);
- 
--    rsa = pubkey->pkey.rsa;
-+    rsa = EVP_PKEY_get0_RSA(pubkey);
-     nRSASize = RSA_size(rsa);
- 
-     encrypted = g_alloca(nRSASize);

Deleted: community-x86_64/PKGBUILD
===================================================================
--- community-x86_64/PKGBUILD	2017-10-31 14:12:00 UTC (rev 264912)
+++ community-x86_64/PKGBUILD	2017-10-31 14:12:22 UTC (rev 264913)
@@ -1,56 +0,0 @@
-# $Id$
-# Maintainer: Sergej Pupykin <pupykin.s+arch at gmail.com>
-# Contributor: Stefano Facchini <stefano.facchini at gmail.com>
-# Contributor: Jonathan Lestrelin <zanko at daemontux.org>
-# Contributor: Lucio Zara <pennega at gmail.com>
-
-pkgname=spice-gtk3
-pkgver=0.34
-pkgrel=1
-pkgdesc="Gtk client and libraries for SPICE remote desktop servers (gtk3 version)"
-arch=('i686' 'x86_64')
-url="https://www.spice-space.org"
-license=('LGPL2.1')
-depends=('celt0.5.1' 'dbus-glib' 'gtk3' 'libcacard' 'libpulse' 'usbredir' 'libsoup' 'spice-glib')
-makedepends=('gobject-introspection' 'intltool' 'python2-pyparsing' 'spice-protocol' 'usbutils'
-	     'vala' 'sdl' 'python2-six')
-options=('!emptydirs')
-source=("https://www.spice-space.org/download/gtk/spice-gtk-$pkgver.tar.bz2"
-        debian_843471-clipboard_Fix_crash_by_handling_error.patch
-        ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch
-        ssl-Rework-our-custom-BIO-type.patch
-        ssl-Use-accessors-rather-than-direct-struct-access.patch)
-sha256sums=('e9720e01165f8451c9f3f58ad50e3afb990993b81cc2db86b3661b7ac5b976ee'
-            '31cacbfce3de9c7599f3cca5b45ed76cf5e3997072aae64b4107676b0b9a2f7b'
-            '0e0d553992ea08a29b14439061c6e831ce4ba4bd7bb5e53d7e7e1306aa6ba0fa'
-            '91bbb28dc5a8968c0eea57919d9a4a86384a62909014b53b05b5e721afa8142d'
-            '0e65852f94849c3efe0c21c01f4be7b804641d7d178b12a22eb62f08db70371e')
-
-prepare() {
-  cd "$srcdir/spice-gtk-$pkgver"
-#  patch -Np1 -i ../debian_843471-clipboard_Fix_crash_by_handling_error.patch
-#  patch -Np1 -i ../ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch
-#  patch -Np1 -i ../ssl-Rework-our-custom-BIO-type.patch
-#  patch -Np1 -i ../ssl-Use-accessors-rather-than-direct-struct-access.patch
-}
-
-build() {
-  cd "$srcdir/spice-gtk-$pkgver"
-  PYTHON=python2 ./configure --prefix=/usr \
-    --disable-static --enable-vala --with-gtk=3.0 \
-    --with-audio=pulse \
-    --with-coroutine=gthread --sbindir=/usr/bin \
-    --enable-smartcard
-  sed -i -e 's/ -shared / -Wl,-O1,--as-needed\0/g' libtool
-  make
-}
-
-package() {
-  cd "$srcdir/spice-gtk-$pkgver"
-  make DESTDIR="$pkgdir/" install
-  pacman -Ql spice-glib | cut -f2 -d' ' | while read f; do
-    [ -f "$pkgdir"/$f ] && rm -f "$pkgdir"/$f || true
-    f=$(echo $f | sed 's|.gz$||')
-    [ -f "$pkgdir"/$f ] && rm -f "$pkgdir"/$f || true
-  done
-}

Copied: spice-gtk3/repos/community-x86_64/PKGBUILD (from rev 264912, spice-gtk3/trunk/PKGBUILD)
===================================================================
--- community-x86_64/PKGBUILD	                        (rev 0)
+++ community-x86_64/PKGBUILD	2017-10-31 14:12:22 UTC (rev 264913)
@@ -0,0 +1,40 @@
+# $Id$
+# Maintainer: Sergej Pupykin <pupykin.s+arch at gmail.com>
+# Contributor: Stefano Facchini <stefano.facchini at gmail.com>
+# Contributor: Jonathan Lestrelin <zanko at daemontux.org>
+# Contributor: Lucio Zara <pennega at gmail.com>
+
+pkgname=spice-gtk3
+pkgver=0.34
+pkgrel=2
+pkgdesc="Gtk client and libraries for SPICE remote desktop servers (gtk3 version)"
+arch=('i686' 'x86_64')
+url="https://www.spice-space.org"
+license=('LGPL2.1')
+depends=('celt0.5.1' 'dbus-glib' 'gtk3' 'libcacard' 'libpulse' 'usbredir' 'libsoup' 'spice-glib')
+makedepends=('gobject-introspection' 'intltool' 'python2-pyparsing' 'spice-protocol' 'usbutils'
+	     'vala' 'sdl' 'python2-six')
+options=('!emptydirs')
+source=("https://www.spice-space.org/download/gtk/spice-gtk-$pkgver.tar.bz2")
+sha256sums=('e9720e01165f8451c9f3f58ad50e3afb990993b81cc2db86b3661b7ac5b976ee')
+
+build() {
+  cd "$srcdir/spice-gtk-$pkgver"
+  PYTHON=python2 ./configure --prefix=/usr \
+    --disable-static --enable-vala --with-gtk=3.0 \
+    --with-audio=pulse \
+    --with-coroutine=gthread --sbindir=/usr/bin \
+    --enable-smartcard
+  sed -i -e 's/ -shared / -Wl,-O1,--as-needed\0/g' libtool
+  make
+}
+
+package() {
+  cd "$srcdir/spice-gtk-$pkgver"
+  make DESTDIR="$pkgdir/" install
+  pacman -Ql spice-glib | cut -f2 -d' ' | while read f; do
+    [ -f "$pkgdir"/$f ] && rm -f "$pkgdir"/$f || true
+    f=$(echo $f | sed 's|.gz$||')
+    [ -f "$pkgdir"/$f ] && rm -f "$pkgdir"/$f || true
+  done
+}

Deleted: community-x86_64/debian_843471-clipboard_Fix_crash_by_handling_error.patch
===================================================================
--- community-x86_64/debian_843471-clipboard_Fix_crash_by_handling_error.patch	2017-10-31 14:12:00 UTC (rev 264912)
+++ community-x86_64/debian_843471-clipboard_Fix_crash_by_handling_error.patch	2017-10-31 14:12:22 UTC (rev 264913)
@@ -1,40 +0,0 @@
-commit 03c016bea939ee4a26e90d80fa1012a993a8ea47
-Author: Victor Toso <me at victortoso.com>
-Origin: upstream, https://cgit.freedesktop.org/spice/spice-gtk/commit/?id=03c016bea939ee4a26e90d80fa1012a993a8ea47
-Bug-Debian: https://bugs.debian.org/843471
-Date:   Fri Oct 14 18:12:01 2016 +0200
-
-    clipboard: Fix crash by handling error
-    
-    As manual states below, text could be NULL for different reasons and
-    we should handle that. I've included a debug message to help
-    identifying possible regressions from wayland's clipboard.
-    
-    This crash is a regression from 7b0de6217670e0f668aff2949f
-    
-     "The text parameter to callback will contain the resulting text if
-     the request succeeded, or NULL if it failed. This could happen for
-     various reasons, in particular if the clipboard was empty or if the
-     contents of the clipboard could not be converted into text form."
-    
-    Resolves: rhbz#1384676
-    
-    Signed-off-by: Victor Toso <victortoso at redhat.com>
-    Acked-by: Pavel Grunt <pgrunt at redhat.com>
-
-diff --git a/src/spice-gtk-session.c b/src/spice-gtk-session.c
-index 3ff4e9a..3e0ec74 100644
---- a/src/spice-gtk-session.c
-+++ b/src/spice-gtk-session.c
-@@ -945,6 +945,11 @@ static void clipboard_received_text_cb(GtkClipboard *clipboard,
-     if (self == NULL)
-         return;
- 
-+    if (text == NULL) {
-+        SPICE_DEBUG("Failed to retrieve clipboard text");
-+        return;
-+    }
-+
-     g_return_if_fail(SPICE_IS_GTK_SESSION(self));
- 
-     selection = get_selection_from_clipboard(self->priv, clipboard);

Deleted: community-x86_64/ssl-Rework-our-custom-BIO-type.patch
===================================================================
--- community-x86_64/ssl-Rework-our-custom-BIO-type.patch	2017-10-31 14:12:00 UTC (rev 264912)
+++ community-x86_64/ssl-Rework-our-custom-BIO-type.patch	2017-10-31 14:12:22 UTC (rev 264913)
@@ -1,121 +0,0 @@
-From: Sebastian Andrzej Siewior <sebastian at breakpoint.cc>
-Date: Wed, 26 Oct 2016 17:31:27 +0200
-Origin: upstream, https://cgit.freedesktop.org/spice/spice-gtk/commit/?id=498f5369203d73026e9fb3929fd19a358d76a152
-Bug-Debian: https://bugs.debian.org/851127
-Subject: ssl: Rework our custom BIO type
-
-This commit changes to an actual new BIO method rather than reusing an
-existing BIO method, and overriding only the fields that we need.
-The approach before this commit would be causing issues with OpenSSL
-1.1.0 as some of the fields we access have become opaque.
----
- src/bio-gio.c | 57 ++++++++++++++++++++++++++++-----------------------------
- 1 file changed, 28 insertions(+), 29 deletions(-)
-
-diff --git a/src/bio-gio.c b/src/bio-gio.c
-index b310c97..0f8b415 100644
---- a/src/bio-gio.c
-+++ b/src/bio-gio.c
-@@ -23,21 +23,22 @@
- #include "spice-util.h"
- #include "bio-gio.h"
- 
--typedef struct bio_gsocket_method {
--    BIO_METHOD method;
--    GIOStream *stream;
--} bio_gsocket_method;
--
--#define BIO_GET_GSOCKET(bio)  (((bio_gsocket_method*)bio->method)->gsocket)
--#define BIO_GET_ISTREAM(bio)  (g_io_stream_get_input_stream(((bio_gsocket_method*)bio->method)->stream))
--#define BIO_GET_OSTREAM(bio)  (g_io_stream_get_output_stream(((bio_gsocket_method*)bio->method)->stream))
-+static long bio_gio_ctrl(G_GNUC_UNUSED BIO *b,
-+                         int cmd,
-+                         G_GNUC_UNUSED long num,
-+                         G_GNUC_UNUSED void *ptr)
-+{
-+    return (cmd == BIO_CTRL_FLUSH);
-+}
- 
- static int bio_gio_write(BIO *bio, const char *in, int inl)
- {
-+    GOutputStream *stream;
-     gssize ret;
-     GError *error = NULL;
- 
--    ret = g_pollable_output_stream_write_nonblocking(G_POLLABLE_OUTPUT_STREAM(BIO_GET_OSTREAM(bio)),
-+    stream = g_io_stream_get_output_stream(bio->ptr);
-+    ret = g_pollable_output_stream_write_nonblocking(G_POLLABLE_OUTPUT_STREAM(stream),
-                                                      in, inl, NULL, &error);
-     BIO_clear_retry_flags(bio);
- 
-@@ -53,10 +54,12 @@ static int bio_gio_write(BIO *bio, const char *in, int inl)
- 
- static int bio_gio_read(BIO *bio, char *out, int outl)
- {
-+    GInputStream *stream;
-     gssize ret;
-     GError *error = NULL;
- 
--    ret = g_pollable_input_stream_read_nonblocking(G_POLLABLE_INPUT_STREAM(BIO_GET_ISTREAM(bio)),
-+    stream = g_io_stream_get_input_stream(bio->ptr);
-+    ret = g_pollable_input_stream_read_nonblocking(G_POLLABLE_INPUT_STREAM(stream),
-                                                    out, outl, NULL, &error);
-     BIO_clear_retry_flags(bio);
- 
-@@ -70,17 +73,6 @@ static int bio_gio_read(BIO *bio, char *out, int outl)
-     return ret;
- }
- 
--static int bio_gio_destroy(BIO *bio)
--{
--    if (bio == NULL || bio->method == NULL)
--        return 0;
--
--    SPICE_DEBUG("bio gsocket destroy");
--    g_clear_pointer(&bio->method, g_free);
--
--    return 1;
--}
--
- static int bio_gio_puts(BIO *bio, const char *str)
- {
-     int n, ret;
-@@ -91,23 +83,30 @@ static int bio_gio_puts(BIO *bio, const char *str)
-     return ret;
- }
- 
-+#define BIO_TYPE_START 128
-+
- G_GNUC_INTERNAL
- BIO* bio_new_giostream(GIOStream *stream)
- {
--    // TODO: make an actual new BIO type, or just switch to GTls already...
--    BIO *bio = BIO_new_socket(-1, BIO_NOCLOSE);
-+    BIO *bio;
-+    static BIO_METHOD bio_gio_method;
- 
--    bio_gsocket_method *bio_method = g_new(bio_gsocket_method, 1);
--    bio_method->method = *bio->method;
--    bio_method->stream = stream;
-+    if (bio_gio_method.name == NULL) {
-+        bio_gio_method.type = BIO_TYPE_START | BIO_TYPE_SOURCE_SINK;
-+        bio_gio_method.name = "gio stream";
-+    }
- 
--    bio->method->destroy(bio);
--    bio->method = (BIO_METHOD*)bio_method;
-+    bio = BIO_new(&bio_gio_method);
-+    if (!bio)
-+        return NULL;
- 
-     bio->method->bwrite = bio_gio_write;
-     bio->method->bread = bio_gio_read;
-     bio->method->bputs = bio_gio_puts;
--    bio->method->destroy = bio_gio_destroy;
-+    bio->method->ctrl = bio_gio_ctrl;
-+
-+    bio->init = 1;
-+    bio->ptr = stream;
- 
-     return bio;
- }

Deleted: community-x86_64/ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch
===================================================================
--- community-x86_64/ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch	2017-10-31 14:12:00 UTC (rev 264912)
+++ community-x86_64/ssl-Stop-creating-our-own-X509_LOOKUP_METHOD.patch	2017-10-31 14:12:22 UTC (rev 264913)
@@ -1,71 +0,0 @@
-From: Sebastian Andrzej Siewior <sebastian at breakpoint.cc>
-Date: Wed, 26 Oct 2016 12:55:03 +0200
-Origin: upstream, https://cgit.freedesktop.org/spice/spice-gtk/commit/?id=3ec02a76ea5e0bea4aa3d3cc81846a9063c26d7a
-Bug-Debian: https://bugs.debian.org/851127
-Subject: ssl: Stop creating our own X509_LOOKUP_METHOD
-
-OpenSSL 1.1.0 does not seem to provide API to do that anymore.
-
-There is no need to create a custom lookup to begin with. This method
-here has no callbacks implemented and is doing nothing. The way I
-understand it, it is used to retrieve a `lookup' object which provides a
-certificate store.  The SSL ctx provides also such a store.
-
-Acked-by: Christophe Fergeau <cfergeau at redhat.com>
-Acked-by: Pavel Grunt <pgrunt at redhat.com>
----
- src/spice-channel.c | 13 ++++---------
- 1 file changed, 4 insertions(+), 9 deletions(-)
-
-diff --git a/src/spice-channel.c b/src/spice-channel.c
-index 95662f3..6a911a6 100644
---- a/src/spice-channel.c
-+++ b/src/spice-channel.c
-@@ -2352,17 +2352,12 @@ static gboolean spice_channel_delayed_unref(gpointer data)
-     return FALSE;
- }
- 
--static X509_LOOKUP_METHOD spice_x509_mem_lookup = {
--    "spice_x509_mem_lookup",
--    0
--};
--
- static int spice_channel_load_ca(SpiceChannel *channel)
- {
-     SpiceChannelPrivate *c = channel->priv;
-     STACK_OF(X509_INFO) *inf;
-     X509_INFO *itmp;
--    X509_LOOKUP *lookup;
-+    X509_STORE *store;
-     BIO *in;
-     int i, count = 0;
-     guint8 *ca;
-@@ -2372,13 +2367,13 @@ static int spice_channel_load_ca(SpiceChannel *channel)
- 
-     g_return_val_if_fail(c->ctx != NULL, 0);
- 
--    lookup = X509_STORE_add_lookup(c->ctx->cert_store, &spice_x509_mem_lookup);
-     ca_file = spice_session_get_ca_file(c->session);
-     spice_session_get_ca(c->session, &ca, &size);
- 
-     CHANNEL_DEBUG(channel, "Load CA, file: %s, data: %p", ca_file, ca);
- 
-     if (ca != NULL) {
-+        store = SSL_CTX_get_cert_store(c->ctx);
-         in = BIO_new_mem_buf(ca, size);
-         inf = PEM_X509_INFO_read_bio(in, NULL, NULL, NULL);
-         BIO_free(in);
-@@ -2386,11 +2381,11 @@ static int spice_channel_load_ca(SpiceChannel *channel)
-         for (i = 0; i < sk_X509_INFO_num(inf); i++) {
-             itmp = sk_X509_INFO_value(inf, i);
-             if (itmp->x509) {
--                X509_STORE_add_cert(lookup->store_ctx, itmp->x509);
-+                X509_STORE_add_cert(store, itmp->x509);
-                 count++;
-             }
-             if (itmp->crl) {
--                X509_STORE_add_crl(lookup->store_ctx, itmp->crl);
-+                X509_STORE_add_crl(store, itmp->crl);
-                 count++;
-             }
-         }

Deleted: community-x86_64/ssl-Use-accessors-rather-than-direct-struct-access.patch
===================================================================
--- community-x86_64/ssl-Use-accessors-rather-than-direct-struct-access.patch	2017-10-31 14:12:00 UTC (rev 264912)
+++ community-x86_64/ssl-Use-accessors-rather-than-direct-struct-access.patch	2017-10-31 14:12:22 UTC (rev 264913)
@@ -1,193 +0,0 @@
-From: Sebastian Andrzej Siewior <sebastian at breakpoint.cc>
-Date: Wed, 30 Nov 2016 16:34:59 +0100
-Origin: upstream, https://cgit.freedesktop.org/spice/spice-gtk/commit/?id=97bd84313597d7c37c637c29e75f8862fcab1940
-Bug-Debian: https://bugs.debian.org/851127
-Subject: ssl: Use accessors rather than direct struct access
-
-In OpenSSL 1.1.0, the struct fields are private so we can no longer
-directly access them.
-
-The accessors are not available in previous OpenSSL releases, so we need
-to add compat helpers.
----
- src/bio-gio.c       | 106 ++++++++++++++++++++++++++++++++++++++++++++--------
- src/spice-channel.c |  11 +++++-
- 2 files changed, 100 insertions(+), 17 deletions(-)
-
-diff --git a/src/bio-gio.c b/src/bio-gio.c
-index 0f8b415..9358fae 100644
---- a/src/bio-gio.c
-+++ b/src/bio-gio.c
-@@ -23,6 +23,75 @@
- #include "spice-util.h"
- #include "bio-gio.h"
- 
-+#if OPENSSL_VERSION_NUMBER < 0x10100000
-+static BIO_METHOD one_static_bio;
-+
-+static int BIO_meth_set_read(BIO_METHOD *biom,
-+                             int (*bread) (BIO *, char *, int))
-+{
-+    biom->bread = bread;
-+    return 1;
-+}
-+
-+static int BIO_meth_set_write(BIO_METHOD *biom,
-+                              int (*bwrite) (BIO *, const char *, int))
-+{
-+    biom->bwrite = bwrite;
-+    return 1;
-+}
-+
-+static int BIO_meth_set_puts(BIO_METHOD *biom,
-+                             int (*bputs) (BIO *, const char *))
-+{
-+    biom->bputs = bputs;
-+    return 1;
-+}
-+
-+static int BIO_meth_set_ctrl(BIO_METHOD *biom,
-+                             long (*ctrl) (BIO *, int, long, void *))
-+{
-+    biom->ctrl = ctrl;
-+    return 1;
-+}
-+
-+#define BIO_TYPE_START 128
-+
-+static int BIO_get_new_index(void)
-+{
-+    static int bio_index = BIO_TYPE_START;
-+    return bio_index++;
-+}
-+
-+static void BIO_set_init(BIO *a, int init)
-+{
-+	a->init = init;
-+}
-+
-+static void BIO_set_data(BIO *a, void *ptr)
-+{
-+    a->ptr = ptr;
-+}
-+
-+static void *BIO_get_data(BIO *a)
-+{
-+    return a->ptr;
-+}
-+
-+static BIO_METHOD *BIO_meth_new(int type, const char *name)
-+{
-+    BIO_METHOD *biom = &one_static_bio;
-+
-+    biom->type = type;
-+    biom->name = name;
-+    return biom;
-+}
-+
-+static void BIO_meth_free(BIO_METHOD *biom)
-+{
-+}
-+
-+#endif
-+
- static long bio_gio_ctrl(G_GNUC_UNUSED BIO *b,
-                          int cmd,
-                          G_GNUC_UNUSED long num,
-@@ -37,7 +106,7 @@ static int bio_gio_write(BIO *bio, const char *in, int inl)
-     gssize ret;
-     GError *error = NULL;
- 
--    stream = g_io_stream_get_output_stream(bio->ptr);
-+    stream = g_io_stream_get_output_stream(BIO_get_data(bio));
-     ret = g_pollable_output_stream_write_nonblocking(G_POLLABLE_OUTPUT_STREAM(stream),
-                                                      in, inl, NULL, &error);
-     BIO_clear_retry_flags(bio);
-@@ -58,7 +127,7 @@ static int bio_gio_read(BIO *bio, char *out, int outl)
-     gssize ret;
-     GError *error = NULL;
- 
--    stream = g_io_stream_get_input_stream(bio->ptr);
-+    stream = g_io_stream_get_input_stream(BIO_get_data(bio));
-     ret = g_pollable_input_stream_read_nonblocking(G_POLLABLE_INPUT_STREAM(stream),
-                                                    out, outl, NULL, &error);
-     BIO_clear_retry_flags(bio);
-@@ -83,30 +152,35 @@ static int bio_gio_puts(BIO *bio, const char *str)
-     return ret;
- }
- 
--#define BIO_TYPE_START 128
-+static BIO_METHOD *bio_gio_method;
- 
- G_GNUC_INTERNAL
- BIO* bio_new_giostream(GIOStream *stream)
- {
-     BIO *bio;
--    static BIO_METHOD bio_gio_method;
- 
--    if (bio_gio_method.name == NULL) {
--        bio_gio_method.type = BIO_TYPE_START | BIO_TYPE_SOURCE_SINK;
--        bio_gio_method.name = "gio stream";
-+    if (!bio_gio_method) {
-+        bio_gio_method = BIO_meth_new(BIO_get_new_index() |
-+                                      BIO_TYPE_SOURCE_SINK,
-+                                      "gio stream");
-+        if (!bio_gio_method)
-+            return NULL;
-+
-+        if (!BIO_meth_set_write(bio_gio_method, bio_gio_write) ||
-+            !BIO_meth_set_read(bio_gio_method, bio_gio_read) ||
-+            !BIO_meth_set_puts(bio_gio_method, bio_gio_puts) ||
-+            !BIO_meth_set_ctrl(bio_gio_method, bio_gio_ctrl)) {
-+            BIO_meth_free(bio_gio_method);
-+            bio_gio_method = NULL;
-+            return NULL;
-+        }
-     }
- 
--    bio = BIO_new(&bio_gio_method);
-+    bio = BIO_new(bio_gio_method);
-     if (!bio)
-         return NULL;
- 
--    bio->method->bwrite = bio_gio_write;
--    bio->method->bread = bio_gio_read;
--    bio->method->bputs = bio_gio_puts;
--    bio->method->ctrl = bio_gio_ctrl;
--
--    bio->init = 1;
--    bio->ptr = stream;
--
-+    BIO_set_init(bio, 1);
-+    BIO_set_data(bio, stream);
-     return bio;
- }
-diff --git a/src/spice-channel.c b/src/spice-channel.c
-index 6a911a6..6556db3 100644
---- a/src/spice-channel.c
-+++ b/src/spice-channel.c
-@@ -55,6 +55,15 @@ static void spice_channel_reset_capabilities(SpiceChannel *channel);
- static void spice_channel_send_migration_handshake(SpiceChannel *channel);
- static gboolean channel_connect(SpiceChannel *channel, gboolean tls);
- 
-+#if OPENSSL_VERSION_NUMBER < 0x10100000
-+static RSA *EVP_PKEY_get0_RSA(EVP_PKEY *pkey)
-+{
-+    if (pkey->type != EVP_PKEY_RSA) {
-+        return NULL;
-+    }
-+    return pkey->pkey.rsa;
-+}
-+#endif
- /**
-  * SECTION:spice-channel
-  * @short_description: the base channel class
-@@ -1161,7 +1170,7 @@ static SpiceChannelEvent spice_channel_send_spice_ticket(SpiceChannel *channel)
-     pubkey = d2i_PUBKEY_bio(bioKey, NULL);
-     g_return_val_if_fail(pubkey != NULL, ret);
- 
--    rsa = pubkey->pkey.rsa;
-+    rsa = EVP_PKEY_get0_RSA(pubkey);
-     nRSASize = RSA_size(rsa);
- 
-     encrypted = g_alloca(nRSASize);



More information about the arch-commits mailing list