1 /* GDK - The GIMP Drawing Kit
2 * Copyright (C) 2009 Carlos Garnacho <carlosg@gnome.org>
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library. If not, see <http://www.gnu.org/licenses/>.
26 #include <gdk/gdkwindow.h>
27 #include <gdk/gdktypes.h>
28 #include "gdkprivate-wayland.h"
29 #include "gdkwayland.h"
30 #include "gdkkeysyms.h"
31 #include "gdkdeviceprivate.h"
32 #include "gdkdevicemanagerprivate.h"
33 #include "gdkprivate-wayland.h"
35 #include <xkbcommon/xkbcommon.h>
36 #include <X11/keysym.h>
41 #define GDK_TYPE_DEVICE_CORE (gdk_device_core_get_type ())
42 #define GDK_DEVICE_CORE(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), GDK_TYPE_DEVICE_CORE, GdkDeviceCore))
43 #define GDK_DEVICE_CORE_CLASS(c) (G_TYPE_CHECK_CLASS_CAST ((c), GDK_TYPE_DEVICE_CORE, GdkDeviceCoreClass))
44 #define GDK_IS_DEVICE_CORE(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), GDK_TYPE_DEVICE_CORE))
45 #define GDK_IS_DEVICE_CORE_CLASS(c) (G_TYPE_CHECK_CLASS_TYPE ((c), GDK_TYPE_DEVICE_CORE))
46 #define GDK_DEVICE_CORE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), GDK_TYPE_DEVICE_CORE, GdkDeviceCoreClass))
48 typedef struct _GdkDeviceCore GdkDeviceCore;
49 typedef struct _GdkDeviceCoreClass GdkDeviceCoreClass;
50 typedef struct _GdkWaylandDevice GdkWaylandDevice;
52 typedef struct _DataOffer DataOffer;
54 typedef struct _GdkWaylandSelectionOffer GdkWaylandSelectionOffer;
56 struct _GdkWaylandDevice
58 struct wl_seat *wl_seat;
59 struct wl_pointer *wl_pointer;
60 struct wl_keyboard *wl_keyboard;
63 GdkDeviceManager *device_manager;
70 GdkModifierType modifiers;
71 GdkWindow *pointer_focus;
72 GdkWindow *keyboard_focus;
73 struct wl_data_device *data_device;
74 double surface_x, surface_y;
76 GdkWindow *pointer_grab_window;
77 uint32_t pointer_grab_time;
82 DataOffer *drag_offer;
83 DataOffer *selection_offer;
85 GdkWaylandSelectionOffer *selection_offer_out;
87 struct wl_surface *pointer_surface;
92 GdkDevice parent_instance;
93 GdkWaylandDevice *device;
96 struct _GdkDeviceCoreClass
98 GdkDeviceClass parent_class;
101 G_DEFINE_TYPE (GdkDeviceCore, gdk_device_core, GDK_TYPE_DEVICE)
103 #define GDK_TYPE_DEVICE_MANAGER_CORE (gdk_device_manager_core_get_type ())
104 #define GDK_DEVICE_MANAGER_CORE(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), GDK_TYPE_DEVICE_MANAGER_CORE, GdkDeviceManagerCore))
105 #define GDK_DEVICE_MANAGER_CORE_CLASS(c) (G_TYPE_CHECK_CLASS_CAST ((c), GDK_TYPE_DEVICE_MANAGER_CORE, GdkDeviceManagerCoreClass))
106 #define GDK_IS_DEVICE_MANAGER_CORE(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), GDK_TYPE_DEVICE_MANAGER_CORE))
107 #define GDK_IS_DEVICE_MANAGER_CORE_CLASS(c) (G_TYPE_CHECK_CLASS_TYPE ((c), GDK_TYPE_DEVICE_MANAGER_CORE))
108 #define GDK_DEVICE_MANAGER_CORE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), GDK_TYPE_DEVICE_MANAGER_CORE, GdkDeviceManagerCoreClass))
110 typedef struct _GdkDeviceManagerCore GdkDeviceManagerCore;
111 typedef struct _GdkDeviceManagerCoreClass GdkDeviceManagerCoreClass;
113 struct _GdkDeviceManagerCore
115 GdkDeviceManager parent_object;
116 GdkDevice *core_pointer;
117 GdkDevice *core_keyboard;
121 struct _GdkDeviceManagerCoreClass
123 GdkDeviceManagerClass parent_class;
126 G_DEFINE_TYPE (GdkDeviceManagerCore,
127 gdk_device_manager_core, GDK_TYPE_DEVICE_MANAGER)
130 gdk_device_core_get_history (GdkDevice *device,
134 GdkTimeCoord ***events,
141 gdk_device_core_get_state (GdkDevice *device,
144 GdkModifierType *mask)
148 gdk_window_get_device_position (window, device, &x_int, &y_int, mask);
158 gdk_device_core_set_window_cursor (GdkDevice *device,
162 GdkWaylandDevice *wd = GDK_DEVICE_CORE(device)->device;
163 GdkWaylandDisplay *wayland_display =
164 GDK_WAYLAND_DISPLAY (gdk_window_get_display (window));
165 struct wl_buffer *buffer;
169 g_object_ref (cursor);
171 /* Setting the cursor to NULL means that we should use the default cursor */
174 /* FIXME: Is this the best sensible default ? */
175 cursor = _gdk_wayland_display_get_cursor_for_type (device->display,
179 buffer = _gdk_wayland_cursor_get_buffer (cursor, &x, &y, &w, &h);
180 wl_pointer_set_cursor (wd->wl_pointer,
181 _gdk_wayland_display_get_serial (wayland_display),
184 wl_surface_attach (wd->pointer_surface, buffer, 0, 0);
185 wl_surface_damage (wd->pointer_surface, 0, 0, w, h);
186 wl_surface_commit(wd->pointer_surface);
188 g_object_unref (cursor);
192 gdk_device_core_warp (GdkDevice *device,
200 gdk_device_core_query_state (GdkDevice *device,
202 GdkWindow **root_window,
203 GdkWindow **child_window,
208 GdkModifierType *mask)
210 GdkWaylandDevice *wd;
211 GdkScreen *default_screen;
213 wd = GDK_DEVICE_CORE(device)->device;
214 default_screen = gdk_display_get_default_screen (wd->display);
217 *root_window = gdk_screen_get_root_window (default_screen);
219 *child_window = wd->pointer_focus;
220 /* Do something clever for relative here */
228 *win_x = wd->surface_x;
230 *win_y = wd->surface_y;
232 *mask = wd->modifiers;
236 gdk_device_core_grab (GdkDevice *device,
238 gboolean owner_events,
239 GdkEventMask event_mask,
240 GdkWindow *confine_to,
244 GdkWaylandDevice *wayland_device = GDK_DEVICE_CORE (device)->device;
246 if (gdk_device_get_source (device) == GDK_SOURCE_KEYBOARD)
248 /* Device is a keyboard */
249 return GDK_GRAB_SUCCESS;
253 /* Device is a pointer */
255 if (wayland_device->pointer_grab_window != NULL &&
256 time_ != 0 && wayland_device->pointer_grab_time > time_)
258 return GDK_GRAB_ALREADY_GRABBED;
262 time_ = wayland_device->time;
264 wayland_device->pointer_grab_window = window;
265 wayland_device->pointer_grab_time = time_;
267 /* FIXME: This probably breaks if you end up with multiple grabs on the
268 * same window - but we need to know the input device for when we are
269 * asked to map a popup window so that the grab can be managed by the
272 _gdk_wayland_window_set_device_grabbed (window,
273 wayland_device->wl_seat,
277 return GDK_GRAB_SUCCESS;
281 gdk_device_core_ungrab (GdkDevice *device,
284 GdkWaylandDevice *wayland_device = GDK_DEVICE_CORE (device)->device;
286 GdkDeviceGrabInfo *grab;
288 display = gdk_device_get_display (device);
290 if (gdk_device_get_source (device) == GDK_SOURCE_KEYBOARD)
292 /* Device is a keyboard */
296 /* Device is a pointer */
297 grab = _gdk_display_get_last_device_grab (display, device);
300 grab->serial_end = grab->serial_start;
302 if (wayland_device->pointer_grab_window)
303 _gdk_wayland_window_set_device_grabbed (wayland_device->pointer_grab_window,
310 gdk_device_core_window_at_position (GdkDevice *device,
313 GdkModifierType *mask,
314 gboolean get_toplevel)
316 GdkWaylandDevice *wd;
318 wd = GDK_DEVICE_CORE(device)->device;
320 *win_x = wd->surface_x;
322 *win_y = wd->surface_y;
324 *mask = wd->modifiers;
326 return wd->pointer_focus;
330 gdk_device_core_select_window_events (GdkDevice *device,
332 GdkEventMask event_mask)
337 gdk_device_core_class_init (GdkDeviceCoreClass *klass)
339 GdkDeviceClass *device_class = GDK_DEVICE_CLASS (klass);
341 device_class->get_history = gdk_device_core_get_history;
342 device_class->get_state = gdk_device_core_get_state;
343 device_class->set_window_cursor = gdk_device_core_set_window_cursor;
344 device_class->warp = gdk_device_core_warp;
345 device_class->query_state = gdk_device_core_query_state;
346 device_class->grab = gdk_device_core_grab;
347 device_class->ungrab = gdk_device_core_ungrab;
348 device_class->window_at_position = gdk_device_core_window_at_position;
349 device_class->select_window_events = gdk_device_core_select_window_events;
353 gdk_device_core_init (GdkDeviceCore *device_core)
357 device = GDK_DEVICE (device_core);
359 _gdk_device_add_axis (device, GDK_NONE, GDK_AXIS_X, 0, 0, 1);
360 _gdk_device_add_axis (device, GDK_NONE, GDK_AXIS_Y, 0, 0, 1);
364 _gdk_wayland_device_get_wl_seat (GdkDevice *device)
366 return GDK_DEVICE_CORE (device)->device->wl_seat;
370 _gdk_wayland_device_get_wl_pointer (GdkDevice *device)
372 return GDK_DEVICE_CORE (device)->device->wl_pointer;
377 _gdk_wayland_device_get_wl_keyboard (GdkDevice *device)
379 return GDK_DEVICE_CORE (device)->device->wl_keyboard;
383 _gdk_wayland_device_get_keymap (GdkDevice *device)
385 return GDK_DEVICE_CORE (device)->device->keymap;
390 input_handle_motion(void *data, struct wl_input_device *input_device,
392 int32_t x, int32_t y, int32_t sx, int32_t sy)
394 GdkWaylandDevice *device = data;
395 GdkWaylandDisplay *display = GDK_WAYLAND_DISPLAY (device->display);
398 event = gdk_event_new (GDK_NOTHING);
403 device->surface_x = sx;
404 device->surface_y = sy;
406 event->motion.type = GDK_MOTION_NOTIFY;
407 event->motion.window = g_object_ref (device->pointer_focus);
408 gdk_event_set_device (event, device->pointer);
409 event->motion.time = time;
410 event->motion.x = (gdouble) sx;
411 event->motion.y = (gdouble) sy;
412 event->motion.x_root = (gdouble) x;
413 event->motion.y_root = (gdouble) y;
414 event->motion.axes = NULL;
415 event->motion.state = device->modifiers;
416 event->motion.is_hint = 0;
417 gdk_event_set_screen (event, display->screen);
420 g_message ("motion %d %d, state %d",
421 sx, sy, event->button.state));
423 _gdk_wayland_display_deliver_event (device->display, event);
427 input_handle_button(void *data, struct wl_input_device *input_device,
428 uint32_t time, uint32_t button, uint32_t state)
430 GdkWaylandDevice *device = data;
431 GdkWaylandDisplay *display = GDK_WAYLAND_DISPLAY (device->display);
444 gdk_button = button - 271;
449 event = gdk_event_new (state ? GDK_BUTTON_PRESS : GDK_BUTTON_RELEASE);
450 event->button.window = g_object_ref (device->pointer_focus);
451 gdk_event_set_device (event, device->pointer);
452 event->button.time = time;
453 event->button.x = (gdouble) device->surface_x;
454 event->button.y = (gdouble) device->surface_y;
455 event->button.x_root = (gdouble) device->x;
456 event->button.y_root = (gdouble) device->y;
457 event->button.axes = NULL;
458 event->button.state = device->modifiers;
459 event->button.button = gdk_button;
460 gdk_event_set_screen (event, display->screen);
462 modifier = 1 << (8 + gdk_button - 1);
464 device->modifiers |= modifier;
466 device->modifiers &= ~modifier;
469 g_message ("button %d %s, state %d",
470 event->button.button,
471 state ? "press" : "release", event->button.state));
473 _gdk_wayland_display_deliver_event (device->display, event);
477 translate_keyboard_string (GdkEventKey *event)
482 /* Fill in event->string crudely, since various programs
485 event->string = NULL;
487 if (event->keyval != GDK_KEY_VoidSymbol)
488 c = gdk_keyval_to_unicode (event->keyval);
495 /* Apply the control key - Taken from Xlib
497 if (event->state & GDK_CONTROL_MASK)
499 if ((c >= '@' && c < '\177') || c == ' ') c &= 0x1F;
502 event->string = g_memdup ("\0\0", 2);
507 else if (c >= '3' && c <= '7') c -= ('3' - '\033');
508 else if (c == '8') c = '\177';
509 else if (c == '/') c = '_' & 0x1F;
512 len = g_unichar_to_utf8 (c, buf);
515 event->string = g_locale_from_utf8 (buf, len,
516 NULL, &bytes_written,
519 event->length = bytes_written;
521 else if (event->keyval == GDK_KEY_Escape)
524 event->string = g_strdup ("\033");
526 else if (event->keyval == GDK_KEY_Return ||
527 event->keyval == GDK_KEY_KP_Enter)
530 event->string = g_strdup ("\r");
536 event->string = g_strdup ("");
541 keyboard_repeat (gpointer data);
544 deliver_key_event(GdkWaylandDevice *device,
545 uint32_t time, uint32_t key, uint32_t state)
548 uint32_t code, modifier, level;
549 struct xkb_desc *xkb;
552 keymap = gdk_keymap_get_for_display (device->display);
553 xkb = _gdk_wayland_keymap_get_xkb_desc (keymap);
556 event = gdk_event_new (state ? GDK_KEY_PRESS : GDK_KEY_RELEASE);
557 event->key.window = g_object_ref (device->keyboard_focus);
558 gdk_event_set_device (event, device->keyboard);
559 event->button.time = time;
560 event->key.state = device->modifiers;
561 event->key.group = 0;
562 code = key + xkb->min_key_code;
563 event->key.hardware_keycode = code;
566 if (device->modifiers & XKB_COMMON_SHIFT_MASK &&
567 XkbKeyGroupWidth(xkb, code, 0) > 1)
570 event->key.keyval = XkbKeySymEntry(xkb, code, level, 0);
572 modifier = xkb->map->modmap[code];
574 device->modifiers |= modifier;
576 device->modifiers &= ~modifier;
578 event->key.is_modifier = modifier > 0;
580 translate_keyboard_string (&event->key);
582 _gdk_wayland_display_deliver_event (device->display, event);
585 g_message ("keyboard event, code %d, sym %d, "
586 "string %s, mods 0x%x",
587 code, event->key.keyval,
588 event->key.string, event->key.state));
590 device->repeat_count++;
591 device->repeat_key = key;
595 if (device->repeat_timer)
597 g_source_remove (device->repeat_timer);
598 device->repeat_timer = 0;
606 else switch (device->repeat_count)
609 if (device->repeat_timer)
611 g_source_remove (device->repeat_timer);
612 device->repeat_timer = 0;
615 device->repeat_timer =
616 gdk_threads_add_timeout (400, keyboard_repeat, device);
619 device->repeat_timer =
620 gdk_threads_add_timeout (80, keyboard_repeat, device);
628 keyboard_repeat (gpointer data)
630 GdkWaylandDevice *device = data;
632 return deliver_key_event (device, device->time, device->repeat_key, 1);
636 input_handle_key(void *data, struct wl_input_device *input_device,
637 uint32_t time, uint32_t key, uint32_t state)
639 GdkWaylandDevice *device = data;
641 device->repeat_count = 0;
642 deliver_key_event (data, time, key, state);
646 input_handle_pointer_focus(void *data,
647 struct wl_input_device *input_device,
648 uint32_t time, struct wl_surface *surface,
649 int32_t x, int32_t y, int32_t sx, int32_t sy)
651 GdkWaylandDevice *device = data;
655 if (device->pointer_focus)
657 event = gdk_event_new (GDK_LEAVE_NOTIFY);
658 event->crossing.window = g_object_ref (device->pointer_focus);
659 gdk_event_set_device (event, device->pointer);
660 event->crossing.subwindow = NULL;
661 event->crossing.time = time;
662 event->crossing.x = (gdouble) device->surface_x;
663 event->crossing.y = (gdouble) device->surface_y;
664 event->crossing.x_root = (gdouble) device->x;
665 event->crossing.y_root = (gdouble) device->y;
667 event->crossing.mode = GDK_CROSSING_NORMAL;
668 event->crossing.detail = GDK_NOTIFY_ANCESTOR;
669 event->crossing.focus = TRUE;
670 event->crossing.state = 0;
672 _gdk_wayland_display_deliver_event (device->display, event);
675 g_message ("leave, device %p surface %p",
676 device, device->pointer_focus));
678 g_object_unref(device->pointer_focus);
679 device->pointer_focus = NULL;
684 device->pointer_focus = wl_surface_get_user_data(surface);
685 g_object_ref(device->pointer_focus);
687 event = gdk_event_new (GDK_ENTER_NOTIFY);
688 event->crossing.window = g_object_ref (device->pointer_focus);
689 gdk_event_set_device (event, device->pointer);
690 event->crossing.subwindow = NULL;
691 event->crossing.time = time;
692 event->crossing.x = (gdouble) sx;
693 event->crossing.y = (gdouble) sy;
694 event->crossing.x_root = (gdouble) x;
695 event->crossing.y_root = (gdouble) y;
697 event->crossing.mode = GDK_CROSSING_NORMAL;
698 event->crossing.detail = GDK_NOTIFY_ANCESTOR;
699 event->crossing.focus = TRUE;
700 event->crossing.state = 0;
702 device->surface_x = sx;
703 device->surface_y = sy;
707 _gdk_wayland_display_deliver_event (device->display, event);
710 g_message ("enter, device %p surface %p",
711 device, device->pointer_focus));
716 update_modifiers(GdkWaylandDevice *device, struct wl_array *keys)
720 struct xkb_desc *xkb;
722 keymap = gdk_keymap_get_for_display (device->display);
723 xkb = _gdk_wayland_keymap_get_xkb_desc (keymap);
725 end = keys->data + keys->size;
726 device->modifiers = 0;
727 for (k = keys->data; k < end; k++)
728 device->modifiers |= xkb->map->modmap[*k];
732 input_handle_keyboard_focus(void *data,
733 struct wl_input_device *input_device,
735 struct wl_surface *surface,
736 struct wl_array *keys)
738 GdkWaylandDevice *device = data;
742 if (device->keyboard_focus)
744 _gdk_wayland_window_remove_focus (device->keyboard_focus);
745 event = gdk_event_new (GDK_FOCUS_CHANGE);
746 event->focus_change.window = g_object_ref (device->keyboard_focus);
747 event->focus_change.send_event = FALSE;
748 event->focus_change.in = FALSE;
749 gdk_event_set_device (event, device->keyboard);
751 g_object_unref(device->keyboard_focus);
752 device->keyboard_focus = NULL;
755 g_message ("focus out, device %p surface %p",
756 device, device->keyboard_focus));
758 _gdk_wayland_display_deliver_event (device->display, event);
763 device->keyboard_focus = wl_surface_get_user_data(surface);
764 g_object_ref(device->keyboard_focus);
766 event = gdk_event_new (GDK_FOCUS_CHANGE);
767 event->focus_change.window = g_object_ref (device->keyboard_focus);
768 event->focus_change.send_event = FALSE;
769 event->focus_change.in = TRUE;
770 gdk_event_set_device (event, device->keyboard);
772 update_modifiers (device, keys);
775 g_message ("focus int, device %p surface %p",
776 device, device->keyboard_focus));
778 _gdk_wayland_display_deliver_event (device->display, event);
780 _gdk_wayland_window_add_focus (device->keyboard_focus);
784 static const struct wl_input_device_listener input_device_listener = {
788 input_handle_pointer_focus,
789 input_handle_keyboard_focus,
794 struct wl_data_offer *offer;
800 data_offer_offer (void *data,
801 struct wl_data_offer *wl_data_offer,
804 DataOffer *offer = (DataOffer *)data;
805 g_debug (G_STRLOC ": %s wl_data_offer = %p type = %s",
806 G_STRFUNC, wl_data_offer, type);
808 g_ptr_array_add (offer->types, g_strdup (type));
812 data_offer_unref (DataOffer *offer)
816 if (offer->ref_count == 0)
818 g_ptr_array_free (offer->types, TRUE);
823 static const struct wl_data_offer_listener data_offer_listener = {
828 data_device_data_offer (void *data,
829 struct wl_data_device *data_device,
830 struct wl_data_offer *_offer)
834 /* This structure is reference counted to handle the case where you get a
835 * leave but are in the middle of transferring data
837 offer = g_new0 (DataOffer, 1);
838 offer->ref_count = 1;
839 offer->types = g_ptr_array_new_with_free_func (g_free);
840 offer->offer = _offer;
842 /* The DataOffer structure is then retrieved later since this sets the user
845 wl_data_offer_add_listener (offer->offer,
846 &data_offer_listener,
851 data_device_enter (void *data,
852 struct wl_data_device *data_device,
854 struct wl_surface *surface,
857 struct wl_data_offer *offer)
859 GdkWaylandDevice *device = (GdkWaylandDevice *)data;
861 g_debug (G_STRLOC ": %s data_device = %p time = %d, surface = %p, x = %d y = %d, offer = %p",
862 G_STRFUNC, data_device, time, surface, x, y, offer);
864 /* Retrieve the DataOffer associated with with the wl_data_offer - this
865 * association is made when the listener is attached.
867 g_assert (device->drag_offer == NULL);
868 device->drag_offer = wl_data_offer_get_user_data (offer);
872 data_device_leave (void *data,
873 struct wl_data_device *data_device)
875 GdkWaylandDevice *device = (GdkWaylandDevice *)data;
877 g_debug (G_STRLOC ": %s data_device = %p",
878 G_STRFUNC, data_device);
880 data_offer_unref (device->drag_offer);
881 device->drag_offer = NULL;
885 data_device_motion (void *data,
886 struct wl_data_device *data_device,
891 g_debug (G_STRLOC ": %s data_device = %p, time = %d, x = %d, y = %d",
892 G_STRFUNC, data_device, time, x, y);
896 data_device_drop (void *data,
897 struct wl_data_device *data_device)
899 g_debug (G_STRLOC ": %s data_device = %p",
900 G_STRFUNC, data_device);
904 data_device_selection (void *data,
905 struct wl_data_device *wl_data_device,
906 struct wl_data_offer *offer)
908 GdkWaylandDevice *device = (GdkWaylandDevice *)data;
910 g_debug (G_STRLOC ": %s wl_data_device = %p wl_data_offer = %p",
911 G_STRFUNC, wl_data_device, offer);
915 if (device->selection_offer)
917 data_offer_unref (device->selection_offer);
918 device->selection_offer = NULL;
924 if (device->selection_offer)
926 data_offer_unref (device->selection_offer);
927 device->selection_offer = NULL;
930 /* Retrieve the DataOffer associated with with the wl_data_offer - this
931 * association is made when the listener is attached.
933 g_assert (device->selection_offer == NULL);
934 device->selection_offer = wl_data_offer_get_user_data (offer);
937 static const struct wl_data_device_listener data_device_listener = {
938 data_device_data_offer,
943 data_device_selection
949 pointer_handle_enter (void *data,
950 struct wl_pointer *pointer,
952 struct wl_surface *surface,
956 GdkWaylandDevice *device = data;
958 GdkWaylandDisplay *wayland_display =
959 GDK_WAYLAND_DISPLAY (device->display);
961 _gdk_wayland_display_update_serial (wayland_display, serial);
963 device->pointer_focus = wl_surface_get_user_data(surface);
964 g_object_ref(device->pointer_focus);
966 event = gdk_event_new (GDK_ENTER_NOTIFY);
967 event->crossing.window = g_object_ref (device->pointer_focus);
968 gdk_event_set_device (event, device->pointer);
969 event->crossing.subwindow = NULL;
970 event->crossing.time = (guint32)(g_get_monotonic_time () / 1000);
971 event->crossing.x = wl_fixed_to_double (sx);
972 event->crossing.y = wl_fixed_to_double (sy);
974 event->crossing.mode = GDK_CROSSING_NORMAL;
975 event->crossing.detail = GDK_NOTIFY_ANCESTOR;
976 event->crossing.focus = TRUE;
977 event->crossing.state = 0;
979 device->surface_x = wl_fixed_to_double (sx);
980 device->surface_y = wl_fixed_to_double (sy);
982 _gdk_wayland_display_deliver_event (device->display, event);
985 g_message ("enter, device %p surface %p",
986 device, device->pointer_focus));
990 pointer_handle_leave (void *data,
991 struct wl_pointer *pointer,
993 struct wl_surface *surface)
995 GdkWaylandDevice *device = data;
997 GdkWaylandDisplay *wayland_display =
998 GDK_WAYLAND_DISPLAY (device->display);
1000 _gdk_wayland_display_update_serial (wayland_display, serial);
1002 event = gdk_event_new (GDK_LEAVE_NOTIFY);
1003 event->crossing.window = g_object_ref (device->pointer_focus);
1004 gdk_event_set_device (event, device->pointer);
1005 event->crossing.subwindow = NULL;
1006 event->crossing.time = (guint32)(g_get_monotonic_time () / 1000);
1007 event->crossing.x = device->surface_x;
1008 event->crossing.y = device->surface_y;
1010 event->crossing.mode = GDK_CROSSING_NORMAL;
1011 event->crossing.detail = GDK_NOTIFY_ANCESTOR;
1012 event->crossing.focus = TRUE;
1013 event->crossing.state = 0;
1015 _gdk_wayland_display_deliver_event (device->display, event);
1018 g_message ("leave, device %p surface %p",
1019 device, device->pointer_focus));
1021 g_object_unref(device->pointer_focus);
1022 device->pointer_focus = NULL;
1026 pointer_handle_motion (void *data,
1027 struct wl_pointer *pointer,
1032 GdkWaylandDevice *device = data;
1033 GdkWaylandDisplay *display = GDK_WAYLAND_DISPLAY (device->display);
1036 event = gdk_event_new (GDK_NOTHING);
1038 device->time = time;
1039 device->surface_x = wl_fixed_to_double (sx);
1040 device->surface_y = wl_fixed_to_double (sy);
1042 event->motion.type = GDK_MOTION_NOTIFY;
1043 event->motion.window = g_object_ref (device->pointer_focus);
1044 gdk_event_set_device (event, device->pointer);
1045 event->motion.time = time;
1046 event->motion.x = wl_fixed_to_double (sx);
1047 event->motion.y = wl_fixed_to_double (sy);
1048 event->motion.axes = NULL;
1049 event->motion.state = device->modifiers;
1050 event->motion.is_hint = 0;
1051 gdk_event_set_screen (event, display->screen);
1054 g_message ("motion %d %d, state %d",
1055 sx, sy, event->button.state));
1057 _gdk_wayland_display_deliver_event (device->display, event);
1061 pointer_handle_button (void *data,
1062 struct wl_pointer *pointer,
1068 GdkWaylandDevice *device = data;
1069 GdkWaylandDisplay *display = GDK_WAYLAND_DISPLAY (device->display);
1073 GdkWaylandDisplay *wayland_display =
1074 GDK_WAYLAND_DISPLAY (device->display);
1076 _gdk_wayland_display_update_serial (wayland_display, serial);
1086 gdk_button = button - 271;
1090 device->time = time;
1092 event = gdk_event_new (state ? GDK_BUTTON_PRESS : GDK_BUTTON_RELEASE);
1093 event->button.window = g_object_ref (device->pointer_focus);
1094 gdk_event_set_device (event, device->pointer);
1095 event->button.time = time;
1096 event->button.x = device->surface_x;
1097 event->button.y = device->surface_y;
1098 event->button.axes = NULL;
1099 event->button.state = device->modifiers;
1100 event->button.button = gdk_button;
1101 gdk_event_set_screen (event, display->screen);
1103 modifier = 1 << (8 + gdk_button - 1);
1105 device->modifiers |= modifier;
1107 device->modifiers &= ~modifier;
1110 g_message ("button %d %s, state %d",
1111 event->button.button,
1112 state ? "press" : "release", event->button.state));
1114 _gdk_wayland_display_deliver_event (device->display, event);
1118 pointer_handle_axis (void *data,
1119 struct wl_pointer *pointer,
1124 GdkWaylandDevice *device = data;
1125 GdkWaylandDisplay *display = GDK_WAYLAND_DISPLAY (device->display);
1127 gdouble delta_x, delta_y;
1130 case WL_POINTER_AXIS_VERTICAL_SCROLL:
1132 delta_y = -wl_fixed_to_double (value);
1134 case WL_POINTER_AXIS_HORIZONTAL_SCROLL:
1135 delta_x = -wl_fixed_to_double (value);
1138 g_return_if_reached ();
1141 device->time = time;
1142 event = gdk_event_new (GDK_SCROLL);
1143 event->scroll.window = g_object_ref (device->pointer_focus);
1144 gdk_event_set_device (event, device->pointer);
1145 event->scroll.time = time;
1146 event->scroll.x = (gdouble) device->surface_x;
1147 event->scroll.y = (gdouble) device->surface_y;
1148 event->scroll.direction = GDK_SCROLL_SMOOTH;
1149 event->scroll.delta_x = delta_x;
1150 event->scroll.delta_y = delta_y;
1151 event->scroll.state = device->modifiers;
1152 gdk_event_set_screen (event, display->screen);
1155 g_message ("scroll %f %f",
1156 event->scroll.delta_x, event->scroll.delta_y));
1158 _gdk_wayland_display_deliver_event (device->display, event);
1162 keyboard_handle_keymap (void *data,
1163 struct wl_keyboard *keyboard,
1168 GdkWaylandDevice *device = data;
1170 g_object_unref (device->keymap);
1172 device->keymap = _gdk_wayland_keymap_new_from_fd (format, fd, size);
1176 keyboard_handle_enter (void *data,
1177 struct wl_keyboard *keyboard,
1179 struct wl_surface *surface,
1180 struct wl_array *keys)
1182 GdkWaylandDevice *device = data;
1184 GdkWaylandDisplay *wayland_display =
1185 GDK_WAYLAND_DISPLAY (device->display);
1187 _gdk_wayland_display_update_serial (wayland_display, serial);
1189 device->keyboard_focus = wl_surface_get_user_data(surface);
1190 g_object_ref(device->keyboard_focus);
1192 event = gdk_event_new (GDK_FOCUS_CHANGE);
1193 event->focus_change.window = g_object_ref (device->keyboard_focus);
1194 event->focus_change.send_event = FALSE;
1195 event->focus_change.in = TRUE;
1196 gdk_event_set_device (event, device->keyboard);
1199 g_message ("focus int, device %p surface %p",
1200 device, device->keyboard_focus));
1202 _gdk_wayland_display_deliver_event (device->display, event);
1204 _gdk_wayland_window_add_focus (device->keyboard_focus);
1208 keyboard_handle_leave (void *data,
1209 struct wl_keyboard *keyboard,
1211 struct wl_surface *surface)
1213 GdkWaylandDevice *device = data;
1215 GdkWaylandDisplay *wayland_display =
1216 GDK_WAYLAND_DISPLAY (device->display);
1218 _gdk_wayland_display_update_serial (wayland_display, serial);
1220 _gdk_wayland_window_remove_focus (device->keyboard_focus);
1221 event = gdk_event_new (GDK_FOCUS_CHANGE);
1222 event->focus_change.window = g_object_ref (device->keyboard_focus);
1223 event->focus_change.send_event = FALSE;
1224 event->focus_change.in = FALSE;
1225 gdk_event_set_device (event, device->keyboard);
1227 g_object_unref(device->keyboard_focus);
1228 device->keyboard_focus = NULL;
1231 g_message ("focus out, device %p surface %p",
1232 device, device->keyboard_focus));
1234 _gdk_wayland_display_deliver_event (device->display, event);
1238 keyboard_repeat (gpointer data);
1240 static GdkModifierType
1241 get_modifier (struct xkb_state *state)
1243 GdkModifierType modifiers = 0;
1244 modifiers |= (xkb_state_mod_name_is_active (state, XKB_MOD_NAME_SHIFT, XKB_STATE_EFFECTIVE) > 0)?GDK_SHIFT_MASK:0;
1245 modifiers |= (xkb_state_mod_name_is_active (state, XKB_MOD_NAME_CAPS, XKB_STATE_EFFECTIVE) > 0)?GDK_LOCK_MASK:0;
1246 modifiers |= (xkb_state_mod_name_is_active (state, XKB_MOD_NAME_CTRL, XKB_STATE_EFFECTIVE) > 0)?GDK_CONTROL_MASK:0;
1247 modifiers |= (xkb_state_mod_name_is_active (state, XKB_MOD_NAME_ALT, XKB_STATE_EFFECTIVE) > 0)?GDK_MOD1_MASK:0;
1248 modifiers |= (xkb_state_mod_name_is_active (state, "Mod2", XKB_STATE_EFFECTIVE) > 0)?GDK_MOD2_MASK:0;
1249 modifiers |= (xkb_state_mod_name_is_active (state, "Mod3", XKB_STATE_EFFECTIVE) > 0)?GDK_MOD3_MASK:0;
1250 modifiers |= (xkb_state_mod_name_is_active (state, XKB_MOD_NAME_LOGO, XKB_STATE_EFFECTIVE) > 0)?GDK_MOD4_MASK:0;
1251 modifiers |= (xkb_state_mod_name_is_active (state, "Mod5", XKB_STATE_EFFECTIVE) > 0)?GDK_MOD5_MASK:0;
1257 translate_keyboard_string (GdkEventKey *event)
1262 /* Fill in event->string crudely, since various programs
1265 event->string = NULL;
1267 if (event->keyval != GDK_KEY_VoidSymbol)
1268 c = gdk_keyval_to_unicode (event->keyval);
1272 gsize bytes_written;
1275 /* Apply the control key - Taken from Xlib
1277 if (event->state & GDK_CONTROL_MASK)
1279 if ((c >= '@' && c < '\177') || c == ' ') c &= 0x1F;
1282 event->string = g_memdup ("\0\0", 2);
1287 else if (c >= '3' && c <= '7') c -= ('3' - '\033');
1288 else if (c == '8') c = '\177';
1289 else if (c == '/') c = '_' & 0x1F;
1292 len = g_unichar_to_utf8 (c, buf);
1295 event->string = g_locale_from_utf8 (buf, len,
1296 NULL, &bytes_written,
1299 event->length = bytes_written;
1301 else if (event->keyval == GDK_KEY_Escape)
1304 event->string = g_strdup ("\033");
1306 else if (event->keyval == GDK_KEY_Return ||
1307 event->keyval == GDK_KEY_KP_Enter)
1310 event->string = g_strdup ("\r");
1316 event->string = g_strdup ("");
1321 deliver_key_event(GdkWaylandDevice *device,
1322 uint32_t time, uint32_t key, uint32_t state)
1325 struct xkb_state *xkb_state;
1329 const xkb_keysym_t *syms;
1331 keymap = device->keymap;
1332 xkb_state = _gdk_wayland_keymap_get_xkb_state (keymap);
1334 num_syms = xkb_key_get_syms (xkb_state, key, &syms);
1335 sym = XKB_KEY_NoSymbol;
1339 device->time = time;
1340 device->modifiers = get_modifier (xkb_state);
1342 event = gdk_event_new (state ? GDK_KEY_PRESS : GDK_KEY_RELEASE);
1343 event->key.window = device->keyboard_focus?g_object_ref (device->keyboard_focus):NULL;
1344 gdk_event_set_device (event, device->keyboard);
1345 event->button.time = time;
1346 event->key.state = device->modifiers;
1347 event->key.group = 0;
1348 event->key.hardware_keycode = sym;
1349 event->key.keyval = sym;
1351 event->key.is_modifier = device->modifiers > 0;
1353 translate_keyboard_string (&event->key);
1355 _gdk_wayland_display_deliver_event (device->display, event);
1358 g_message ("keyboard event, code %d, sym %d, "
1359 "string %s, mods 0x%x",
1360 event->key.hardware_keycode, event->key.keyval,
1361 event->key.string, event->key.state));
1363 device->repeat_count++;
1364 device->repeat_key = key;
1368 if (device->repeat_timer)
1370 g_source_remove (device->repeat_timer);
1371 device->repeat_timer = 0;
1375 else if (device->modifiers)
1379 else switch (device->repeat_count)
1382 if (device->repeat_timer)
1384 g_source_remove (device->repeat_timer);
1385 device->repeat_timer = 0;
1388 device->repeat_timer =
1389 gdk_threads_add_timeout (400, keyboard_repeat, device);
1392 device->repeat_timer =
1393 gdk_threads_add_timeout (80, keyboard_repeat, device);
1401 keyboard_repeat (gpointer data)
1403 GdkWaylandDevice *device = data;
1405 return deliver_key_event (device, device->time, device->repeat_key, 1);
1409 keyboard_handle_key (void *data,
1410 struct wl_keyboard *keyboard,
1416 GdkWaylandDevice *device = data;
1417 GdkWaylandDisplay *wayland_display =
1418 GDK_WAYLAND_DISPLAY (device->display);
1420 device->repeat_count = 0;
1421 _gdk_wayland_display_update_serial (wayland_display, serial);
1422 deliver_key_event (data, time, key + 8, state_w);
1426 keyboard_handle_modifiers (void *data,
1427 struct wl_keyboard *keyboard,
1429 uint32_t mods_depressed,
1430 uint32_t mods_latched,
1431 uint32_t mods_locked,
1434 GdkWaylandDevice *device = data;
1436 struct xkb_state *xkb_state;
1438 keymap = device->keymap;
1439 xkb_state = _gdk_wayland_keymap_get_xkb_state (keymap);
1440 device->modifiers = mods_depressed | mods_latched | mods_locked;
1442 xkb_state_update_mask (xkb_state, mods_depressed, mods_latched, mods_locked, group, 0, 0);
1445 static const struct wl_pointer_listener pointer_listener = {
1446 pointer_handle_enter,
1447 pointer_handle_leave,
1448 pointer_handle_motion,
1449 pointer_handle_button,
1450 pointer_handle_axis,
1453 static const struct wl_keyboard_listener keyboard_listener = {
1454 keyboard_handle_keymap,
1455 keyboard_handle_enter,
1456 keyboard_handle_leave,
1457 keyboard_handle_key,
1458 keyboard_handle_modifiers,
1462 seat_handle_capabilities(void *data, struct wl_seat *seat,
1463 enum wl_seat_capability caps)
1465 GdkWaylandDevice *device = data;
1466 GdkDeviceManagerCore *device_manager_core =
1467 GDK_DEVICE_MANAGER_CORE(device->device_manager);
1469 if ((caps & WL_SEAT_CAPABILITY_POINTER) && !device->wl_pointer)
1471 device->wl_pointer = wl_seat_get_pointer(seat);
1472 wl_pointer_set_user_data(device->wl_pointer, device);
1473 wl_pointer_add_listener(device->wl_pointer, &pointer_listener,
1476 device->pointer = g_object_new (GDK_TYPE_DEVICE_CORE,
1477 "name", "Core Pointer",
1478 "type", GDK_DEVICE_TYPE_MASTER,
1479 "input-source", GDK_SOURCE_MOUSE,
1480 "input-mode", GDK_MODE_SCREEN,
1482 "display", device->display,
1483 "device-manager", device->device_manager,
1485 GDK_DEVICE_CORE (device->pointer)->device = device;
1487 device_manager_core->devices =
1488 g_list_prepend (device_manager_core->devices, device->pointer);
1490 else if (!(caps & WL_SEAT_CAPABILITY_POINTER) && device->wl_pointer)
1492 wl_pointer_destroy(device->wl_pointer);
1493 device->wl_pointer = NULL;
1495 device_manager_core->devices =
1496 g_list_remove (device_manager_core->devices, device->pointer);
1498 g_object_unref (device->pointer);
1499 device->pointer = NULL;
1502 if ((caps & WL_SEAT_CAPABILITY_KEYBOARD) && !device->wl_keyboard)
1504 device->wl_keyboard = wl_seat_get_keyboard(seat);
1505 wl_keyboard_set_user_data(device->wl_keyboard, device);
1506 wl_keyboard_add_listener(device->wl_keyboard, &keyboard_listener,
1509 device->keyboard = g_object_new (GDK_TYPE_DEVICE_CORE,
1510 "name", "Core Keyboard",
1511 "type", GDK_DEVICE_TYPE_MASTER,
1512 "input-source", GDK_SOURCE_KEYBOARD,
1513 "input-mode", GDK_MODE_SCREEN,
1514 "has-cursor", FALSE,
1515 "display", device->display,
1516 "device-manager", device->device_manager,
1518 GDK_DEVICE_CORE (device->keyboard)->device = device;
1520 device_manager_core->devices =
1521 g_list_prepend (device_manager_core->devices, device->keyboard);
1523 else if (!(caps & WL_SEAT_CAPABILITY_KEYBOARD) && device->wl_keyboard)
1525 wl_keyboard_destroy(device->wl_keyboard);
1526 device->wl_keyboard = NULL;
1528 device_manager_core->devices =
1529 g_list_remove (device_manager_core->devices, device->keyboard);
1531 g_object_unref (device->keyboard);
1532 device->keyboard = NULL;
1535 if (device->keyboard && device->pointer)
1537 _gdk_device_set_associated_device (device->pointer, device->keyboard);
1538 _gdk_device_set_associated_device (device->keyboard, device->pointer);
1542 static const struct wl_seat_listener seat_listener = {
1543 seat_handle_capabilities,
1547 _gdk_wayland_device_manager_add_device (GdkDeviceManager *device_manager,
1548 struct wl_seat *wl_seat)
1550 GdkDisplay *display;
1551 GdkWaylandDisplay *display_wayland;
1552 GdkWaylandDevice *device;
1554 display = gdk_device_manager_get_display (device_manager);
1555 display_wayland = GDK_WAYLAND_DISPLAY (display);
1557 device = g_new0 (GdkWaylandDevice, 1);
1558 device->keymap = _gdk_wayland_keymap_new ();
1559 device->display = display;
1560 device->device_manager = device_manager;
1562 device->wl_seat = wl_seat;
1564 wl_seat_add_listener (device->wl_seat, &seat_listener, device);
1565 wl_seat_set_user_data (device->wl_seat, device);
1567 device->data_device =
1568 wl_data_device_manager_get_data_device (display_wayland->data_device_manager,
1570 wl_data_device_add_listener (device->data_device,
1571 &data_device_listener, device);
1573 device->pointer_surface =
1574 wl_compositor_create_surface (display_wayland->compositor);
1578 free_device (gpointer data)
1580 g_object_unref (data);
1584 gdk_device_manager_core_finalize (GObject *object)
1586 GdkDeviceManagerCore *device_manager_core;
1588 device_manager_core = GDK_DEVICE_MANAGER_CORE (object);
1590 g_list_free_full (device_manager_core->devices, free_device);
1592 G_OBJECT_CLASS (gdk_device_manager_core_parent_class)->finalize (object);
1596 gdk_device_manager_core_list_devices (GdkDeviceManager *device_manager,
1599 GdkDeviceManagerCore *device_manager_core;
1600 GList *devices = NULL;
1602 if (type == GDK_DEVICE_TYPE_MASTER)
1604 device_manager_core = (GdkDeviceManagerCore *) device_manager;
1605 devices = g_list_copy(device_manager_core->devices);
1612 gdk_device_manager_core_get_client_pointer (GdkDeviceManager *device_manager)
1614 GdkDeviceManagerCore *device_manager_core;
1617 device_manager_core = (GdkDeviceManagerCore *) device_manager;
1619 /* Find the first pointer device */
1620 for (l = device_manager_core->devices; l != NULL; l = l->next)
1622 GdkDevice *device = l->data;
1624 if (gdk_device_get_source (device) == GDK_SOURCE_MOUSE)
1632 gdk_device_manager_core_class_init (GdkDeviceManagerCoreClass *klass)
1634 GdkDeviceManagerClass *device_manager_class = GDK_DEVICE_MANAGER_CLASS (klass);
1635 GObjectClass *object_class = G_OBJECT_CLASS (klass);
1637 object_class->finalize = gdk_device_manager_core_finalize;
1638 device_manager_class->list_devices = gdk_device_manager_core_list_devices;
1639 device_manager_class->get_client_pointer = gdk_device_manager_core_get_client_pointer;
1643 gdk_device_manager_core_init (GdkDeviceManagerCore *device_manager)
1648 _gdk_wayland_device_manager_new (GdkDisplay *display)
1650 return g_object_new (GDK_TYPE_DEVICE_MANAGER_CORE,
1656 gdk_wayland_device_get_selection_type_atoms (GdkDevice *gdk_device,
1657 GdkAtom **atoms_out)
1661 GdkWaylandDevice *device;
1663 g_return_val_if_fail (GDK_IS_DEVICE_CORE (gdk_device), 0);
1664 g_return_val_if_fail (atoms_out != NULL, 0);
1666 device = GDK_DEVICE_CORE (gdk_device)->device;
1668 if (!device->selection_offer || device->selection_offer->types->len == 0)
1674 atoms = g_new0 (GdkAtom, device->selection_offer->types->len);
1676 /* Convert list of targets to atoms */
1677 for (i = 0; i < device->selection_offer->types->len; i++)
1679 atoms[i] = gdk_atom_intern (device->selection_offer->types->pdata[i],
1682 g_message (G_STRLOC ": Adding atom for %s",
1683 (char *)device->selection_offer->types->pdata[i]));
1687 return device->selection_offer->types->len;
1692 GdkWaylandDevice *device;
1694 GIOChannel *channel;
1695 GdkDeviceWaylandRequestContentCallback cb;
1697 } RequestContentClosure;
1700 _request_content_io_func (GIOChannel *channel,
1701 GIOCondition condition,
1704 RequestContentClosure *closure = (RequestContentClosure *)userdata;
1707 GError *error = NULL;
1709 /* FIXME: We probably want to do something better than this to avoid
1710 * blocking on the transfer of large pieces of data: call the callback
1711 * multiple times I should think.
1713 if (g_io_channel_read_to_end (channel,
1716 &error) != G_IO_STATUS_NORMAL)
1718 g_warning (G_STRLOC ": Error reading content from pipe: %s", error->message);
1719 g_clear_error (&error);
1722 /* Since we use _read_to_end we've got a guaranteed EOF and thus can go
1723 * ahead and close the fd
1725 g_io_channel_shutdown (channel, TRUE, NULL);
1727 closure->cb (closure->device->pointer, data, len, closure->userdata);
1730 data_offer_unref (closure->offer);
1731 g_io_channel_unref (channel);
1738 gdk_wayland_device_request_selection_content (GdkDevice *gdk_device,
1739 const gchar *requested_mime_type,
1740 GdkDeviceWaylandRequestContentCallback cb,
1744 RequestContentClosure *closure;
1745 GdkWaylandDevice *device;
1746 GError *error = NULL;
1748 g_return_val_if_fail (GDK_IS_DEVICE_CORE (gdk_device), FALSE);
1749 g_return_val_if_fail (requested_mime_type != NULL, FALSE);
1750 g_return_val_if_fail (cb != NULL, FALSE);
1752 device = GDK_DEVICE_CORE (gdk_device)->device;
1754 if (!device->selection_offer)
1757 /* TODO: Check mimetypes */
1759 closure = g_new0 (RequestContentClosure, 1);
1761 device->selection_offer->ref_count++;
1763 pipe2 (pipe_fd, O_CLOEXEC);
1764 wl_data_offer_receive (device->selection_offer->offer,
1765 requested_mime_type,
1769 closure->device = device;
1770 closure->offer = device->selection_offer;
1771 closure->channel = g_io_channel_unix_new (pipe_fd[0]);
1773 closure->userdata = userdata;
1775 if (!g_io_channel_set_encoding (closure->channel, NULL, &error))
1777 g_warning (G_STRLOC ": Error setting encoding on channel: %s",
1779 g_clear_error (&error);
1783 g_io_add_watch (closure->channel,
1785 _request_content_io_func,
1791 data_offer_unref (closure->offer);
1792 g_io_channel_unref (closure->channel);
1799 struct _GdkWaylandSelectionOffer {
1800 GdkDeviceWaylandOfferContentCallback cb;
1802 struct wl_data_source *source;
1803 GdkWaylandDevice *device;
1807 data_source_target (void *data,
1808 struct wl_data_source *source,
1809 const char *mime_type)
1811 g_debug (G_STRLOC ": %s source = %p, mime_type = %s",
1812 G_STRFUNC, source, mime_type);
1816 data_source_send (void *data,
1817 struct wl_data_source *source,
1818 const char *mime_type,
1821 GdkWaylandSelectionOffer *offer = (GdkWaylandSelectionOffer *)data;;
1823 gssize len, bytes_written = 0;
1825 g_debug (G_STRLOC ": %s source = %p, mime_type = %s fd = %d",
1826 G_STRFUNC, source, mime_type, fd);
1828 buf = offer->cb (offer->device->pointer, mime_type, &len, offer->userdata);
1832 bytes_written += write (fd, buf + bytes_written, len);
1833 if (bytes_written == -1)
1835 len -= bytes_written;
1844 g_warning (G_STRLOC ": Error writing data to client: %s",
1845 g_strerror (errno));
1852 data_source_cancelled (void *data,
1853 struct wl_data_source *source)
1855 g_debug (G_STRLOC ": %s source = %p",
1859 static const struct wl_data_source_listener data_source_listener = {
1862 data_source_cancelled
1870 gettimeofday(&tv, NULL);
1872 return tv.tv_sec * 1000 + tv.tv_usec / 1000;
1876 gdk_wayland_device_offer_selection_content (GdkDevice *gdk_device,
1877 const gchar **mime_types,
1879 GdkDeviceWaylandOfferContentCallback cb,
1882 GdkDisplay *display;
1883 GdkWaylandDisplay *display_wayland;
1884 GdkWaylandSelectionOffer *offer;
1885 GdkWaylandDevice *device;
1888 g_return_val_if_fail (GDK_IS_DEVICE_CORE (gdk_device), 0);
1889 device = GDK_DEVICE_CORE (gdk_device)->device;
1891 display = device->display;
1892 display_wayland = GDK_WAYLAND_DISPLAY (display);
1894 offer = g_new0 (GdkWaylandSelectionOffer, 1);
1896 offer->userdata = userdata;
1898 wl_data_device_manager_create_data_source (display_wayland->data_device_manager);
1899 offer->device = device;
1901 for (i = 0; i < nr_mime_types; i++)
1903 wl_data_source_offer (offer->source,
1907 wl_data_source_add_listener (offer->source,
1908 &data_source_listener,
1911 wl_data_device_set_selection (device->data_device,
1915 device->selection_offer_out = offer;
1921 gdk_wayland_device_clear_selection_content (GdkDevice *gdk_device)
1923 GdkWaylandDevice *device;
1925 g_return_val_if_fail (GDK_IS_DEVICE_CORE (gdk_device), 0);
1926 device = GDK_DEVICE_CORE (gdk_device)->device;
1928 if (!device->selection_offer_out)
1931 wl_data_device_set_selection (device->data_device,
1935 wl_data_source_destroy (device->selection_offer_out->source);
1936 g_free (device->selection_offer_out);
1937 device->selection_offer_out = NULL;