Blame SOURCES/0005-vdagent-x11-Release-clipboard-on-client-disconnect-i.patch

a547b4
From 19f3f91c041ebc4e52e8d287ba6d9c66a85af0d0 Mon Sep 17 00:00:00 2001
a547b4
From: Hans de Goede <hdegoede@redhat.com>
a547b4
Date: Mon, 9 Sep 2013 15:50:39 +0200
a547b4
Subject: [PATCH] vdagent-x11: Release clipboard on client disconnect if owned
a547b4
 by client
a547b4
a547b4
https://bugzilla.redhat.com/show_bug.cgi?id=1003977
a547b4
a547b4
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
a547b4
---
a547b4
 src/vdagent-x11.c | 10 ++++++++++
a547b4
 src/vdagent-x11.h |  2 ++
a547b4
 src/vdagent.c     |  1 +
a547b4
 3 files changed, 13 insertions(+)
a547b4
a547b4
diff --git a/src/vdagent-x11.c b/src/vdagent-x11.c
a547b4
index 6a58532..8287421 100644
a547b4
--- a/src/vdagent-x11.c
a547b4
+++ b/src/vdagent-x11.c
a547b4
@@ -1301,6 +1301,16 @@ void vdagent_x11_clipboard_release(struct vdagent_x11 *x11, uint8_t selection)
a547b4
     vdagent_x11_do_read(x11);
a547b4
 }
a547b4
 
a547b4
+void vdagent_x11_client_disconnected(struct vdagent_x11 *x11)
a547b4
+{
a547b4
+    int sel;
a547b4
+
a547b4
+    for (sel = 0; sel < VD_AGENT_CLIPBOARD_SELECTION_SECONDARY; sel++) {
a547b4
+        if (x11->clipboard_owner[sel] == owner_client)
a547b4
+            vdagent_x11_clipboard_release(x11, sel);
a547b4
+    }
a547b4
+}
a547b4
+
a547b4
 /* Function used to determine the default location to save file-xfers,
a547b4
    xdg desktop dir or xdg download dir. We error on the save side and use a
a547b4
    whitelist approach, so any unknown desktops will end up with saving
a547b4
diff --git a/src/vdagent-x11.h b/src/vdagent-x11.h
a547b4
index baa4ce8..5d949f6 100644
a547b4
--- a/src/vdagent-x11.h
a547b4
+++ b/src/vdagent-x11.h
a547b4
@@ -46,6 +46,8 @@ void vdagent_x11_clipboard_data(struct vdagent_x11 *x11, uint8_t selection,
a547b4
     uint32_t type, uint8_t *data, uint32_t size);
a547b4
 void vdagent_x11_clipboard_release(struct vdagent_x11 *x11, uint8_t selection);
a547b4
 
a547b4
+void vdagent_x11_client_disconnected(struct vdagent_x11 *x11);
a547b4
+
a547b4
 int vdagent_x11_has_icons_on_desktop(struct vdagent_x11 *x11);
a547b4
 
a547b4
 #endif
a547b4
diff --git a/src/vdagent.c b/src/vdagent.c
a547b4
index 10ebf6e..c5e09ff 100644
a547b4
--- a/src/vdagent.c
a547b4
+++ b/src/vdagent.c
a547b4
@@ -103,6 +103,7 @@ void daemon_read_complete(struct udscs_connection **connp,
a547b4
         free(data);
a547b4
         break;
a547b4
     case VDAGENTD_CLIENT_DISCONNECTED:
a547b4
+        vdagent_x11_client_disconnected(x11);
a547b4
         vdagent_file_xfers_destroy(vdagent_file_xfers);
a547b4
         vdagent_file_xfers = vdagent_file_xfers_create(client, fx_dir,
a547b4
                                                        fx_open_dir, debug);