[gtk+/wip/otte/clipboard: 99/107] x11: Split out a function
- From: Benjamin Otte <otte src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/otte/clipboard: 99/107] x11: Split out a function
- Date: Fri, 1 Dec 2017 14:06:15 +0000 (UTC)
commit e2369c7109177c6d00e178972519fe35733e3870
Author: Benjamin Otte <otte redhat com>
Date: Fri Dec 1 00:02:12 2017 +0100
x11: Split out a function
This will be necessary for MULTIPLE handling.
gdk/x11/gdkclipboard-x11.c | 172 ++++++++++++++++++++++++-------------------
1 files changed, 96 insertions(+), 76 deletions(-)
---
diff --git a/gdk/x11/gdkclipboard-x11.c b/gdk/x11/gdkclipboard-x11.c
index bdda2aa..89b8589 100644
--- a/gdk/x11/gdkclipboard-x11.c
+++ b/gdk/x11/gdkclipboard-x11.c
@@ -479,6 +479,96 @@ gdk_x11_clipboard_claim_remote (GdkX11Clipboard *cb,
gdk_x11_clipboard_request_targets (cb);
}
+static void
+gdk_x11_clipboard_request_selection (GdkX11Clipboard *cb,
+ Window requestor,
+ const char *target,
+ const char *property,
+ gulong timestamp)
+{
+ const char *type, *mime_type;
+ MimeTypeHandleFunc handler_func = NULL;
+ GdkDisplay *display;
+ gint format;
+ gsize i;
+
+ display = gdk_clipboard_get_display (GDK_CLIPBOARD (cb));
+ mime_type = gdk_intern_mime_type (target);
+
+ if (mime_type)
+ {
+ handler_func = gdk_x11_clipboard_default_output_handler;
+ type = target;
+ format = 8;
+ }
+ else
+ {
+ for (i = 0; i < G_N_ELEMENTS (special_targets); i++)
+ {
+ if (g_str_equal (target, special_targets[i].x_target) &&
+ special_targets[i].handler)
+ {
+ if (special_targets[i].mime_type)
+ mime_type = gdk_intern_mime_type (special_targets[i].mime_type);
+ handler_func = special_targets[i].handler;
+ type = special_targets[i].type;
+ format = special_targets[i].format;
+ break;
+ }
+ }
+ }
+
+ if (handler_func == NULL ||
+ (mime_type && !gdk_content_formats_contain_mime_type (gdk_clipboard_get_formats (GDK_CLIPBOARD (cb)),
mime_type)))
+ {
+ Display *xdisplay = gdk_x11_display_get_xdisplay (display);
+ XSelectionEvent xreply;
+ int error;
+
+ xreply.type = SelectionNotify;
+ xreply.serial = 0;
+ xreply.send_event = True;
+ xreply.requestor = requestor;
+ xreply.selection = cb->xselection;
+ xreply.target = gdk_x11_get_xatom_by_name_for_display (display, target);
+ xreply.property = None;
+ xreply.time = timestamp;
+
+ GDK_NOTE(CLIPBOARD, g_printerr ("%s%s: Sending SelectionNotify rejecting request\n",
+ cb->selection, target));
+
+ gdk_x11_display_error_trap_push (display);
+ if (XSendEvent (xdisplay, xreply.requestor, False, NoEventMask, (XEvent*) & xreply) == 0)
+ {
+ GDK_NOTE(CLIPBOARD, g_printerr ("%s:%s: failed to XSendEvent()\n",
+ cb->selection, target));
+ g_warning ("failed to XSendEvent()");
+ }
+ XSync (xdisplay, False);
+
+ error = gdk_x11_display_error_trap_pop (display);
+ if (error != Success)
+ {
+ GDK_NOTE(CLIPBOARD, g_printerr ("%s:%s: X error during write: %d\n",
+ cb->selection, target, error));
+ }
+ }
+ else
+ {
+ GOutputStream *stream;
+
+ stream = gdk_x11_selection_output_stream_new (display,
+ requestor,
+ cb->selection,
+ target,
+ property,
+ type,
+ format,
+ timestamp);
+ handler_func (cb, target, type, format, stream);
+ }
+}
+
static GdkFilterReturn
gdk_x11_clipboard_filter_event (GdkXEvent *xev,
GdkEvent *gdkevent,
@@ -514,11 +604,7 @@ gdk_x11_clipboard_filter_event (GdkXEvent *xev,
case SelectionRequest:
{
- GOutputStream *stream;
- const char *target, *property, *type, *mime_type;
- MimeTypeHandleFunc handler_func = NULL;
- gint format;
- gsize i;
+ const char *target, *property;
if (xevent->xselectionrequest.selection != cb->xselection)
return GDK_FILTER_CONTINUE;
@@ -544,77 +630,11 @@ gdk_x11_clipboard_filter_event (GdkXEvent *xev,
GDK_NOTE(CLIPBOARD, g_printerr ("%s: got SelectionRequest for %s @ %s\n",
cb->selection, target, property));
- mime_type = gdk_intern_mime_type (target);
- if (mime_type)
- {
- handler_func = gdk_x11_clipboard_default_output_handler;
- type = target;
- format = 8;
- }
- else
- {
- for (i = 0; i < G_N_ELEMENTS (special_targets); i++)
- {
- if (g_str_equal (target, special_targets[i].x_target) &&
- special_targets[i].handler)
- {
- if (special_targets[i].mime_type)
- mime_type = gdk_intern_mime_type (special_targets[i].mime_type);
- handler_func = special_targets[i].handler;
- type = special_targets[i].type;
- format = special_targets[i].format;
- break;
- }
- }
- }
-
- if (handler_func == NULL ||
- (mime_type && !gdk_content_formats_contain_mime_type (gdk_clipboard_get_formats (GDK_CLIPBOARD
(cb)), mime_type)))
- {
- Display *xdisplay = gdk_x11_display_get_xdisplay (display);
- XSelectionEvent xreply;
- int error;
-
- xreply.type = SelectionNotify;
- xreply.serial = 0;
- xreply.send_event = True;
- xreply.requestor = xevent->xselectionrequest.requestor,
- xreply.selection = xevent->xselectionrequest.selection;
- xreply.target = xevent->xselectionrequest.target;
- xreply.property = None;
- xreply.time = xevent->xselectionrequest.time;
-
- GDK_NOTE(CLIPBOARD, g_printerr ("%s%s: Sending SelectionNotify rejecting request\n",
- cb->selection, target));
-
- gdk_x11_display_error_trap_push (display);
- if (XSendEvent (xdisplay, xreply.requestor, False, NoEventMask, (XEvent*) & xreply) == 0)
- {
- GDK_NOTE(CLIPBOARD, g_printerr ("%s:%s: failed to XSendEvent()\n",
- cb->selection, target));
- g_warning ("failed to XSendEvent()");
- }
- XSync (xdisplay, False);
-
- error = gdk_x11_display_error_trap_pop (display);
- if (error != Success)
- {
- GDK_NOTE(CLIPBOARD, g_printerr ("%s:%s: X error during write: %d\n",
- cb->selection, target, error));
- }
- }
- else
- {
- stream = gdk_x11_selection_output_stream_new (display,
- xevent->xselectionrequest.requestor,
- cb->selection,
- target,
- property,
- type,
- format,
- xevent->xselectionrequest.time);
- handler_func (cb, target, type, format, stream);
- }
+ gdk_x11_clipboard_request_selection (cb,
+ xevent->xselectionrequest.requestor,
+ target,
+ property,
+ xevent->xselectionrequest.time);
return GDK_FILTER_REMOVE;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]