diff options
author | Mike Blumenkrantz <zmike@osg.samsung.com> | 2017-05-26 16:34:10 -0400 |
---|---|---|
committer | Mike Blumenkrantz <zmike@osg.samsung.com> | 2017-05-26 16:27:43 -0400 |
commit | 6775b23212305c957f4447c708053585f361bb86 (patch) | |
tree | e2124ab06d22565d80f00ab112237238fd5dc520 | |
parent | d4ce9b1ac38b6297ceccc8cdbb9b0bb2e8f3ec66 (diff) | |
download | efl-6775b23212305c957f4447c708053585f361bb86.tar.gz |
evas: better handle async device creation of default mouse
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
-rw-r--r-- | src/lib/evas/canvas/evas_device.c | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/src/lib/evas/canvas/evas_device.c b/src/lib/evas/canvas/evas_device.c index 2e7763aa1c..ae048e6cbc 100644 --- a/src/lib/evas/canvas/evas_device.c +++ b/src/lib/evas/canvas/evas_device.c @@ -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; } |