static void
_e_vis_hook_client_del(void *data EINA_UNUSED, E_Client *ec)
{
- if (!ec->new_client) return;
+ E_VIS_CLIENT_GET_OR_RETURN(vc, ec);
+ if (vc->skip_hook_del) return;
_e_vis_client_remove(ec);
}
+static Eina_Bool
+_e_vis_cb_client_add(void *data EINA_UNUSED, int type EINA_UNUSED, void *event)
+{
+ E_Event_Client *ev;
+
+ ev = event;
+ E_VIS_CLIENT_GET_OR_RETURN_VAL(vc, ev->ec, ECORE_CALLBACK_PASS_ON);
+
+ vc->skip_hook_del = EINA_TRUE;
+
+ return ECORE_CALLBACK_PASS_ON;
+}
+
static Eina_Bool
_e_vis_cb_client_remove(void *data EINA_UNUSED, int type EINA_UNUSED, void *event)
{
E_LIST_HOOK_APPEND(pol_vis->hooks, E_CLIENT_HOOK_NEW_CLIENT_POST, _e_vis_hook_new_client_post, NULL);
E_LIST_HOOK_APPEND(pol_vis->hooks, E_CLIENT_HOOK_DEL, _e_vis_hook_client_del, NULL);
+ E_LIST_HANDLER_APPEND(pol_vis->handlers, E_EVENT_CLIENT_ADD, _e_vis_cb_client_add, NULL);
E_LIST_HANDLER_APPEND(pol_vis->handlers, E_EVENT_CLIENT_REMOVE, _e_vis_cb_client_remove, NULL);
E_COMP_OBJECT_INTERCEPT_HOOK_APPEND(pol_vis->interceptors, E_COMP_OBJECT_INTERCEPT_HOOK_SHOW_HELPER, _e_vis_intercept_show, NULL);