aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/xwayland/selection.h2
-rw-r--r--xwayland/selection/outgoing.c21
-rw-r--r--xwayland/xwm.c1
3 files changed, 24 insertions, 0 deletions
diff --git a/include/xwayland/selection.h b/include/xwayland/selection.h
index 85201461..67a23e81 100644
--- a/include/xwayland/selection.h
+++ b/include/xwayland/selection.h
@@ -56,6 +56,8 @@ struct wlr_xwm_selection *xwm_get_selection(struct wlr_xwm *xwm,
void xwm_send_incr_chunk(struct wlr_xwm_selection_transfer *transfer);
void xwm_handle_selection_request(struct wlr_xwm *xwm,
xcb_selection_request_event_t *req);
+void xwm_handle_selection_destroy_notify(struct wlr_xwm *xwm,
+ xcb_destroy_notify_event_t *event);
void xwm_get_incr_chunk(struct wlr_xwm_selection_transfer *transfer);
void xwm_handle_selection_notify(struct wlr_xwm *xwm,
diff --git a/xwayland/selection/outgoing.c b/xwayland/selection/outgoing.c
index fd5021d5..169f516e 100644
--- a/xwayland/selection/outgoing.c
+++ b/xwayland/selection/outgoing.c
@@ -3,6 +3,7 @@
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
+#include <wayland-util.h>
#include <wlr/types/wlr_data_device.h>
#include <wlr/types/wlr_primary_selection.h>
#include <wlr/util/log.h>
@@ -417,3 +418,23 @@ void xwm_handle_selection_request(struct wlr_xwm *xwm,
free(mime_type);
}
}
+
+void xwm_handle_selection_destroy_notify(struct wlr_xwm *xwm,
+ xcb_destroy_notify_event_t *event) {
+ struct wlr_xwm_selection *selections[] = {
+ &xwm->clipboard_selection,
+ &xwm->primary_selection,
+ &xwm->dnd_selection,
+ };
+
+ for (size_t i = 0; i < sizeof(selections)/sizeof(selections[0]); ++i) {
+ struct wlr_xwm_selection *selection = selections[i];
+
+ struct wlr_xwm_selection_transfer *outgoing, *tmp;
+ wl_list_for_each_safe(outgoing, tmp, &selection->outgoing, outgoing_link) {
+ if (event->window == outgoing->request.requestor) {
+ xwm_selection_transfer_destroy_outgoing(outgoing);
+ }
+ }
+ }
+}
diff --git a/xwayland/xwm.c b/xwayland/xwm.c
index a0ff4d90..28e329f3 100644
--- a/xwayland/xwm.c
+++ b/xwayland/xwm.c
@@ -846,6 +846,7 @@ static void xwm_handle_destroy_notify(struct wlr_xwm *xwm,
return;
}
xwayland_surface_destroy(xsurface);
+ xwm_handle_selection_destroy_notify(xwm, ev);
}
static void xwm_handle_configure_request(struct wlr_xwm *xwm,