evas_events: look for seats on hash instead of input devices
authorBruno Dilly <bdilly@profusion.mobi>
Thu, 23 Mar 2017 22:00:44 +0000 (19:00 -0300)
committerBruno Dilly <bdilly@profusion.mobi>
Fri, 24 Mar 2017 17:14:38 +0000 (14:14 -0300)
Summary:
Otherwise it won't ever find the modifier masks.

Fixes T5146

@fix

Reviewers: iscaro, Jaehyun_Cho

Subscribers: cedric, jpeg

Maniphest Tasks: T5146

Differential Revision: https://phab.enlightenment.org/D4738

src/lib/evas/canvas/evas_events.c

index 82c6dd7..cfaee6e 100644 (file)
@@ -3110,9 +3110,12 @@ _canvas_event_feed_key_down_internal(Evas_Public_Data *e, Efl_Input_Key_Data *ev
         Eina_List *l;
         Evas_Key_Grab *g;
         Evas_Modifier_Mask *seat_mask, modifier_mask;
+        Efl_Input_Device *seat = NULL;
 
         e->walking_grabs++;
-        seat_mask = eina_hash_find(e->modifiers.masks, &ev->device);
+        if (ev->device)
+          seat = efl_input_device_seat_get(ev->device);
+        seat_mask = eina_hash_find(e->modifiers.masks, &seat);
         modifier_mask = seat_mask ? *seat_mask : 0;
         EINA_LIST_FOREACH(e->grabs, l, g)
           {
@@ -3200,9 +3203,12 @@ _canvas_event_feed_key_up_internal(Evas_Public_Data *e, Efl_Input_Key_Data *ev)
         Eina_List *l;
         Evas_Key_Grab *g;
         Evas_Modifier_Mask *seat_mask, modifier_mask;
+        Efl_Input_Device *seat = NULL;
 
         e->walking_grabs++;
-        seat_mask = eina_hash_find(e->modifiers.masks, &ev->device);
+        if (ev->device)
+          seat = efl_input_device_seat_get(ev->device);
+        seat_mask = eina_hash_find(e->modifiers.masks, &seat);
         modifier_mask = seat_mask ? *seat_mask : 0;
         EINA_LIST_FOREACH(e->grabs, l, g)
           {