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, write to the
16 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17 * Boston, MA 02111-1307, USA.
23 #include <gdk/gdkwindow.h>
24 #include <gdk/gdktypes.h>
25 #include "gdkprivate-wayland.h"
26 #include "gdkwayland.h"
27 #include "gdkkeysyms.h"
28 #include "gdkdeviceprivate.h"
29 #include "gdkdevicemanagerprivate.h"
30 #include "gdkprivate-wayland.h"
32 #include <X11/extensions/XKBcommon.h>
33 #include <X11/keysym.h>
35 #define GDK_TYPE_DEVICE_CORE (gdk_device_core_get_type ())
36 #define GDK_DEVICE_CORE(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), GDK_TYPE_DEVICE_CORE, GdkDeviceCore))
37 #define GDK_DEVICE_CORE_CLASS(c) (G_TYPE_CHECK_CLASS_CAST ((c), GDK_TYPE_DEVICE_CORE, GdkDeviceCoreClass))
38 #define GDK_IS_DEVICE_CORE(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), GDK_TYPE_DEVICE_CORE))
39 #define GDK_IS_DEVICE_CORE_CLASS(c) (G_TYPE_CHECK_CLASS_TYPE ((c), GDK_TYPE_DEVICE_CORE))
40 #define GDK_DEVICE_CORE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), GDK_TYPE_DEVICE_CORE, GdkDeviceCoreClass))
42 typedef struct _GdkDeviceCore GdkDeviceCore;
43 typedef struct _GdkDeviceCoreClass GdkDeviceCoreClass;
44 typedef struct _GdkWaylandDevice GdkWaylandDevice;
46 struct _GdkWaylandDevice
51 GdkModifierType modifiers;
52 GdkWindow *pointer_focus;
53 GdkWindow *keyboard_focus;
54 struct wl_input_device *device;
55 int32_t x, y, surface_x, surface_y;
61 GdkDevice parent_instance;
62 GdkWaylandDevice *device;
65 struct _GdkDeviceCoreClass
67 GdkDeviceClass parent_class;
70 G_DEFINE_TYPE (GdkDeviceCore, gdk_device_core, GDK_TYPE_DEVICE)
72 #define GDK_TYPE_DEVICE_MANAGER_CORE (gdk_device_manager_core_get_type ())
73 #define GDK_DEVICE_MANAGER_CORE(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), GDK_TYPE_DEVICE_MANAGER_CORE, GdkDeviceManagerCore))
74 #define GDK_DEVICE_MANAGER_CORE_CLASS(c) (G_TYPE_CHECK_CLASS_CAST ((c), GDK_TYPE_DEVICE_MANAGER_CORE, GdkDeviceManagerCoreClass))
75 #define GDK_IS_DEVICE_MANAGER_CORE(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), GDK_TYPE_DEVICE_MANAGER_CORE))
76 #define GDK_IS_DEVICE_MANAGER_CORE_CLASS(c) (G_TYPE_CHECK_CLASS_TYPE ((c), GDK_TYPE_DEVICE_MANAGER_CORE))
77 #define GDK_DEVICE_MANAGER_CORE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), GDK_TYPE_DEVICE_MANAGER_CORE, GdkDeviceManagerCoreClass))
79 typedef struct _GdkDeviceManagerCore GdkDeviceManagerCore;
80 typedef struct _GdkDeviceManagerCoreClass GdkDeviceManagerCoreClass;
82 struct _GdkDeviceManagerCore
84 GdkDeviceManager parent_object;
85 GdkDevice *core_pointer;
86 GdkDevice *core_keyboard;
90 struct _GdkDeviceManagerCoreClass
92 GdkDeviceManagerClass parent_class;
95 G_DEFINE_TYPE (GdkDeviceManagerCore,
96 gdk_device_manager_core, GDK_TYPE_DEVICE_MANAGER)
99 gdk_device_core_get_history (GdkDevice *device,
103 GdkTimeCoord ***events,
110 gdk_device_core_get_state (GdkDevice *device,
113 GdkModifierType *mask)
117 gdk_window_get_pointer (window, &x_int, &y_int, mask);
127 gdk_device_core_set_window_cursor (GdkDevice *device,
131 GdkWaylandDevice *wd = GDK_DEVICE_CORE(device)->device;
132 struct wl_buffer *buffer;
137 buffer = _gdk_wayland_cursor_get_buffer(cursor, &x, &y);
138 wl_input_device_attach(wd->device, wd->time, buffer, x, y);
142 wl_input_device_attach(wd->device, wd->time, NULL, 0, 0);
147 gdk_device_core_warp (GdkDevice *device,
155 gdk_device_core_query_state (GdkDevice *device,
157 GdkWindow **root_window,
158 GdkWindow **child_window,
163 GdkModifierType *mask)
165 GdkWaylandDevice *wd;
166 GdkScreen *default_screen;
168 wd = GDK_DEVICE_CORE(device)->device;
169 default_screen = gdk_display_get_default_screen (wd->display);
172 *root_window = gdk_screen_get_root_window (default_screen);
174 *child_window = wd->pointer_focus;
180 *win_x = wd->surface_x;
182 *win_y = wd->surface_y;
184 *mask = wd->modifiers;
190 gdk_device_core_grab (GdkDevice *device,
192 gboolean owner_events,
193 GdkEventMask event_mask,
194 GdkWindow *confine_to,
198 return GDK_GRAB_SUCCESS;
202 gdk_device_core_ungrab (GdkDevice *device,
208 gdk_device_core_window_at_position (GdkDevice *device,
211 GdkModifierType *mask,
212 gboolean get_toplevel)
214 GdkWaylandDevice *wd;
216 wd = GDK_DEVICE_CORE(device)->device;
217 *win_x = wd->surface_x;
218 *win_y = wd->surface_y;
219 *mask = wd->modifiers;
221 return wd->pointer_focus;
225 gdk_device_core_select_window_events (GdkDevice *device,
227 GdkEventMask event_mask)
232 gdk_device_core_class_init (GdkDeviceCoreClass *klass)
234 GdkDeviceClass *device_class = GDK_DEVICE_CLASS (klass);
236 device_class->get_history = gdk_device_core_get_history;
237 device_class->get_state = gdk_device_core_get_state;
238 device_class->set_window_cursor = gdk_device_core_set_window_cursor;
239 device_class->warp = gdk_device_core_warp;
240 device_class->query_state = gdk_device_core_query_state;
241 device_class->grab = gdk_device_core_grab;
242 device_class->ungrab = gdk_device_core_ungrab;
243 device_class->window_at_position = gdk_device_core_window_at_position;
244 device_class->select_window_events = gdk_device_core_select_window_events;
248 gdk_device_core_init (GdkDeviceCore *device_core)
252 device = GDK_DEVICE (device_core);
254 _gdk_device_add_axis (device, GDK_NONE, GDK_AXIS_X, 0, 0, 1);
255 _gdk_device_add_axis (device, GDK_NONE, GDK_AXIS_Y, 0, 0, 1);
258 struct wl_input_device *
259 _gdk_wayland_device_get_device (GdkDevice *device)
261 return GDK_DEVICE_CORE (device)->device->device;
265 input_handle_motion(void *data, struct wl_input_device *input_device,
267 int32_t x, int32_t y, int32_t sx, int32_t sy)
269 GdkWaylandDevice *device = data;
270 GdkDisplayWayland *display = GDK_DISPLAY_WAYLAND (device->display);
273 event = gdk_event_new (GDK_NOTHING);
278 device->surface_x = sx;
279 device->surface_y = sy;
281 event->motion.type = GDK_MOTION_NOTIFY;
282 event->motion.window = g_object_ref (device->pointer_focus);
283 gdk_event_set_device (event, device->pointer);
284 event->motion.time = time;
285 event->motion.x = (gdouble) sx;
286 event->motion.y = (gdouble) sy;
287 event->motion.x_root = (gdouble) x;
288 event->motion.y_root = (gdouble) y;
289 event->motion.axes = NULL;
290 event->motion.state = device->modifiers;
291 event->motion.is_hint = 0;
292 gdk_event_set_screen (event, display->screens[0]);
295 g_message ("motion %d %d, state %d",
296 sx, sy, event->button.state));
298 _gdk_wayland_display_deliver_event (device->display, event);
302 input_handle_button(void *data, struct wl_input_device *input_device,
303 uint32_t time, uint32_t button, uint32_t state)
305 GdkWaylandDevice *device = data;
306 GdkDisplayWayland *display = GDK_DISPLAY_WAYLAND (device->display);
311 event = gdk_event_new (state ? GDK_BUTTON_PRESS : GDK_BUTTON_RELEASE);
312 event->button.window = g_object_ref (device->pointer_focus);
313 gdk_event_set_device (event, device->pointer);
314 event->button.time = time;
315 event->button.x = (gdouble) device->surface_x;
316 event->button.y = (gdouble) device->surface_y;
317 event->button.x_root = (gdouble) device->x;
318 event->button.y_root = (gdouble) device->y;
319 event->button.axes = NULL;
320 event->button.state = device->modifiers;
321 event->button.button = button - 271;
322 gdk_event_set_screen (event, display->screens[0]);
324 modifier = 1 << (8 + button - 272);
326 device->modifiers |= modifier;
328 device->modifiers &= ~modifier;
331 g_message ("button %d %s, state %d",
332 event->button.button,
333 state ? "press" : "release", event->button.state));
335 _gdk_wayland_display_deliver_event (device->display, event);
339 translate_keyboard_string (GdkEventKey *event)
344 /* Fill in event->string crudely, since various programs
347 event->string = NULL;
349 if (event->keyval != GDK_KEY_VoidSymbol)
350 c = gdk_keyval_to_unicode (event->keyval);
357 /* Apply the control key - Taken from Xlib
359 if (event->state & GDK_CONTROL_MASK)
361 if ((c >= '@' && c < '\177') || c == ' ') c &= 0x1F;
364 event->string = g_memdup ("\0\0", 2);
369 else if (c >= '3' && c <= '7') c -= ('3' - '\033');
370 else if (c == '8') c = '\177';
371 else if (c == '/') c = '_' & 0x1F;
374 len = g_unichar_to_utf8 (c, buf);
377 event->string = g_locale_from_utf8 (buf, len,
378 NULL, &bytes_written,
381 event->length = bytes_written;
383 else if (event->keyval == GDK_KEY_Escape)
386 event->string = g_strdup ("\033");
388 else if (event->keyval == GDK_KEY_Return ||
389 event->keyval == GDK_KEY_KP_Enter)
392 event->string = g_strdup ("\r");
398 event->string = g_strdup ("");
403 input_handle_key(void *data, struct wl_input_device *input_device,
404 uint32_t time, uint32_t key, uint32_t state)
406 GdkWaylandDevice *device = data;
408 uint32_t code, modifier, level;
409 struct xkb_desc *xkb;
412 keymap = gdk_keymap_get_for_display (device->display);
413 xkb = _gdk_wayland_keymap_get_xkb_desc (keymap);
416 event = gdk_event_new (state ? GDK_KEY_PRESS : GDK_KEY_RELEASE);
417 event->key.window = g_object_ref (device->keyboard_focus);
418 gdk_event_set_device (event, device->keyboard);
419 event->button.time = time;
420 event->key.state = device->modifiers;
421 event->key.group = 0;
422 code = key + xkb->min_key_code;
423 event->key.hardware_keycode = code;
426 if (device->modifiers & XKB_COMMON_SHIFT_MASK &&
427 XkbKeyGroupWidth(xkb, code, 0) > 1)
430 event->key.keyval = XkbKeySymEntry(xkb, code, level, 0);
432 modifier = xkb->map->modmap[code];
434 device->modifiers |= modifier;
436 device->modifiers &= ~modifier;
438 event->key.is_modifier = modifier > 0;
440 translate_keyboard_string (&event->key);
442 _gdk_wayland_display_deliver_event (device->display, event);
445 g_message ("keyboard event, code %d, sym %d, "
446 "string %s, mods 0x%x",
447 code, event->key.keyval,
448 event->key.string, event->key.state));
452 input_handle_pointer_focus(void *data,
453 struct wl_input_device *input_device,
454 uint32_t time, struct wl_surface *surface,
455 int32_t x, int32_t y, int32_t sx, int32_t sy)
457 GdkWaylandDevice *device = data;
461 if (device->pointer_focus)
463 event = gdk_event_new (GDK_LEAVE_NOTIFY);
464 event->crossing.window = g_object_ref (device->pointer_focus);
465 gdk_event_set_device (event, device->pointer);
466 event->crossing.subwindow = NULL;
467 event->crossing.time = time;
468 event->crossing.x = (gdouble) device->surface_x;
469 event->crossing.y = (gdouble) device->surface_y;
470 event->crossing.x_root = (gdouble) device->x;
471 event->crossing.y_root = (gdouble) device->y;
473 event->crossing.mode = GDK_CROSSING_NORMAL;
474 event->crossing.detail = GDK_NOTIFY_ANCESTOR;
475 event->crossing.focus = TRUE;
476 event->crossing.state = 0;
478 _gdk_wayland_display_deliver_event (device->display, event);
481 g_message ("leave, device %p surface %p",
482 device, device->pointer_focus));
484 g_object_unref(device->pointer_focus);
485 device->pointer_focus = NULL;
490 device->pointer_focus = wl_surface_get_user_data(surface);
491 g_object_ref(device->pointer_focus);
493 event = gdk_event_new (GDK_ENTER_NOTIFY);
494 event->crossing.window = g_object_ref (device->pointer_focus);
495 gdk_event_set_device (event, device->pointer);
496 event->crossing.subwindow = NULL;
497 event->crossing.time = time;
498 event->crossing.x = (gdouble) sx;
499 event->crossing.y = (gdouble) sy;
500 event->crossing.x_root = (gdouble) x;
501 event->crossing.y_root = (gdouble) y;
503 event->crossing.mode = GDK_CROSSING_NORMAL;
504 event->crossing.detail = GDK_NOTIFY_ANCESTOR;
505 event->crossing.focus = TRUE;
506 event->crossing.state = 0;
508 device->surface_x = sx;
509 device->surface_y = sy;
513 _gdk_wayland_display_deliver_event (device->display, event);
516 g_message ("enter, device %p surface %p",
517 device, device->pointer_focus));
522 update_modifiers(GdkWaylandDevice *device, struct wl_array *keys)
526 struct xkb_desc *xkb;
528 keymap = gdk_keymap_get_for_display (device->display);
529 xkb = _gdk_wayland_keymap_get_xkb_desc (keymap);
531 end = keys->data + keys->size;
532 device->modifiers = 0;
533 for (k = keys->data; k < end; k++)
534 device->modifiers |= xkb->map->modmap[*k];
538 input_handle_keyboard_focus(void *data,
539 struct wl_input_device *input_device,
541 struct wl_surface *surface,
542 struct wl_array *keys)
544 GdkWaylandDevice *device = data;
548 if (device->keyboard_focus)
550 event = gdk_event_new (GDK_FOCUS_CHANGE);
551 event->focus_change.window = g_object_ref (device->keyboard_focus);
552 event->focus_change.send_event = FALSE;
553 event->focus_change.in = FALSE;
554 gdk_event_set_device (event, device->keyboard);
556 g_object_unref(device->keyboard_focus);
557 device->keyboard_focus = NULL;
560 g_message ("focus out, device %p surface %p",
561 device, device->keyboard_focus));
563 _gdk_wayland_display_deliver_event (device->display, event);
568 device->keyboard_focus = wl_surface_get_user_data(surface);
569 g_object_ref(device->keyboard_focus);
571 event = gdk_event_new (GDK_FOCUS_CHANGE);
572 event->focus_change.window = g_object_ref (device->keyboard_focus);
573 event->focus_change.send_event = FALSE;
574 event->focus_change.in = TRUE;
575 gdk_event_set_device (event, device->keyboard);
577 update_modifiers (device, keys);
580 g_message ("focus int, device %p surface %p",
581 device, device->keyboard_focus));
583 _gdk_wayland_display_deliver_event (device->display, event);
587 static const struct wl_input_device_listener input_device_listener = {
591 input_handle_pointer_focus,
592 input_handle_keyboard_focus,
596 _gdk_wayland_device_manager_add_device (GdkDeviceManager *device_manager,
597 struct wl_input_device *wl_device)
600 GdkDeviceManagerCore *device_manager_core =
601 GDK_DEVICE_MANAGER_CORE(device_manager);
602 GdkWaylandDevice *device;
604 device = g_new0 (GdkWaylandDevice, 1);
605 display = gdk_device_manager_get_display (device_manager);
607 device->display = display;
608 device->pointer = g_object_new (GDK_TYPE_DEVICE_CORE,
609 "name", "Core Pointer",
610 "type", GDK_DEVICE_TYPE_MASTER,
611 "input-source", GDK_SOURCE_MOUSE,
612 "input-mode", GDK_MODE_SCREEN,
615 "device-manager", device_manager,
618 device->keyboard = g_object_new (GDK_TYPE_DEVICE_CORE,
619 "name", "Core Keyboard",
620 "type", GDK_DEVICE_TYPE_MASTER,
621 "input-source", GDK_SOURCE_KEYBOARD,
622 "input-mode", GDK_MODE_SCREEN,
625 "device-manager", device_manager,
628 GDK_DEVICE_CORE (device->pointer)->device = device;
629 GDK_DEVICE_CORE (device->keyboard)->device = device;
630 device->device = wl_device;
632 wl_input_device_add_listener(device->device,
633 &input_device_listener, device);
635 device_manager_core->devices =
636 g_list_prepend (device_manager_core->devices, device->keyboard);
637 device_manager_core->devices =
638 g_list_prepend (device_manager_core->devices, device->pointer);
640 _gdk_device_set_associated_device (device->pointer, device->keyboard);
641 _gdk_device_set_associated_device (device->keyboard, device->pointer);
645 free_device (void *data, void *user_data)
647 g_object_unref (data);
651 gdk_device_manager_core_finalize (GObject *object)
653 GdkDeviceManagerCore *device_manager_core;
655 device_manager_core = GDK_DEVICE_MANAGER_CORE (object);
657 g_list_foreach (device_manager_core->devices, free_device, NULL);
658 g_list_free (device_manager_core->devices);
660 G_OBJECT_CLASS (gdk_device_manager_core_parent_class)->finalize (object);
664 gdk_device_manager_core_list_devices (GdkDeviceManager *device_manager,
667 GdkDeviceManagerCore *device_manager_core;
668 GList *devices = NULL;
670 if (type == GDK_DEVICE_TYPE_MASTER)
672 device_manager_core = (GdkDeviceManagerCore *) device_manager;
673 devices = g_list_copy(device_manager_core->devices);
680 gdk_device_manager_core_get_client_pointer (GdkDeviceManager *device_manager)
682 GdkDeviceManagerCore *device_manager_core;
684 device_manager_core = (GdkDeviceManagerCore *) device_manager;
685 return device_manager_core->devices->data;
689 gdk_device_manager_core_class_init (GdkDeviceManagerCoreClass *klass)
691 GdkDeviceManagerClass *device_manager_class = GDK_DEVICE_MANAGER_CLASS (klass);
692 GObjectClass *object_class = G_OBJECT_CLASS (klass);
694 object_class->finalize = gdk_device_manager_core_finalize;
695 device_manager_class->list_devices = gdk_device_manager_core_list_devices;
696 device_manager_class->get_client_pointer = gdk_device_manager_core_get_client_pointer;
700 gdk_device_manager_core_init (GdkDeviceManagerCore *device_manager)
705 _gdk_wayland_device_manager_new (GdkDisplay *display)
707 return g_object_new (GDK_TYPE_DEVICE_MANAGER_CORE,