evas: better handle async device creation of default mouse
authorMike Blumenkrantz <zmike@osg.samsung.com>
Fri, 26 May 2017 20:34:10 +0000 (16:34 -0400)
committerMike Blumenkrantz <zmike@osg.samsung.com>
Fri, 26 May 2017 20:27:43 +0000 (16:27 -0400)
instead of yolo setting the first pointer-ish device which is created,
check to see if a better match for "default mouse" can be applied

@fix

src/lib/evas/canvas/evas_device.c

index 2e7763a..ae048e6 100644 (file)
@@ -190,7 +190,21 @@ evas_device_add_full(Evas *eo_e, const char *name, const char *desc,
              return NULL;
           }
 
-        if (!e->default_mouse)
+        if (e->default_mouse)
+          {
+             int x, y;
+
+             if ((clas == EVAS_DEVICE_CLASS_MOUSE) &&
+                 (parent_dev == e->default_seat) &&
+                 (evas_device_class_get(e->default_mouse) != EVAS_DEVICE_CLASS_MOUSE))
+               {
+                  evas_pointer_canvas_xy_get(eo_e, &x, &y);
+                  evas_event_feed_mouse_out(eo_e, 0, NULL);
+                  e->default_mouse = dev;
+                  evas_event_feed_mouse_in(eo_e, 0, NULL);
+               }
+          }
+        else
           e->default_mouse = dev;
      }