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;
68 GdkModifierType modifiers;
69 GdkWindow *pointer_focus;
70 GdkWindow *keyboard_focus;
71 struct wl_data_device *data_device;
72 double surface_x, surface_y;
74 GdkWindow *pointer_grab_window;
75 uint32_t pointer_grab_time;
80 DataOffer *drag_offer;
81 DataOffer *selection_offer;
83 GdkWaylandSelectionOffer *selection_offer_out;
85 struct wl_surface *pointer_surface;
90 GdkDevice parent_instance;
91 GdkWaylandDevice *device;
94 struct _GdkDeviceCoreClass
96 GdkDeviceClass parent_class;
99 G_DEFINE_TYPE (GdkDeviceCore, gdk_device_core, GDK_TYPE_DEVICE)
101 #define GDK_TYPE_DEVICE_MANAGER_CORE (gdk_device_manager_core_get_type ())
102 #define GDK_DEVICE_MANAGER_CORE(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), GDK_TYPE_DEVICE_MANAGER_CORE, GdkDeviceManagerCore))
103 #define GDK_DEVICE_MANAGER_CORE_CLASS(c) (G_TYPE_CHECK_CLASS_CAST ((c), GDK_TYPE_DEVICE_MANAGER_CORE, GdkDeviceManagerCoreClass))
104 #define GDK_IS_DEVICE_MANAGER_CORE(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), GDK_TYPE_DEVICE_MANAGER_CORE))
105 #define GDK_IS_DEVICE_MANAGER_CORE_CLASS(c) (G_TYPE_CHECK_CLASS_TYPE ((c), GDK_TYPE_DEVICE_MANAGER_CORE))
106 #define GDK_DEVICE_MANAGER_CORE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), GDK_TYPE_DEVICE_MANAGER_CORE, GdkDeviceManagerCoreClass))
108 typedef struct _GdkDeviceManagerCore GdkDeviceManagerCore;
109 typedef struct _GdkDeviceManagerCoreClass GdkDeviceManagerCoreClass;
111 struct _GdkDeviceManagerCore
113 GdkDeviceManager parent_object;
114 GdkDevice *core_pointer;
115 GdkDevice *core_keyboard;
119 struct _GdkDeviceManagerCoreClass
121 GdkDeviceManagerClass parent_class;
124 G_DEFINE_TYPE (GdkDeviceManagerCore,
125 gdk_device_manager_core, GDK_TYPE_DEVICE_MANAGER)
128 gdk_device_core_get_history (GdkDevice *device,
132 GdkTimeCoord ***events,
139 gdk_device_core_get_state (GdkDevice *device,
142 GdkModifierType *mask)
146 gdk_window_get_device_position (window, device, &x_int, &y_int, mask);
156 gdk_device_core_set_window_cursor (GdkDevice *device,
160 GdkWaylandDevice *wd = GDK_DEVICE_CORE(device)->device;
161 GdkWaylandDisplay *wayland_display =
162 GDK_WAYLAND_DISPLAY (gdk_window_get_display (window));
163 struct wl_buffer *buffer;
167 g_object_ref (cursor);
169 /* Setting the cursor to NULL means that we should use the default cursor */
172 /* FIXME: Is this the best sensible default ? */
173 cursor = _gdk_wayland_display_get_cursor_for_type (device->display,
177 buffer = _gdk_wayland_cursor_get_buffer (cursor, &x, &y, &w, &h);
178 wl_pointer_set_cursor (wd->wl_pointer,
179 _gdk_wayland_display_get_serial (wayland_display),
182 wl_surface_attach (wd->pointer_surface, buffer, 0, 0);
183 wl_surface_damage (wd->pointer_surface, 0, 0, w, h);
185 g_object_unref (cursor);
189 gdk_device_core_warp (GdkDevice *device,
197 gdk_device_core_query_state (GdkDevice *device,
199 GdkWindow **root_window,
200 GdkWindow **child_window,
205 GdkModifierType *mask)
207 GdkWaylandDevice *wd;
208 GdkScreen *default_screen;
210 wd = GDK_DEVICE_CORE(device)->device;
211 default_screen = gdk_display_get_default_screen (wd->display);
214 *root_window = gdk_screen_get_root_window (default_screen);
216 *child_window = wd->pointer_focus;
217 /* Do something clever for relative here */
225 *win_x = wd->surface_x;
227 *win_y = wd->surface_y;
229 *mask = wd->modifiers;
233 gdk_device_core_grab (GdkDevice *device,
235 gboolean owner_events,
236 GdkEventMask event_mask,
237 GdkWindow *confine_to,
241 GdkWaylandDevice *wayland_device = GDK_DEVICE_CORE (device)->device;
243 if (gdk_device_get_source (device) == GDK_SOURCE_KEYBOARD)
245 /* Device is a keyboard */
246 return GDK_GRAB_SUCCESS;
250 /* Device is a pointer */
252 if (wayland_device->pointer_grab_window != NULL &&
253 time_ != 0 && wayland_device->pointer_grab_time > time_)
255 return GDK_GRAB_ALREADY_GRABBED;
259 time_ = wayland_device->time;
261 wayland_device->pointer_grab_window = window;
262 wayland_device->pointer_grab_time = time_;
264 /* FIXME: This probably breaks if you end up with multiple grabs on the
265 * same window - but we need to know the input device for when we are
266 * asked to map a popup window so that the grab can be managed by the
269 _gdk_wayland_window_set_device_grabbed (window,
270 wayland_device->wl_seat,
274 return GDK_GRAB_SUCCESS;
278 gdk_device_core_ungrab (GdkDevice *device,
281 GdkWaylandDevice *wayland_device = GDK_DEVICE_CORE (device)->device;
283 GdkDeviceGrabInfo *grab;
285 display = gdk_device_get_display (device);
287 if (gdk_device_get_source (device) == GDK_SOURCE_KEYBOARD)
289 /* Device is a keyboard */
293 /* Device is a pointer */
294 grab = _gdk_display_get_last_device_grab (display, device);
297 grab->serial_end = grab->serial_start;
299 if (wayland_device->pointer_grab_window)
300 _gdk_wayland_window_set_device_grabbed (wayland_device->pointer_grab_window,
307 gdk_device_core_window_at_position (GdkDevice *device,
310 GdkModifierType *mask,
311 gboolean get_toplevel)
313 GdkWaylandDevice *wd;
315 wd = GDK_DEVICE_CORE(device)->device;
317 *win_x = wd->surface_x;
319 *win_y = wd->surface_y;
321 *mask = wd->modifiers;
323 return wd->pointer_focus;
327 gdk_device_core_select_window_events (GdkDevice *device,
329 GdkEventMask event_mask)
334 gdk_device_core_class_init (GdkDeviceCoreClass *klass)
336 GdkDeviceClass *device_class = GDK_DEVICE_CLASS (klass);
338 device_class->get_history = gdk_device_core_get_history;
339 device_class->get_state = gdk_device_core_get_state;
340 device_class->set_window_cursor = gdk_device_core_set_window_cursor;
341 device_class->warp = gdk_device_core_warp;
342 device_class->query_state = gdk_device_core_query_state;
343 device_class->grab = gdk_device_core_grab;
344 device_class->ungrab = gdk_device_core_ungrab;
345 device_class->window_at_position = gdk_device_core_window_at_position;
346 device_class->select_window_events = gdk_device_core_select_window_events;
350 gdk_device_core_init (GdkDeviceCore *device_core)
354 device = GDK_DEVICE (device_core);
356 _gdk_device_add_axis (device, GDK_NONE, GDK_AXIS_X, 0, 0, 1);
357 _gdk_device_add_axis (device, GDK_NONE, GDK_AXIS_Y, 0, 0, 1);
361 _gdk_wayland_device_get_wl_seat (GdkDevice *device)
363 return GDK_DEVICE_CORE (device)->device->wl_seat;
367 _gdk_wayland_device_get_wl_pointer (GdkDevice *device)
369 return GDK_DEVICE_CORE (device)->device->wl_pointer;
374 _gdk_wayland_device_get_wl_keyboard (GdkDevice *device)
376 return GDK_DEVICE_CORE (device)->device->wl_keyboard;
381 input_handle_motion(void *data, struct wl_input_device *input_device,
383 int32_t x, int32_t y, int32_t sx, int32_t sy)
385 GdkWaylandDevice *device = data;
386 GdkWaylandDisplay *display = GDK_WAYLAND_DISPLAY (device->display);
389 event = gdk_event_new (GDK_NOTHING);
394 device->surface_x = sx;
395 device->surface_y = sy;
397 event->motion.type = GDK_MOTION_NOTIFY;
398 event->motion.window = g_object_ref (device->pointer_focus);
399 gdk_event_set_device (event, device->pointer);
400 event->motion.time = time;
401 event->motion.x = (gdouble) sx;
402 event->motion.y = (gdouble) sy;
403 event->motion.x_root = (gdouble) x;
404 event->motion.y_root = (gdouble) y;
405 event->motion.axes = NULL;
406 event->motion.state = device->modifiers;
407 event->motion.is_hint = 0;
408 gdk_event_set_screen (event, display->screen);
411 g_message ("motion %d %d, state %d",
412 sx, sy, event->button.state));
414 _gdk_wayland_display_deliver_event (device->display, event);
418 input_handle_button(void *data, struct wl_input_device *input_device,
419 uint32_t time, uint32_t button, uint32_t state)
421 GdkWaylandDevice *device = data;
422 GdkWaylandDisplay *display = GDK_WAYLAND_DISPLAY (device->display);
435 gdk_button = button - 271;
440 event = gdk_event_new (state ? GDK_BUTTON_PRESS : GDK_BUTTON_RELEASE);
441 event->button.window = g_object_ref (device->pointer_focus);
442 gdk_event_set_device (event, device->pointer);
443 event->button.time = time;
444 event->button.x = (gdouble) device->surface_x;
445 event->button.y = (gdouble) device->surface_y;
446 event->button.x_root = (gdouble) device->x;
447 event->button.y_root = (gdouble) device->y;
448 event->button.axes = NULL;
449 event->button.state = device->modifiers;
450 event->button.button = gdk_button;
451 gdk_event_set_screen (event, display->screen);
453 modifier = 1 << (8 + gdk_button - 1);
455 device->modifiers |= modifier;
457 device->modifiers &= ~modifier;
460 g_message ("button %d %s, state %d",
461 event->button.button,
462 state ? "press" : "release", event->button.state));
464 _gdk_wayland_display_deliver_event (device->display, event);
468 translate_keyboard_string (GdkEventKey *event)
473 /* Fill in event->string crudely, since various programs
476 event->string = NULL;
478 if (event->keyval != GDK_KEY_VoidSymbol)
479 c = gdk_keyval_to_unicode (event->keyval);
486 /* Apply the control key - Taken from Xlib
488 if (event->state & GDK_CONTROL_MASK)
490 if ((c >= '@' && c < '\177') || c == ' ') c &= 0x1F;
493 event->string = g_memdup ("\0\0", 2);
498 else if (c >= '3' && c <= '7') c -= ('3' - '\033');
499 else if (c == '8') c = '\177';
500 else if (c == '/') c = '_' & 0x1F;
503 len = g_unichar_to_utf8 (c, buf);
506 event->string = g_locale_from_utf8 (buf, len,
507 NULL, &bytes_written,
510 event->length = bytes_written;
512 else if (event->keyval == GDK_KEY_Escape)
515 event->string = g_strdup ("\033");
517 else if (event->keyval == GDK_KEY_Return ||
518 event->keyval == GDK_KEY_KP_Enter)
521 event->string = g_strdup ("\r");
527 event->string = g_strdup ("");
532 keyboard_repeat (gpointer data);
535 deliver_key_event(GdkWaylandDevice *device,
536 uint32_t time, uint32_t key, uint32_t state)
539 uint32_t code, modifier, level;
540 struct xkb_desc *xkb;
543 keymap = gdk_keymap_get_for_display (device->display);
544 xkb = _gdk_wayland_keymap_get_xkb_desc (keymap);
547 event = gdk_event_new (state ? GDK_KEY_PRESS : GDK_KEY_RELEASE);
548 event->key.window = g_object_ref (device->keyboard_focus);
549 gdk_event_set_device (event, device->keyboard);
550 event->button.time = time;
551 event->key.state = device->modifiers;
552 event->key.group = 0;
553 code = key + xkb->min_key_code;
554 event->key.hardware_keycode = code;
557 if (device->modifiers & XKB_COMMON_SHIFT_MASK &&
558 XkbKeyGroupWidth(xkb, code, 0) > 1)
561 event->key.keyval = XkbKeySymEntry(xkb, code, level, 0);
563 modifier = xkb->map->modmap[code];
565 device->modifiers |= modifier;
567 device->modifiers &= ~modifier;
569 event->key.is_modifier = modifier > 0;
571 translate_keyboard_string (&event->key);
573 _gdk_wayland_display_deliver_event (device->display, event);
576 g_message ("keyboard event, code %d, sym %d, "
577 "string %s, mods 0x%x",
578 code, event->key.keyval,
579 event->key.string, event->key.state));
581 device->repeat_count++;
582 device->repeat_key = key;
586 if (device->repeat_timer)
588 g_source_remove (device->repeat_timer);
589 device->repeat_timer = 0;
597 else switch (device->repeat_count)
600 if (device->repeat_timer)
602 g_source_remove (device->repeat_timer);
603 device->repeat_timer = 0;
606 device->repeat_timer =
607 gdk_threads_add_timeout (400, keyboard_repeat, device);
610 device->repeat_timer =
611 gdk_threads_add_timeout (80, keyboard_repeat, device);
619 keyboard_repeat (gpointer data)
621 GdkWaylandDevice *device = data;
623 return deliver_key_event (device, device->time, device->repeat_key, 1);
627 input_handle_key(void *data, struct wl_input_device *input_device,
628 uint32_t time, uint32_t key, uint32_t state)
630 GdkWaylandDevice *device = data;
632 device->repeat_count = 0;
633 deliver_key_event (data, time, key, state);
637 input_handle_pointer_focus(void *data,
638 struct wl_input_device *input_device,
639 uint32_t time, struct wl_surface *surface,
640 int32_t x, int32_t y, int32_t sx, int32_t sy)
642 GdkWaylandDevice *device = data;
646 if (device->pointer_focus)
648 event = gdk_event_new (GDK_LEAVE_NOTIFY);
649 event->crossing.window = g_object_ref (device->pointer_focus);
650 gdk_event_set_device (event, device->pointer);
651 event->crossing.subwindow = NULL;
652 event->crossing.time = time;
653 event->crossing.x = (gdouble) device->surface_x;
654 event->crossing.y = (gdouble) device->surface_y;
655 event->crossing.x_root = (gdouble) device->x;
656 event->crossing.y_root = (gdouble) device->y;
658 event->crossing.mode = GDK_CROSSING_NORMAL;
659 event->crossing.detail = GDK_NOTIFY_ANCESTOR;
660 event->crossing.focus = TRUE;
661 event->crossing.state = 0;
663 _gdk_wayland_display_deliver_event (device->display, event);
666 g_message ("leave, device %p surface %p",
667 device, device->pointer_focus));
669 g_object_unref(device->pointer_focus);
670 device->pointer_focus = NULL;
675 device->pointer_focus = wl_surface_get_user_data(surface);
676 g_object_ref(device->pointer_focus);
678 event = gdk_event_new (GDK_ENTER_NOTIFY);
679 event->crossing.window = g_object_ref (device->pointer_focus);
680 gdk_event_set_device (event, device->pointer);
681 event->crossing.subwindow = NULL;
682 event->crossing.time = time;
683 event->crossing.x = (gdouble) sx;
684 event->crossing.y = (gdouble) sy;
685 event->crossing.x_root = (gdouble) x;
686 event->crossing.y_root = (gdouble) y;
688 event->crossing.mode = GDK_CROSSING_NORMAL;
689 event->crossing.detail = GDK_NOTIFY_ANCESTOR;
690 event->crossing.focus = TRUE;
691 event->crossing.state = 0;
693 device->surface_x = sx;
694 device->surface_y = sy;
698 _gdk_wayland_display_deliver_event (device->display, event);
701 g_message ("enter, device %p surface %p",
702 device, device->pointer_focus));
707 update_modifiers(GdkWaylandDevice *device, struct wl_array *keys)
711 struct xkb_desc *xkb;
713 keymap = gdk_keymap_get_for_display (device->display);
714 xkb = _gdk_wayland_keymap_get_xkb_desc (keymap);
716 end = keys->data + keys->size;
717 device->modifiers = 0;
718 for (k = keys->data; k < end; k++)
719 device->modifiers |= xkb->map->modmap[*k];
723 input_handle_keyboard_focus(void *data,
724 struct wl_input_device *input_device,
726 struct wl_surface *surface,
727 struct wl_array *keys)
729 GdkWaylandDevice *device = data;
733 if (device->keyboard_focus)
735 _gdk_wayland_window_remove_focus (device->keyboard_focus);
736 event = gdk_event_new (GDK_FOCUS_CHANGE);
737 event->focus_change.window = g_object_ref (device->keyboard_focus);
738 event->focus_change.send_event = FALSE;
739 event->focus_change.in = FALSE;
740 gdk_event_set_device (event, device->keyboard);
742 g_object_unref(device->keyboard_focus);
743 device->keyboard_focus = NULL;
746 g_message ("focus out, device %p surface %p",
747 device, device->keyboard_focus));
749 _gdk_wayland_display_deliver_event (device->display, event);
754 device->keyboard_focus = wl_surface_get_user_data(surface);
755 g_object_ref(device->keyboard_focus);
757 event = gdk_event_new (GDK_FOCUS_CHANGE);
758 event->focus_change.window = g_object_ref (device->keyboard_focus);
759 event->focus_change.send_event = FALSE;
760 event->focus_change.in = TRUE;
761 gdk_event_set_device (event, device->keyboard);
763 update_modifiers (device, keys);
766 g_message ("focus int, device %p surface %p",
767 device, device->keyboard_focus));
769 _gdk_wayland_display_deliver_event (device->display, event);
771 _gdk_wayland_window_add_focus (device->keyboard_focus);
775 static const struct wl_input_device_listener input_device_listener = {
779 input_handle_pointer_focus,
780 input_handle_keyboard_focus,
785 struct wl_data_offer *offer;
791 data_offer_offer (void *data,
792 struct wl_data_offer *wl_data_offer,
795 DataOffer *offer = (DataOffer *)data;
796 g_debug (G_STRLOC ": %s wl_data_offer = %p type = %s",
797 G_STRFUNC, wl_data_offer, type);
799 g_ptr_array_add (offer->types, g_strdup (type));
803 data_offer_unref (DataOffer *offer)
807 if (offer->ref_count == 0)
809 g_ptr_array_free (offer->types, TRUE);
814 static const struct wl_data_offer_listener data_offer_listener = {
819 data_device_data_offer (void *data,
820 struct wl_data_device *data_device,
825 g_debug (G_STRLOC ": %s data_device = %p id = %lu",
826 G_STRFUNC, data_device, (long unsigned int)id);
828 /* This structure is reference counted to handle the case where you get a
829 * leave but are in the middle of transferring data
831 offer = g_new0 (DataOffer, 1);
832 offer->ref_count = 1;
833 offer->types = g_ptr_array_new_with_free_func (g_free);
834 offer->offer = (struct wl_data_offer *)
835 wl_proxy_create_for_id ((struct wl_proxy *) data_device,
837 &wl_data_offer_interface);
839 /* The DataOffer structure is then retrieved later since this sets the user
842 wl_data_offer_add_listener (offer->offer,
843 &data_offer_listener,
848 data_device_enter (void *data,
849 struct wl_data_device *data_device,
851 struct wl_surface *surface,
854 struct wl_data_offer *offer)
856 GdkWaylandDevice *device = (GdkWaylandDevice *)data;
858 g_debug (G_STRLOC ": %s data_device = %p time = %d, surface = %p, x = %d y = %d, offer = %p",
859 G_STRFUNC, data_device, time, surface, x, y, offer);
861 /* Retrieve the DataOffer associated with with the wl_data_offer - this
862 * association is made when the listener is attached.
864 g_assert (device->drag_offer == NULL);
865 device->drag_offer = wl_data_offer_get_user_data (offer);
869 data_device_leave (void *data,
870 struct wl_data_device *data_device)
872 GdkWaylandDevice *device = (GdkWaylandDevice *)data;
874 g_debug (G_STRLOC ": %s data_device = %p",
875 G_STRFUNC, data_device);
877 data_offer_unref (device->drag_offer);
878 device->drag_offer = NULL;
882 data_device_motion (void *data,
883 struct wl_data_device *data_device,
888 g_debug (G_STRLOC ": %s data_device = %p, time = %d, x = %d, y = %d",
889 G_STRFUNC, data_device, time, x, y);
893 data_device_drop (void *data,
894 struct wl_data_device *data_device)
896 g_debug (G_STRLOC ": %s data_device = %p",
897 G_STRFUNC, data_device);
901 data_device_selection (void *data,
902 struct wl_data_device *wl_data_device,
903 struct wl_data_offer *offer)
905 GdkWaylandDevice *device = (GdkWaylandDevice *)data;
907 g_debug (G_STRLOC ": %s wl_data_device = %p wl_data_offer = %p",
908 G_STRFUNC, wl_data_device, offer);
912 if (device->selection_offer)
914 data_offer_unref (device->selection_offer);
915 device->selection_offer = NULL;
921 if (device->selection_offer)
923 data_offer_unref (device->selection_offer);
924 device->selection_offer = NULL;
927 /* Retrieve the DataOffer associated with with the wl_data_offer - this
928 * association is made when the listener is attached.
930 g_assert (device->selection_offer == NULL);
931 device->selection_offer = wl_data_offer_get_user_data (offer);
934 static const struct wl_data_device_listener data_device_listener = {
935 data_device_data_offer,
940 data_device_selection
946 pointer_handle_enter (void *data,
947 struct wl_pointer *pointer,
949 struct wl_surface *surface,
953 GdkWaylandDevice *device = data;
955 GdkWaylandDisplay *wayland_display =
956 GDK_WAYLAND_DISPLAY (device->display);
958 _gdk_wayland_display_update_serial (wayland_display, serial);
960 device->pointer_focus = wl_surface_get_user_data(surface);
961 g_object_ref(device->pointer_focus);
963 event = gdk_event_new (GDK_ENTER_NOTIFY);
964 event->crossing.window = g_object_ref (device->pointer_focus);
965 gdk_event_set_device (event, device->pointer);
966 event->crossing.subwindow = NULL;
967 event->crossing.time = (guint32)(g_get_monotonic_time () / 1000);
968 event->crossing.x = wl_fixed_to_double (sx);
969 event->crossing.y = wl_fixed_to_double (sy);
971 event->crossing.mode = GDK_CROSSING_NORMAL;
972 event->crossing.detail = GDK_NOTIFY_ANCESTOR;
973 event->crossing.focus = TRUE;
974 event->crossing.state = 0;
976 device->surface_x = wl_fixed_to_double (sx);
977 device->surface_y = wl_fixed_to_double (sy);
979 _gdk_wayland_display_deliver_event (device->display, event);
982 g_message ("enter, device %p surface %p",
983 device, device->pointer_focus));
987 pointer_handle_leave (void *data,
988 struct wl_pointer *pointer,
990 struct wl_surface *surface)
992 GdkWaylandDevice *device = data;
994 GdkWaylandDisplay *wayland_display =
995 GDK_WAYLAND_DISPLAY (device->display);
997 _gdk_wayland_display_update_serial (wayland_display, serial);
999 event = gdk_event_new (GDK_LEAVE_NOTIFY);
1000 event->crossing.window = g_object_ref (device->pointer_focus);
1001 gdk_event_set_device (event, device->pointer);
1002 event->crossing.subwindow = NULL;
1003 event->crossing.time = (guint32)(g_get_monotonic_time () / 1000);
1004 event->crossing.x = device->surface_x;
1005 event->crossing.y = device->surface_y;
1007 event->crossing.mode = GDK_CROSSING_NORMAL;
1008 event->crossing.detail = GDK_NOTIFY_ANCESTOR;
1009 event->crossing.focus = TRUE;
1010 event->crossing.state = 0;
1012 _gdk_wayland_display_deliver_event (device->display, event);
1015 g_message ("leave, device %p surface %p",
1016 device, device->pointer_focus));
1018 g_object_unref(device->pointer_focus);
1019 device->pointer_focus = NULL;
1023 pointer_handle_motion (void *data,
1024 struct wl_pointer *pointer,
1029 GdkWaylandDevice *device = data;
1030 GdkWaylandDisplay *display = GDK_WAYLAND_DISPLAY (device->display);
1033 event = gdk_event_new (GDK_NOTHING);
1035 device->time = time;
1036 device->surface_x = wl_fixed_to_double (sx);
1037 device->surface_y = wl_fixed_to_double (sy);
1039 event->motion.type = GDK_MOTION_NOTIFY;
1040 event->motion.window = g_object_ref (device->pointer_focus);
1041 gdk_event_set_device (event, device->pointer);
1042 event->motion.time = time;
1043 event->motion.x = wl_fixed_to_double (sx);
1044 event->motion.y = wl_fixed_to_double (sy);
1045 event->motion.axes = NULL;
1046 event->motion.state = device->modifiers;
1047 event->motion.is_hint = 0;
1048 gdk_event_set_screen (event, display->screen);
1051 g_message ("motion %d %d, state %d",
1052 sx, sy, event->button.state));
1054 _gdk_wayland_display_deliver_event (device->display, event);
1058 pointer_handle_button (void *data,
1059 struct wl_pointer *pointer,
1065 GdkWaylandDevice *device = data;
1066 GdkWaylandDisplay *display = GDK_WAYLAND_DISPLAY (device->display);
1070 GdkWaylandDisplay *wayland_display =
1071 GDK_WAYLAND_DISPLAY (device->display);
1073 _gdk_wayland_display_update_serial (wayland_display, serial);
1083 gdk_button = button - 271;
1087 device->time = time;
1089 event = gdk_event_new (state ? GDK_BUTTON_PRESS : GDK_BUTTON_RELEASE);
1090 event->button.window = g_object_ref (device->pointer_focus);
1091 gdk_event_set_device (event, device->pointer);
1092 event->button.time = time;
1093 event->button.x = device->surface_x;
1094 event->button.y = device->surface_y;
1095 event->button.axes = NULL;
1096 event->button.state = device->modifiers;
1097 event->button.button = gdk_button;
1098 gdk_event_set_screen (event, display->screen);
1100 modifier = 1 << (8 + gdk_button - 1);
1102 device->modifiers |= modifier;
1104 device->modifiers &= ~modifier;
1107 g_message ("button %d %s, state %d",
1108 event->button.button,
1109 state ? "press" : "release", event->button.state));
1111 _gdk_wayland_display_deliver_event (device->display, event);
1115 pointer_handle_axis (void *data,
1116 struct wl_pointer *pointer,
1124 keyboard_handle_keymap (void *data,
1125 struct wl_keyboard *keyboard,
1130 GdkWaylandDevice *device = data;
1131 GdkWaylandDisplay *display = GDK_WAYLAND_DISPLAY (device->display);
1132 GdkKeymap *gdk_keymap;
1134 struct xkb_keymap *keymap;
1136 if (format != WL_KEYBOARD_KEYMAP_FORMAT_XKB_V1)
1138 g_critical (G_STRLOC ": Unknown keymap format");
1143 keymap_data = mmap (NULL, size, PROT_READ, MAP_SHARED, fd, 0);
1144 if (keymap_data == MAP_FAILED)
1146 g_critical (G_STRLOC ": Unable to map fd for keymap %s", g_strerror (errno));
1151 keymap = xkb_map_new_from_string (display->xkb_context,
1156 munmap (keymap_data, size);
1159 gdk_keymap = _gdk_wayland_display_get_keymap (device->display);
1160 _gdk_wayland_keymap_update_keymap (gdk_keymap, keymap);
1164 keyboard_handle_enter (void *data,
1165 struct wl_keyboard *keyboard,
1167 struct wl_surface *surface,
1168 struct wl_array *keys)
1174 keyboard_handle_leave (void *data,
1175 struct wl_keyboard *keyboard,
1177 struct wl_surface *surface)
1182 keyboard_handle_key (void *data,
1183 struct wl_keyboard *keyboard,
1192 keyboard_handle_modifiers (void *data,
1193 struct wl_keyboard *keyboard,
1195 uint32_t mods_depressed,
1196 uint32_t mods_latched,
1197 uint32_t mods_locked,
1202 static const struct wl_pointer_listener pointer_listener = {
1203 pointer_handle_enter,
1204 pointer_handle_leave,
1205 pointer_handle_motion,
1206 pointer_handle_button,
1207 pointer_handle_axis,
1210 static const struct wl_keyboard_listener keyboard_listener = {
1211 keyboard_handle_keymap,
1212 keyboard_handle_enter,
1213 keyboard_handle_leave,
1214 keyboard_handle_key,
1215 keyboard_handle_modifiers,
1219 seat_handle_capabilities(void *data, struct wl_seat *seat,
1220 enum wl_seat_capability caps)
1222 GdkWaylandDevice *device = data;
1223 GdkDeviceManagerCore *device_manager_core =
1224 GDK_DEVICE_MANAGER_CORE(device->device_manager);
1226 if ((caps & WL_SEAT_CAPABILITY_POINTER) && !device->wl_pointer)
1228 device->wl_pointer = wl_seat_get_pointer(seat);
1229 wl_pointer_set_user_data(device->wl_pointer, device);
1230 wl_pointer_add_listener(device->wl_pointer, &pointer_listener,
1233 device->pointer = g_object_new (GDK_TYPE_DEVICE_CORE,
1234 "name", "Core Pointer",
1235 "type", GDK_DEVICE_TYPE_MASTER,
1236 "input-source", GDK_SOURCE_MOUSE,
1237 "input-mode", GDK_MODE_SCREEN,
1239 "display", device->display,
1240 "device-manager", device->device_manager,
1242 GDK_DEVICE_CORE (device->pointer)->device = device;
1244 device_manager_core->devices =
1245 g_list_prepend (device_manager_core->devices, device->pointer);
1247 else if (!(caps & WL_SEAT_CAPABILITY_POINTER) && device->wl_pointer)
1249 wl_pointer_destroy(device->wl_pointer);
1250 device->wl_pointer = NULL;
1252 device_manager_core->devices =
1253 g_list_remove (device_manager_core->devices, device->pointer);
1255 g_object_unref (device->pointer);
1256 device->pointer = NULL;
1259 if ((caps & WL_SEAT_CAPABILITY_KEYBOARD) && !device->wl_keyboard)
1261 device->wl_keyboard = wl_seat_get_keyboard(seat);
1262 wl_keyboard_set_user_data(device->wl_keyboard, device);
1263 wl_keyboard_add_listener(device->wl_keyboard, &keyboard_listener,
1266 device->keyboard = g_object_new (GDK_TYPE_DEVICE_CORE,
1267 "name", "Core Keyboard",
1268 "type", GDK_DEVICE_TYPE_MASTER,
1269 "input-source", GDK_SOURCE_KEYBOARD,
1270 "input-mode", GDK_MODE_SCREEN,
1271 "has-cursor", FALSE,
1272 "display", device->display,
1273 "device-manager", device->device_manager,
1275 GDK_DEVICE_CORE (device->keyboard)->device = device;
1277 device_manager_core->devices =
1278 g_list_prepend (device_manager_core->devices, device->keyboard);
1280 else if (!(caps & WL_SEAT_CAPABILITY_KEYBOARD) && device->wl_keyboard)
1282 wl_keyboard_destroy(device->wl_keyboard);
1283 device->wl_keyboard = NULL;
1285 device_manager_core->devices =
1286 g_list_remove (device_manager_core->devices, device->keyboard);
1288 g_object_unref (device->keyboard);
1289 device->keyboard = NULL;
1292 if (device->keyboard && device->pointer)
1294 _gdk_device_set_associated_device (device->pointer, device->keyboard);
1295 _gdk_device_set_associated_device (device->keyboard, device->pointer);
1299 static const struct wl_seat_listener seat_listener = {
1300 seat_handle_capabilities,
1304 _gdk_wayland_device_manager_add_device (GdkDeviceManager *device_manager,
1305 struct wl_seat *wl_seat)
1307 GdkDisplay *display;
1308 GdkWaylandDisplay *display_wayland;
1309 GdkWaylandDevice *device;
1311 display = gdk_device_manager_get_display (device_manager);
1312 display_wayland = GDK_WAYLAND_DISPLAY (display);
1314 device = g_new0 (GdkWaylandDevice, 1);
1315 device->display = display;
1316 device->device_manager = device_manager;
1318 device->wl_seat = wl_seat;
1320 wl_seat_add_listener (device->wl_seat, &seat_listener, device);
1321 wl_seat_set_user_data (device->wl_seat, device);
1323 device->data_device =
1324 wl_data_device_manager_get_data_device (display_wayland->data_device_manager,
1326 wl_data_device_add_listener (device->data_device,
1327 &data_device_listener, device);
1329 device->pointer_surface =
1330 wl_compositor_create_surface (display_wayland->compositor);
1334 free_device (gpointer data)
1336 g_object_unref (data);
1340 gdk_device_manager_core_finalize (GObject *object)
1342 GdkDeviceManagerCore *device_manager_core;
1344 device_manager_core = GDK_DEVICE_MANAGER_CORE (object);
1346 g_list_free_full (device_manager_core->devices, free_device);
1348 G_OBJECT_CLASS (gdk_device_manager_core_parent_class)->finalize (object);
1352 gdk_device_manager_core_list_devices (GdkDeviceManager *device_manager,
1355 GdkDeviceManagerCore *device_manager_core;
1356 GList *devices = NULL;
1358 if (type == GDK_DEVICE_TYPE_MASTER)
1360 device_manager_core = (GdkDeviceManagerCore *) device_manager;
1361 devices = g_list_copy(device_manager_core->devices);
1368 gdk_device_manager_core_get_client_pointer (GdkDeviceManager *device_manager)
1370 GdkDeviceManagerCore *device_manager_core;
1373 device_manager_core = (GdkDeviceManagerCore *) device_manager;
1375 /* Find the first pointer device */
1376 for (l = device_manager_core->devices; l != NULL; l = l->next)
1378 GdkDevice *device = l->data;
1380 if (gdk_device_get_source (device) == GDK_SOURCE_MOUSE)
1388 gdk_device_manager_core_class_init (GdkDeviceManagerCoreClass *klass)
1390 GdkDeviceManagerClass *device_manager_class = GDK_DEVICE_MANAGER_CLASS (klass);
1391 GObjectClass *object_class = G_OBJECT_CLASS (klass);
1393 object_class->finalize = gdk_device_manager_core_finalize;
1394 device_manager_class->list_devices = gdk_device_manager_core_list_devices;
1395 device_manager_class->get_client_pointer = gdk_device_manager_core_get_client_pointer;
1399 gdk_device_manager_core_init (GdkDeviceManagerCore *device_manager)
1404 _gdk_wayland_device_manager_new (GdkDisplay *display)
1406 return g_object_new (GDK_TYPE_DEVICE_MANAGER_CORE,
1412 gdk_wayland_device_get_selection_type_atoms (GdkDevice *gdk_device,
1413 GdkAtom **atoms_out)
1417 GdkWaylandDevice *device;
1419 g_return_val_if_fail (GDK_IS_DEVICE_CORE (gdk_device), 0);
1420 g_return_val_if_fail (atoms_out != NULL, 0);
1422 device = GDK_DEVICE_CORE (gdk_device)->device;
1424 if (!device->selection_offer || device->selection_offer->types->len == 0)
1430 atoms = g_new0 (GdkAtom, device->selection_offer->types->len);
1432 /* Convert list of targets to atoms */
1433 for (i = 0; i < device->selection_offer->types->len; i++)
1435 atoms[i] = gdk_atom_intern (device->selection_offer->types->pdata[i],
1438 g_message (G_STRLOC ": Adding atom for %s",
1439 (char *)device->selection_offer->types->pdata[i]));
1443 return device->selection_offer->types->len;
1448 GdkWaylandDevice *device;
1450 GIOChannel *channel;
1451 GdkDeviceWaylandRequestContentCallback cb;
1453 } RequestContentClosure;
1456 _request_content_io_func (GIOChannel *channel,
1457 GIOCondition condition,
1460 RequestContentClosure *closure = (RequestContentClosure *)userdata;
1463 GError *error = NULL;
1465 /* FIXME: We probably want to do something better than this to avoid
1466 * blocking on the transfer of large pieces of data: call the callback
1467 * multiple times I should think.
1469 if (g_io_channel_read_to_end (channel,
1472 &error) != G_IO_STATUS_NORMAL)
1474 g_warning (G_STRLOC ": Error reading content from pipe: %s", error->message);
1475 g_clear_error (&error);
1478 /* Since we use _read_to_end we've got a guaranteed EOF and thus can go
1479 * ahead and close the fd
1481 g_io_channel_shutdown (channel, TRUE, NULL);
1483 closure->cb (closure->device->pointer, data, len, closure->userdata);
1486 data_offer_unref (closure->offer);
1487 g_io_channel_unref (channel);
1494 gdk_wayland_device_request_selection_content (GdkDevice *gdk_device,
1495 const gchar *requested_mime_type,
1496 GdkDeviceWaylandRequestContentCallback cb,
1500 RequestContentClosure *closure;
1501 GdkWaylandDevice *device;
1502 GError *error = NULL;
1504 g_return_val_if_fail (GDK_IS_DEVICE_CORE (gdk_device), FALSE);
1505 g_return_val_if_fail (requested_mime_type != NULL, FALSE);
1506 g_return_val_if_fail (cb != NULL, FALSE);
1508 device = GDK_DEVICE_CORE (gdk_device)->device;
1510 if (!device->selection_offer)
1513 /* TODO: Check mimetypes */
1515 closure = g_new0 (RequestContentClosure, 1);
1517 device->selection_offer->ref_count++;
1519 pipe2 (pipe_fd, O_CLOEXEC);
1520 wl_data_offer_receive (device->selection_offer->offer,
1521 requested_mime_type,
1525 closure->device = device;
1526 closure->offer = device->selection_offer;
1527 closure->channel = g_io_channel_unix_new (pipe_fd[0]);
1529 closure->userdata = userdata;
1531 if (!g_io_channel_set_encoding (closure->channel, NULL, &error))
1533 g_warning (G_STRLOC ": Error setting encoding on channel: %s",
1535 g_clear_error (&error);
1539 g_io_add_watch (closure->channel,
1541 _request_content_io_func,
1547 data_offer_unref (closure->offer);
1548 g_io_channel_unref (closure->channel);
1555 struct _GdkWaylandSelectionOffer {
1556 GdkDeviceWaylandOfferContentCallback cb;
1558 struct wl_data_source *source;
1559 GdkWaylandDevice *device;
1563 data_source_target (void *data,
1564 struct wl_data_source *source,
1565 const char *mime_type)
1567 g_debug (G_STRLOC ": %s source = %p, mime_type = %s",
1568 G_STRFUNC, source, mime_type);
1572 data_source_send (void *data,
1573 struct wl_data_source *source,
1574 const char *mime_type,
1577 GdkWaylandSelectionOffer *offer = (GdkWaylandSelectionOffer *)data;;
1579 gssize len, bytes_written = 0;
1581 g_debug (G_STRLOC ": %s source = %p, mime_type = %s fd = %d",
1582 G_STRFUNC, source, mime_type, fd);
1584 buf = offer->cb (offer->device->pointer, mime_type, &len, offer->userdata);
1588 bytes_written += write (fd, buf + bytes_written, len);
1589 if (bytes_written == -1)
1591 len -= bytes_written;
1600 g_warning (G_STRLOC ": Error writing data to client: %s",
1601 g_strerror (errno));
1608 data_source_cancelled (void *data,
1609 struct wl_data_source *source)
1611 g_debug (G_STRLOC ": %s source = %p",
1615 static const struct wl_data_source_listener data_source_listener = {
1618 data_source_cancelled
1626 gettimeofday(&tv, NULL);
1628 return tv.tv_sec * 1000 + tv.tv_usec / 1000;
1632 gdk_wayland_device_offer_selection_content (GdkDevice *gdk_device,
1633 const gchar **mime_types,
1635 GdkDeviceWaylandOfferContentCallback cb,
1638 GdkDisplay *display;
1639 GdkWaylandDisplay *display_wayland;
1640 GdkWaylandSelectionOffer *offer;
1641 GdkWaylandDevice *device;
1644 g_return_val_if_fail (GDK_IS_DEVICE_CORE (gdk_device), 0);
1645 device = GDK_DEVICE_CORE (gdk_device)->device;
1647 display = device->display;
1648 display_wayland = GDK_WAYLAND_DISPLAY (display);
1650 offer = g_new0 (GdkWaylandSelectionOffer, 1);
1652 offer->userdata = userdata;
1654 wl_data_device_manager_create_data_source (display_wayland->data_device_manager);
1655 offer->device = device;
1657 for (i = 0; i < nr_mime_types; i++)
1659 wl_data_source_offer (offer->source,
1663 wl_data_source_add_listener (offer->source,
1664 &data_source_listener,
1667 wl_data_device_set_selection (device->data_device,
1671 device->selection_offer_out = offer;
1677 gdk_wayland_device_clear_selection_content (GdkDevice *gdk_device)
1679 GdkWaylandDevice *device;
1681 g_return_val_if_fail (GDK_IS_DEVICE_CORE (gdk_device), 0);
1682 device = GDK_DEVICE_CORE (gdk_device)->device;
1684 if (!device->selection_offer_out)
1687 wl_data_device_set_selection (device->data_device,
1691 wl_data_source_destroy (device->selection_offer_out->source);
1692 g_free (device->selection_offer_out);
1693 device->selection_offer_out = NULL;