summaryrefslogtreecommitdiff
path: root/gtk/gtktreeview.c
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2017-11-23 15:40:12 -0500
committerMatthias Clasen <mclasen@redhat.com>2017-11-25 11:04:14 -0500
commit835805ad6147b43f65b120802f12eb6d2ab121a3 (patch)
tree2787a24f44f86ef92b8b327fae2d4161b414242a /gtk/gtktreeview.c
parent7c0a1ddb0579068ad1d780c34accc80b3d3de587 (diff)
downloadgtk+-835805ad6147b43f65b120802f12eb6d2ab121a3.tar.gz
treeview: Don't use GdkDeviceManager
We can just as well use GdkSeat to enumerate (attached) devices. Note that this change excludes floating devices from consideration. This keeps the copy-pasted code in sync with gtkwindow.c
Diffstat (limited to 'gtk/gtktreeview.c')
-rw-r--r--gtk/gtktreeview.c17
1 files changed, 5 insertions, 12 deletions
diff --git a/gtk/gtktreeview.c b/gtk/gtktreeview.c
index 31da0d890a..e21ea17372 100644
--- a/gtk/gtktreeview.c
+++ b/gtk/gtktreeview.c
@@ -10638,15 +10638,12 @@ send_focus_change (GtkWidget *widget,
GdkDevice *device,
gboolean in)
{
- GdkDeviceManager *device_manager;
+ GdkSeat *seat;
GList *devices, *d;
- G_GNUC_BEGIN_IGNORE_DEPRECATIONS;
- device_manager = gdk_display_get_device_manager (gtk_widget_get_display (widget));
- devices = gdk_device_manager_list_devices (device_manager, GDK_DEVICE_TYPE_MASTER);
- devices = g_list_concat (devices, gdk_device_manager_list_devices (device_manager, GDK_DEVICE_TYPE_SLAVE));
- devices = g_list_concat (devices, gdk_device_manager_list_devices (device_manager, GDK_DEVICE_TYPE_FLOATING));
- G_GNUC_END_IGNORE_DEPRECATIONS;
+ seat = gdk_display_get_default_seat (gtk_widget_get_display (widget));
+ devices = gdk_seat_get_slaves (seat, GDK_SEAT_CAPABILITY_KEYBOARD);
+ devices = g_list_prepend (devices, gdk_seat_get_keyboard (seat));
for (d = devices; d; d = d->next)
{
@@ -10654,14 +10651,10 @@ send_focus_change (GtkWidget *widget,
GdkEvent *fevent;
GdkWindow *window;
- if (gdk_device_get_source (dev) != GDK_SOURCE_KEYBOARD)
- continue;
-
- window = gtk_widget_get_window (widget);
-
/* Skip non-master keyboards that haven't
* selected for events from this window
*/
+ window = gtk_widget_get_window (widget);
if (gdk_device_get_device_type (dev) != GDK_DEVICE_TYPE_MASTER &&
!gdk_window_get_device_events (window, dev))
continue;