From c2cad994e15cce76f15f34f35411f3839d09c645 Mon Sep 17 00:00:00 2001 From: Derek Foreman Date: Thu, 15 Mar 2018 14:36:27 -0500 Subject: [PATCH] ee_wayland: Prevent extra commits It's possible that we unregister then reregister an animator so quickly that the ecore_evas idle enter/exiters haven't had a chance to run yet. In this case a render will come shortly anyway and we shouldn't use a 'false' commit to kick off a frame callback. Silences an ERR and unmeasurably improves protocol utilization. --- src/modules/ecore_evas/engines/wayland/ecore_evas_wayland_common.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/modules/ecore_evas/engines/wayland/ecore_evas_wayland_common.c b/src/modules/ecore_evas/engines/wayland/ecore_evas_wayland_common.c index 3e3ee74..93b906a 100644 --- a/src/modules/ecore_evas/engines/wayland/ecore_evas_wayland_common.c +++ b/src/modules/ecore_evas/engines/wayland/ecore_evas_wayland_common.c @@ -131,7 +131,8 @@ _ecore_evas_wl_common_animator_register(Ecore_Evas *ee) edata->frame = ecore_wl2_window_frame_callback_add(edata->win, _anim_cb_tick, ee); - if (!ecore_wl2_window_pending_get(edata->win) && !ee->in_async_render) + if (!ecore_wl2_window_pending_get(edata->win) && !ee->in_async_render && + !ee->animator_ticked && !ee->animator_ran) ecore_wl2_window_false_commit(edata->win); edata->ticking = EINA_TRUE; } -- 2.7.4