Update to spice-gtk 0.21
This commit is contained in:
parent
8dc5ba9f89
commit
ad9d1fabb8
1
.gitignore
vendored
1
.gitignore
vendored
@ -20,3 +20,4 @@
|
|||||||
/spice-gtk-0.18.tar.bz2
|
/spice-gtk-0.18.tar.bz2
|
||||||
/spice-gtk-0.19.tar.bz2
|
/spice-gtk-0.19.tar.bz2
|
||||||
/spice-gtk-0.20.tar.bz2
|
/spice-gtk-0.20.tar.bz2
|
||||||
|
/spice-gtk-0.21.tar.bz2
|
||||||
|
@ -1,91 +0,0 @@
|
|||||||
From b85ca792af72d5f1e10aa6af9515eb96a044fc5c Mon Sep 17 00:00:00 2001
|
|
||||||
From: Hans de Goede <hdegoede@redhat.com>
|
|
||||||
Date: Wed, 26 Jun 2013 17:39:39 +0200
|
|
||||||
Subject: [PATCH spice-gtk] Add spice_channel_string_to_type to map files
|
|
||||||
|
|
||||||
And document both spice_channel_string_to_type and
|
|
||||||
spice_channel_type_to_string.
|
|
||||||
|
|
||||||
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
|
||||||
---
|
|
||||||
doc/reference/spice-gtk-sections.txt | 1 +
|
|
||||||
gtk/map-file | 1 +
|
|
||||||
gtk/spice-channel.c | 18 ++++++++++++++++++
|
|
||||||
gtk/spice-glib-sym-file | 1 +
|
|
||||||
4 files changed, 21 insertions(+)
|
|
||||||
|
|
||||||
diff --git a/doc/reference/spice-gtk-sections.txt b/doc/reference/spice-gtk-sections.txt
|
|
||||||
index e1e2833..8d61aa9 100644
|
|
||||||
--- a/doc/reference/spice-gtk-sections.txt
|
|
||||||
+++ b/doc/reference/spice-gtk-sections.txt
|
|
||||||
@@ -98,6 +98,7 @@ spice_channel_disconnect
|
|
||||||
spice_channel_test_capability
|
|
||||||
spice_channel_test_common_capability
|
|
||||||
spice_channel_type_to_string
|
|
||||||
+spice_channel_string_to_type
|
|
||||||
spice_channel_set_capability
|
|
||||||
spice_channel_flush_async
|
|
||||||
spice_channel_flush_finish
|
|
||||||
diff --git a/gtk/map-file b/gtk/map-file
|
|
||||||
index a0b7330..a69eb40 100644
|
|
||||||
--- a/gtk/map-file
|
|
||||||
+++ b/gtk/map-file
|
|
||||||
@@ -11,6 +11,7 @@ spice_channel_get_type;
|
|
||||||
spice_channel_new;
|
|
||||||
spice_channel_open_fd;
|
|
||||||
spice_channel_set_capability;
|
|
||||||
+spice_channel_string_to_type;
|
|
||||||
spice_channel_test_capability;
|
|
||||||
spice_channel_test_common_capability;
|
|
||||||
spice_channel_type_to_string;
|
|
||||||
diff --git a/gtk/spice-channel.c b/gtk/spice-channel.c
|
|
||||||
index 0a32d6c..093b292 100644
|
|
||||||
--- a/gtk/spice-channel.c
|
|
||||||
+++ b/gtk/spice-channel.c
|
|
||||||
@@ -1884,6 +1884,15 @@ static const char *to_string[] = {
|
|
||||||
[ SPICE_CHANNEL_PORT ] = "port",
|
|
||||||
};
|
|
||||||
|
|
||||||
+/**
|
|
||||||
+ * spice_channel_type_to_string:
|
|
||||||
+ * @type: a channel-type property value
|
|
||||||
+ *
|
|
||||||
+ * Convert a channel-type property value to a string.
|
|
||||||
+ *
|
|
||||||
+ * Returns: string representation of @type.
|
|
||||||
+ * Since: 0.20
|
|
||||||
+ **/
|
|
||||||
const gchar* spice_channel_type_to_string(gint type)
|
|
||||||
{
|
|
||||||
const char *str = NULL;
|
|
||||||
@@ -1895,6 +1904,15 @@ const gchar* spice_channel_type_to_string(gint type)
|
|
||||||
return str ? str : "unknown channel type";
|
|
||||||
}
|
|
||||||
|
|
||||||
+/**
|
|
||||||
+ * spice_channel_string_to_type:
|
|
||||||
+ * @str: a string representation of the channel-type property
|
|
||||||
+ *
|
|
||||||
+ * Convert a channel-type property value to a string.
|
|
||||||
+ *
|
|
||||||
+ * Returns: the channel-type property value for a @str channel
|
|
||||||
+ * Since: 0.21
|
|
||||||
+ **/
|
|
||||||
gint spice_channel_string_to_type(const gchar *str)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
diff --git a/gtk/spice-glib-sym-file b/gtk/spice-glib-sym-file
|
|
||||||
index 2b172d0..8540307 100644
|
|
||||||
--- a/gtk/spice-glib-sym-file
|
|
||||||
+++ b/gtk/spice-glib-sym-file
|
|
||||||
@@ -14,6 +14,7 @@ spice_channel_set_capability
|
|
||||||
spice_channel_test_capability
|
|
||||||
spice_channel_test_common_capability
|
|
||||||
spice_channel_type_to_string
|
|
||||||
+spice_channel_string_to_type
|
|
||||||
spice_client_error_quark
|
|
||||||
spice_cursor_channel_get_type
|
|
||||||
spice_display_channel_get_type
|
|
||||||
--
|
|
||||||
1.8.3.rc1.49.g8d97506
|
|
||||||
|
|
@ -1,45 +0,0 @@
|
|||||||
From 3bb15dd43daaed6b1d77e66c59432f228935322e Mon Sep 17 00:00:00 2001
|
|
||||||
From: Christophe Fergeau <cfergeau@redhat.com>
|
|
||||||
Date: Thu, 11 Jul 2013 15:18:33 +0200
|
|
||||||
Subject: [spice-gtk] smartcard: Handle VCARD_EMUL_INIT_ALREADY_INITED
|
|
||||||
|
|
||||||
When initializing a software smartcard, vcard_emul_init() can
|
|
||||||
report success, error, or indicate that initialization has already
|
|
||||||
been done. In this last case, we would assume that an error occurred
|
|
||||||
instead of behaving as if the initialization succeeded.
|
|
||||||
|
|
||||||
vcard_emul_init() can end up being called multiple time if the
|
|
||||||
smartcard channel gets destroyed and recreated during the lifetime
|
|
||||||
of the application
|
|
||||||
|
|
||||||
Fixes rhbz#815639
|
|
||||||
---
|
|
||||||
gtk/smartcard-manager.c | 5 ++++-
|
|
||||||
1 file changed, 4 insertions(+), 1 deletion(-)
|
|
||||||
|
|
||||||
diff --git a/gtk/smartcard-manager.c b/gtk/smartcard-manager.c
|
|
||||||
index 4b1efe2..2a0e397 100644
|
|
||||||
--- a/gtk/smartcard-manager.c
|
|
||||||
+++ b/gtk/smartcard-manager.c
|
|
||||||
@@ -408,6 +408,7 @@ static gboolean smartcard_manager_init(SpiceSession *session,
|
|
||||||
{
|
|
||||||
gchar *emul_args = NULL;
|
|
||||||
VCardEmulOptions *options = NULL;
|
|
||||||
+ VCardEmulError emul_init_status;
|
|
||||||
gchar *dbname = NULL;
|
|
||||||
GStrv certificates = NULL;
|
|
||||||
gboolean retval = FALSE;
|
|
||||||
@@ -448,7 +449,9 @@ static gboolean smartcard_manager_init(SpiceSession *session,
|
|
||||||
|
|
||||||
init:
|
|
||||||
SPICE_DEBUG("vcard_emul_init");
|
|
||||||
- if (vcard_emul_init(options) != VCARD_EMUL_OK) {
|
|
||||||
+ emul_init_status = vcard_emul_init(options);
|
|
||||||
+ if ((emul_init_status != VCARD_EMUL_OK)
|
|
||||||
+ && (emul_init_status != VCARD_EMUL_INIT_ALREADY_INITED)) {
|
|
||||||
*err = g_error_new(SPICE_CLIENT_ERROR,
|
|
||||||
SPICE_CLIENT_ERROR_FAILED,
|
|
||||||
"Failed to initialize smartcard");
|
|
||||||
--
|
|
||||||
1.8.3.1
|
|
||||||
|
|
@ -1,130 +0,0 @@
|
|||||||
From 28ef25781f62d6e3d96dba57a7ec772899b83661 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Hans de Goede <hdegoede@redhat.com>
|
|
||||||
Date: Mon, 24 Jun 2013 14:30:43 +0200
|
|
||||||
Subject: [PATCH] channel-main: Convert text line-endings if necessary
|
|
||||||
(rhbz#752350)
|
|
||||||
|
|
||||||
This implements line-ending conversion following the specification in the
|
|
||||||
commit message of spice-protocol commit 7be0e88e7e03a956b364cc847aad11b96ed4 :
|
|
||||||
vd_agent: Add caps for the agent to signal the guest line-ending (rhbz#752350)
|
|
||||||
|
|
||||||
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
|
||||||
(cherry picked from commit e45a446a9981ad4adaeff9c885962a8c6140333e)
|
|
||||||
---
|
|
||||||
gtk/channel-main.c | 73 +++++++++++++++++++++++++++++++++++++++++++++++++++---
|
|
||||||
1 file changed, 69 insertions(+), 4 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/gtk/channel-main.c b/gtk/channel-main.c
|
|
||||||
index b58af52..b9e0da2 100644
|
|
||||||
--- a/gtk/channel-main.c
|
|
||||||
+++ b/gtk/channel-main.c
|
|
||||||
@@ -1181,6 +1181,24 @@ static void agent_announce_caps(SpiceMainChannel *channel)
|
|
||||||
#define HAS_CLIPBOARD_SELECTION(c) \
|
|
||||||
VD_AGENT_HAS_CAPABILITY((c)->agent_caps, G_N_ELEMENTS((c)->agent_caps), VD_AGENT_CAP_CLIPBOARD_SELECTION)
|
|
||||||
|
|
||||||
+#define GUEST_LINEEND_LF(c) \
|
|
||||||
+ VD_AGENT_HAS_CAPABILITY((c)->agent_caps, G_N_ELEMENTS((c)->agent_caps), VD_AGENT_CAP_GUEST_LINEEND_LF)
|
|
||||||
+
|
|
||||||
+#define GUEST_LINEEND_CRLF(c) \
|
|
||||||
+ VD_AGENT_HAS_CAPABILITY((c)->agent_caps, G_N_ELEMENTS((c)->agent_caps), VD_AGENT_CAP_GUEST_LINEEND_CRLF)
|
|
||||||
+
|
|
||||||
+#ifdef G_OS_UNIX
|
|
||||||
+#define CLIENT_LINEEND_LF 1
|
|
||||||
+#else
|
|
||||||
+#define CLIENT_LINEEND_LF 0
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
+#ifdef G_OS_WIN32
|
|
||||||
+#define CLIENT_LINEEND_CRLF 1
|
|
||||||
+#else
|
|
||||||
+#define CLIENT_LINEEND_CRLF 0
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
/* any context: the message is not flushed immediately,
|
|
||||||
you can wakeup() the channel coroutine or send_msg_queue() */
|
|
||||||
static void agent_clipboard_grab(SpiceMainChannel *channel, guint selection,
|
|
||||||
@@ -1751,6 +1769,29 @@ static void file_xfer_handle_status(SpiceMainChannel *channel,
|
|
||||||
file_xfer_completed(task, error);
|
|
||||||
}
|
|
||||||
|
|
||||||
+/* any context */
|
|
||||||
+static guchar *convert_lineend(const guchar *in, gsize *size,
|
|
||||||
+ const gchar *from, const gchar *to)
|
|
||||||
+{
|
|
||||||
+ gchar *nul_terminated, **split, *out;
|
|
||||||
+
|
|
||||||
+ /* Nul-terminate */
|
|
||||||
+ nul_terminated = g_malloc(*size + 1);
|
|
||||||
+ memcpy(nul_terminated, in, *size);
|
|
||||||
+ nul_terminated[*size] = 0;
|
|
||||||
+
|
|
||||||
+ /* Convert */
|
|
||||||
+ split = g_strsplit(nul_terminated, from, -1);
|
|
||||||
+ out = g_strjoinv(to, split);
|
|
||||||
+ *size = strlen(out);
|
|
||||||
+
|
|
||||||
+ /* Clean-up */
|
|
||||||
+ g_strfreev(split);
|
|
||||||
+ g_free(nul_terminated);
|
|
||||||
+
|
|
||||||
+ return (guchar *)out;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
/* coroutine context */
|
|
||||||
static void main_agent_handle_msg(SpiceChannel *channel,
|
|
||||||
VDAgentMessage *msg, gpointer payload)
|
|
||||||
@@ -1809,12 +1850,22 @@ static void main_agent_handle_msg(SpiceChannel *channel,
|
|
||||||
case VD_AGENT_CLIPBOARD:
|
|
||||||
{
|
|
||||||
VDAgentClipboard *cb = payload;
|
|
||||||
+ guchar *data = cb->data;
|
|
||||||
+ gsize size = msg->size - sizeof(VDAgentClipboard);
|
|
||||||
+ if (cb->type == VD_AGENT_CLIPBOARD_UTF8_TEXT) {
|
|
||||||
+ if (GUEST_LINEEND_LF(c) && CLIENT_LINEEND_CRLF)
|
|
||||||
+ data = convert_lineend(data, &size, "\n", "\r\n");
|
|
||||||
+ if (GUEST_LINEEND_CRLF(c) && CLIENT_LINEEND_LF)
|
|
||||||
+ data = convert_lineend(data, &size, "\r\n", "\n");
|
|
||||||
+ }
|
|
||||||
emit_main_context(channel, SPICE_MAIN_CLIPBOARD_SELECTION, selection,
|
|
||||||
- cb->type, cb->data, msg->size - sizeof(VDAgentClipboard));
|
|
||||||
+ cb->type, data, size);
|
|
||||||
|
|
||||||
- if (selection == VD_AGENT_CLIPBOARD_SELECTION_CLIPBOARD)
|
|
||||||
+ if (selection == VD_AGENT_CLIPBOARD_SELECTION_CLIPBOARD)
|
|
||||||
emit_main_context(channel, SPICE_MAIN_CLIPBOARD,
|
|
||||||
- cb->type, cb->data, msg->size - sizeof(VDAgentClipboard));
|
|
||||||
+ cb->type, data, size);
|
|
||||||
+ if (data != cb->data)
|
|
||||||
+ g_free(data);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case VD_AGENT_CLIPBOARD_GRAB:
|
|
||||||
@@ -2554,13 +2605,27 @@ void spice_main_clipboard_notify(SpiceMainChannel *channel,
|
|
||||||
* Since: 0.6
|
|
||||||
**/
|
|
||||||
void spice_main_clipboard_selection_notify(SpiceMainChannel *channel, guint selection,
|
|
||||||
- guint32 type, const guchar *data, size_t size)
|
|
||||||
+ guint32 type, const guchar *_data, size_t _size)
|
|
||||||
{
|
|
||||||
+ const guchar *data = _data;
|
|
||||||
+ gsize size = _size;
|
|
||||||
+
|
|
||||||
g_return_if_fail(channel != NULL);
|
|
||||||
g_return_if_fail(SPICE_IS_MAIN_CHANNEL(channel));
|
|
||||||
|
|
||||||
+ SpiceMainChannelPrivate *c = channel->priv;
|
|
||||||
+
|
|
||||||
+ if (type == VD_AGENT_CLIPBOARD_UTF8_TEXT) {
|
|
||||||
+ if (CLIENT_LINEEND_CRLF && GUEST_LINEEND_LF(c))
|
|
||||||
+ data = convert_lineend(data, &size, "\r\n", "\n");
|
|
||||||
+ if (CLIENT_LINEEND_LF && GUEST_LINEEND_CRLF(c))
|
|
||||||
+ data = convert_lineend(data, &size, "\n", "\r\n");
|
|
||||||
+ }
|
|
||||||
agent_clipboard_notify(channel, selection, type, data, size);
|
|
||||||
spice_channel_wakeup(SPICE_CHANNEL(channel), FALSE);
|
|
||||||
+
|
|
||||||
+ if (data != _data)
|
|
||||||
+ g_free((guchar *)data);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
@ -1,53 +0,0 @@
|
|||||||
From 3010789e722f4a0fce62d7f172ad8134e1c5e866 Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?Marc-Andr=C3=A9=20Lureau?= <marcandre.lureau@redhat.com>
|
|
||||||
Date: Tue, 6 Aug 2013 12:09:18 +0200
|
|
||||||
Subject: [spice-gtk] usb-widget: fix gtk2 Python bindings
|
|
||||||
|
|
||||||
The Python bindings generator failed to bind the USB widget, because of
|
|
||||||
the object/class declaration. The declaration was circumventing the
|
|
||||||
deprecated errors when compiling with GTK_DISABLE_DEPRECATED. We used
|
|
||||||
to need that because of broken gtk+ headers, but it is no longer
|
|
||||||
necessary since 15bd7ceba1434b5d710bfd16078044f30693467b.
|
|
||||||
|
|
||||||
(cherry picked from commit a7565265532f6abec0fd3c6d843683b58eee070a)
|
|
||||||
---
|
|
||||||
gtk/usb-device-widget.h | 12 ++----------
|
|
||||||
1 file changed, 2 insertions(+), 10 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/gtk/usb-device-widget.h b/gtk/usb-device-widget.h
|
|
||||||
index 3920990..b68cc6b 100644
|
|
||||||
--- a/gtk/usb-device-widget.h
|
|
||||||
+++ b/gtk/usb-device-widget.h
|
|
||||||
@@ -37,14 +37,6 @@ typedef struct _SpiceUsbDeviceWidget SpiceUsbDeviceWidget;
|
|
||||||
typedef struct _SpiceUsbDeviceWidgetClass SpiceUsbDeviceWidgetClass;
|
|
||||||
typedef struct _SpiceUsbDeviceWidgetPrivate SpiceUsbDeviceWidgetPrivate;
|
|
||||||
|
|
||||||
-#if GTK_CHECK_VERSION(3,0,0)
|
|
||||||
-typedef struct _GtkBox _SpiceGtkBox;
|
|
||||||
-typedef struct _GtkBoxClass _SpiceGtkBoxClass;
|
|
||||||
-#else
|
|
||||||
-typedef struct _GtkVBox _SpiceGtkBox;
|
|
||||||
-typedef struct _GtkVBoxClass _SpiceGtkBoxClass;
|
|
||||||
-#endif
|
|
||||||
-
|
|
||||||
/**
|
|
||||||
* SpiceUsbDeviceWidget:
|
|
||||||
*
|
|
||||||
@@ -52,7 +44,7 @@ typedef struct _GtkVBoxClass _SpiceGtkBoxClass;
|
|
||||||
*/
|
|
||||||
struct _SpiceUsbDeviceWidget
|
|
||||||
{
|
|
||||||
- _SpiceGtkBox parent;
|
|
||||||
+ GtkVBox parent;
|
|
||||||
|
|
||||||
/*< private >*/
|
|
||||||
SpiceUsbDeviceWidgetPrivate *priv;
|
|
||||||
@@ -67,7 +59,7 @@ struct _SpiceUsbDeviceWidget
|
|
||||||
*/
|
|
||||||
struct _SpiceUsbDeviceWidgetClass
|
|
||||||
{
|
|
||||||
- _SpiceGtkBoxClass parent_class;
|
|
||||||
+ GtkVBoxClass parent_class;
|
|
||||||
|
|
||||||
/* signals */
|
|
||||||
void (*connect_failed) (SpiceUsbDeviceWidget *widget,
|
|
@ -1,27 +0,0 @@
|
|||||||
From f5dfea28a3b909e51bcb544c399b02bd3ff65df7 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Hans de Goede <hdegoede@redhat.com>
|
|
||||||
Date: Mon, 19 Aug 2013 16:51:58 +0200
|
|
||||||
Subject: [PATCH spice-gtk] glib-compat: g_slist_free_full: pass the right ptr
|
|
||||||
to destroy (rhbz#997893)
|
|
||||||
|
|
||||||
The destroy function passed to g_slist_free_full should be passed the elements
|
|
||||||
data pointer, not the element itself.
|
|
||||||
|
|
||||||
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
|
||||||
---
|
|
||||||
gtk/glib-compat.c | 2 +-
|
|
||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
||||||
|
|
||||||
diff --git a/gtk/glib-compat.c b/gtk/glib-compat.c
|
|
||||||
index 21be1f6..c3bb8e6 100644
|
|
||||||
--- a/gtk/glib-compat.c
|
|
||||||
+++ b/gtk/glib-compat.c
|
|
||||||
@@ -88,7 +88,7 @@ g_slist_free_full(GSList *list,
|
|
||||||
|
|
||||||
if (free_func) {
|
|
||||||
for (el = list; el ; el = g_slist_next(el)) {
|
|
||||||
- free_func(el);
|
|
||||||
+ free_func(el->data);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -1,53 +0,0 @@
|
|||||||
From 630d4d0b2cddefa85aeab796b1859a9d65aaec5d Mon Sep 17 00:00:00 2001
|
|
||||||
From: Alon Levy <alevy@redhat.com>
|
|
||||||
Date: Wed, 28 Aug 2013 16:01:15 +0300
|
|
||||||
Subject: [PATCH 1/2] gtk/channel-cursor.c: add cursor_type_to_string for
|
|
||||||
debugging
|
|
||||||
|
|
||||||
---
|
|
||||||
gtk/channel-cursor.c | 22 ++++++++++++++++++++--
|
|
||||||
1 file changed, 20 insertions(+), 2 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/gtk/channel-cursor.c b/gtk/channel-cursor.c
|
|
||||||
index 99e7a48..41ad696 100644
|
|
||||||
--- a/gtk/channel-cursor.c
|
|
||||||
+++ b/gtk/channel-cursor.c
|
|
||||||
@@ -325,6 +325,23 @@ static void display_cursor_unref(display_cursor *cursor)
|
|
||||||
g_free(cursor);
|
|
||||||
}
|
|
||||||
|
|
||||||
+static const char *cursor_type_to_string(int type)
|
|
||||||
+{
|
|
||||||
+ switch (type) {
|
|
||||||
+ case SPICE_CURSOR_TYPE_MONO:
|
|
||||||
+ return "mono";
|
|
||||||
+ case SPICE_CURSOR_TYPE_ALPHA:
|
|
||||||
+ return "alpha";
|
|
||||||
+ case SPICE_CURSOR_TYPE_COLOR32:
|
|
||||||
+ return "color32";
|
|
||||||
+ case SPICE_CURSOR_TYPE_COLOR16:
|
|
||||||
+ return "color16";
|
|
||||||
+ case SPICE_CURSOR_TYPE_COLOR4:
|
|
||||||
+ return "color4";
|
|
||||||
+ }
|
|
||||||
+ return "unknown";
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
static display_cursor *set_cursor(SpiceChannel *channel, SpiceCursor *scursor)
|
|
||||||
{
|
|
||||||
SpiceCursorChannelPrivate *c = SPICE_CURSOR_CHANNEL(channel)->priv;
|
|
||||||
@@ -343,8 +360,9 @@ static display_cursor *set_cursor(SpiceChannel *channel, SpiceCursor *scursor)
|
|
||||||
if (scursor->flags & SPICE_CURSOR_FLAGS_NONE)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
- CHANNEL_DEBUG(channel, "%s: type %d, %" PRIx64 ", %dx%d", __FUNCTION__,
|
|
||||||
- hdr->type, hdr->unique, hdr->width, hdr->height);
|
|
||||||
+ CHANNEL_DEBUG(channel, "%s: type %s(%d), %" PRIx64 ", %dx%d", __FUNCTION__,
|
|
||||||
+ cursor_type_to_string(hdr->type), hdr->type, hdr->unique,
|
|
||||||
+ hdr->width, hdr->height);
|
|
||||||
|
|
||||||
if (scursor->flags & SPICE_CURSOR_FLAGS_FROM_CACHE) {
|
|
||||||
item = cache_find(&c->cursors, hdr->unique);
|
|
||||||
--
|
|
||||||
1.8.3.1
|
|
||||||
|
|
@ -1,50 +0,0 @@
|
|||||||
From c4428fd886ca344fb77a684028e181236873b05e Mon Sep 17 00:00:00 2001
|
|
||||||
From: Alon Levy <alevy@redhat.com>
|
|
||||||
Date: Wed, 28 Aug 2013 16:14:16 +0300
|
|
||||||
Subject: [PATCH 2/2] gtk/channel-cursor: copy spicec hack, RHBZ #998529
|
|
||||||
|
|
||||||
flip -> unsupported by x11, since XCreatePixmapCursor has no invert
|
|
||||||
functionality, only a mask, shape, background and foreground colors. Use
|
|
||||||
this checkerboard hack to get some contrast for cursors in the guest
|
|
||||||
that relied on invert for the same contrast.
|
|
||||||
---
|
|
||||||
gtk/channel-cursor.c | 23 ++++++++++++++++++-----
|
|
||||||
1 file changed, 18 insertions(+), 5 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/gtk/channel-cursor.c b/gtk/channel-cursor.c
|
|
||||||
index 41ad696..e4a996b 100644
|
|
||||||
--- a/gtk/channel-cursor.c
|
|
||||||
+++ b/gtk/channel-cursor.c
|
|
||||||
@@ -259,11 +259,24 @@ static void mono_cursor(display_cursor *cursor, const guint8 *data)
|
|
||||||
for (x = 0; x < cursor->hdr.width; x++, dest += 4) {
|
|
||||||
if (and[x/8] & bit) {
|
|
||||||
if (xor[x/8] & bit) {
|
|
||||||
- /* flip -> hmm? */
|
|
||||||
- dest[0] = 0x00;
|
|
||||||
- dest[1] = 0x00;
|
|
||||||
- dest[2] = 0x00;
|
|
||||||
- dest[3] = 0x80;
|
|
||||||
+ /*
|
|
||||||
+ * flip -> unsupported by x11, since XCreatePixmapCursor has
|
|
||||||
+ * no invert functionality, only a mask, shape, background and
|
|
||||||
+ * foreground colors. Use this checkerboard hack to get some
|
|
||||||
+ * contrast for cursors in the guest that relied on invert for
|
|
||||||
+ * the same contrast.
|
|
||||||
+ */
|
|
||||||
+ if ((x ^ y) & 1) {
|
|
||||||
+ dest[0] = 0x30;
|
|
||||||
+ dest[1] = 0x30;
|
|
||||||
+ dest[2] = 0x30;
|
|
||||||
+ dest[3] = 0xc0;
|
|
||||||
+ } else {
|
|
||||||
+ dest[0] = 0x50;
|
|
||||||
+ dest[1] = 0x50;
|
|
||||||
+ dest[2] = 0x50;
|
|
||||||
+ dest[3] = 0x30;
|
|
||||||
+ }
|
|
||||||
} else {
|
|
||||||
/* unchanged -> transparent */
|
|
||||||
dest[0] = 0x00;
|
|
||||||
--
|
|
||||||
1.8.3.1
|
|
||||||
|
|
2
sources
2
sources
@ -1 +1 @@
|
|||||||
9ef6b7f2f368b7966029b7834b7c2bec spice-gtk-0.20.tar.bz2
|
290d1ad5ab8f1e5708fa2549dde2e024 spice-gtk-0.21.tar.bz2
|
||||||
|
@ -12,8 +12,8 @@
|
|||||||
#define _version_suffix
|
#define _version_suffix
|
||||||
|
|
||||||
Name: spice-gtk
|
Name: spice-gtk
|
||||||
Version: 0.20
|
Version: 0.21
|
||||||
Release: 6%{?dist}
|
Release: 1%{?dist}
|
||||||
Summary: A GTK+ widget for SPICE clients
|
Summary: A GTK+ widget for SPICE clients
|
||||||
|
|
||||||
Group: System Environment/Libraries
|
Group: System Environment/Libraries
|
||||||
@ -21,13 +21,6 @@ License: LGPLv2+
|
|||||||
URL: http://spice-space.org/page/Spice-Gtk
|
URL: http://spice-space.org/page/Spice-Gtk
|
||||||
#VCS: git:git://anongit.freedesktop.org/spice/spice-gtk
|
#VCS: git:git://anongit.freedesktop.org/spice/spice-gtk
|
||||||
Source0: http://www.spice-space.org/download/gtk/%{name}-%{version}%{?_version_suffix}.tar.bz2
|
Source0: http://www.spice-space.org/download/gtk/%{name}-%{version}%{?_version_suffix}.tar.bz2
|
||||||
Patch1: 0001-Add-spice_channel_string_to_type-to-map-files.patch
|
|
||||||
Patch2: 0002-smartcard-Handle-VCARD_EMUL_INIT_ALREADY_INITED.patch
|
|
||||||
Patch3: 0003-channel-main-Convert-text-line-endings-if-necessary-.patch
|
|
||||||
Patch4: 0004-usb-widget-fix-gtk2-Python-bindings.patch
|
|
||||||
Patch5: 0005-glib-compat-g_slist_free_full-pass-the-right-ptr-to-.patch
|
|
||||||
Patch6: 0006-gtk-channel-cursor.c-add-cursor_type_to_string-for-d.patch
|
|
||||||
Patch7: 0007-gtk-channel-cursor-copy-spicec-hack-RHBZ-998529.patch
|
|
||||||
|
|
||||||
BuildRequires: intltool
|
BuildRequires: intltool
|
||||||
BuildRequires: gtk2-devel >= 2.14
|
BuildRequires: gtk2-devel >= 2.14
|
||||||
@ -153,16 +146,10 @@ if [ -n '%{?_version_suffix}' ]; then
|
|||||||
mv spice-gtk-%{version}%{?_version_suffix} spice-gtk-%{version}
|
mv spice-gtk-%{version}%{?_version_suffix} spice-gtk-%{version}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
pushd spice-gtk-%{version}
|
#pushd spice-gtk-%{version}
|
||||||
%patch0001 -p1
|
#%patch1 -p1
|
||||||
%patch0002 -p1
|
#find . -name '*.stamp' | xargs touch
|
||||||
%patch0003 -p1
|
#popd
|
||||||
%patch0004 -p1
|
|
||||||
%patch0005 -p1
|
|
||||||
%patch0006 -p1
|
|
||||||
%patch0007 -p1
|
|
||||||
find . -name '*.stamp' | xargs touch
|
|
||||||
popd
|
|
||||||
|
|
||||||
%if %{with_gtk3}
|
%if %{with_gtk3}
|
||||||
cp -a spice-gtk-%{version} spice-gtk3-%{version}
|
cp -a spice-gtk-%{version} spice-gtk3-%{version}
|
||||||
@ -282,6 +269,9 @@ rm -rf %{buildroot}%{_datadir}/pkgconfig/spice-protocol.pc
|
|||||||
%{_bindir}/spicy-stats
|
%{_bindir}/spicy-stats
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Wed Sep 18 2013 Marc-André Lureau <marcandre.lureau@redhat.com> - 0.21-1
|
||||||
|
- Update to spice-gtk 0.21
|
||||||
|
|
||||||
* Fri Sep 13 2013 Christophe Fergeau <cfergeau@redhat.com> 0.20-6
|
* Fri Sep 13 2013 Christophe Fergeau <cfergeau@redhat.com> 0.20-6
|
||||||
- Add misc upstream patches fixing various 0.20 bugs
|
- Add misc upstream patches fixing various 0.20 bugs
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user