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/>.
20 #include "gdkx11devicemanager-core.h"
21 #include "gdkdevicemanagerprivate-core.h"
23 #include "gdkx11devicemanager-xi2.h"
25 #include "gdkinternals.h"
26 #include "gdkprivate-x11.h"
28 /* Defines for VCP/VCK, to be used too
29 * for the core protocol device manager
31 #define VIRTUAL_CORE_POINTER_ID 2
32 #define VIRTUAL_CORE_KEYBOARD_ID 3
35 _gdk_x11_device_manager_new (GdkDisplay *display)
37 if (!g_getenv ("GDK_CORE_DEVICE_EVENTS"))
40 int opcode, firstevent, firsterror;
43 xdisplay = GDK_DISPLAY_XDISPLAY (display);
45 if (XQueryExtension (xdisplay, "XInputExtension",
46 &opcode, &firstevent, &firsterror))
53 if (!_gdk_disable_multidevice &&
54 XIQueryVersion (xdisplay, &major, &minor) != BadRequest)
56 GdkX11DeviceManagerXI2 *device_manager_xi2;
58 GDK_NOTE (INPUT, g_print ("Creating XI2 device manager\n"));
60 device_manager_xi2 = g_object_new (GDK_TYPE_X11_DEVICE_MANAGER_XI2,
67 return GDK_DEVICE_MANAGER (device_manager_xi2);
73 GDK_NOTE (INPUT, g_print ("Creating core device manager\n"));
75 return g_object_new (GDK_TYPE_X11_DEVICE_MANAGER_CORE,
81 * gdk_x11_device_manager_lookup:
82 * @device_manager: a #GdkDeviceManager
83 * @device_id: a device ID, as understood by the XInput2 protocol
85 * Returns the #GdkDevice that wraps the given device ID.
87 * Returns: (transfer none): (allow-none): The #GdkDevice wrapping the device ID,
88 * or %NULL if the given ID doesn't currently represent a device.
93 gdk_x11_device_manager_lookup (GdkDeviceManager *device_manager,
96 GdkDevice *device = NULL;
98 g_return_val_if_fail (GDK_IS_DEVICE_MANAGER (device_manager), NULL);
101 if (GDK_IS_X11_DEVICE_MANAGER_XI2 (device_manager))
102 device = _gdk_x11_device_manager_xi2_lookup (GDK_X11_DEVICE_MANAGER_XI2 (device_manager),
105 #endif /* XINPUT_2 */
106 if (GDK_IS_X11_DEVICE_MANAGER_CORE (device_manager))
108 /* It is a core/xi1 device manager, we only map
109 * IDs 2 and 3, matching XI2's Virtual Core Pointer
112 if (device_id == VIRTUAL_CORE_POINTER_ID)
113 device = GDK_X11_DEVICE_MANAGER_CORE (device_manager)->core_pointer;
114 else if (device_id == VIRTUAL_CORE_KEYBOARD_ID)
115 device = GDK_X11_DEVICE_MANAGER_CORE (device_manager)->core_keyboard;
122 * gdk_x11_device_get_id:
123 * @device: a #GdkDevice
125 * Returns the device ID as seen by XInput2.
128 * If gdk_disable_multidevice() has been called, this function
129 * will respectively return 2/3 for the core pointer and keyboard,
130 * (matching the IDs for the Virtual Core Pointer and Keyboard in
131 * XInput 2), but calling this function on any slave devices (i.e.
132 * those managed via XInput 1.x), will return 0.
135 * Returns: the XInput2 device ID.
140 gdk_x11_device_get_id (GdkDevice *device)
144 g_return_val_if_fail (GDK_IS_DEVICE (device), 0);
147 if (GDK_IS_X11_DEVICE_XI2 (device))
148 device_id = _gdk_x11_device_xi2_get_id (GDK_X11_DEVICE_XI2 (device));
150 #endif /* XINPUT_2 */
151 if (GDK_IS_X11_DEVICE_CORE (device))
153 if (gdk_device_get_source (device) == GDK_SOURCE_KEYBOARD)
154 device_id = VIRTUAL_CORE_KEYBOARD_ID;
156 device_id = VIRTUAL_CORE_POINTER_ID;