diff options
author | Cedric BAIL <cedric@osg.samsung.com> | 2017-03-09 16:16:28 -0800 |
---|---|---|
committer | Cedric BAIL <cedric@osg.samsung.com> | 2017-03-09 16:17:58 -0800 |
commit | 168d2a14460918f8b658add7e5d71807bd24ee19 (patch) | |
tree | 4b495b90767554d60e17b79a424a2cb8feef8457 | |
parent | ff3c6f394eb5a944da75a5cc001a664fc4dfee69 (diff) | |
download | efl-168d2a14460918f8b658add7e5d71807bd24ee19.tar.gz |
efreet: avoid crash during shutdown due to Ecore_Event queue.
-rw-r--r-- | src/lib/efreet/efreet_cache.c | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/src/lib/efreet/efreet_cache.c b/src/lib/efreet/efreet_cache.c index 82ceaca802..a9d5bec428 100644 --- a/src/lib/efreet/efreet_cache.c +++ b/src/lib/efreet/efreet_cache.c @@ -274,9 +274,12 @@ efreet_cache_init(void) ERR("Failed to create directory '%s'", buf); } - EFREET_EVENT_ICON_CACHE_UPDATE = ecore_event_type_new(); - EFREET_EVENT_DESKTOP_CACHE_UPDATE = ecore_event_type_new(); - EFREET_EVENT_DESKTOP_CACHE_BUILD = ecore_event_type_new(); + if (EFREET_EVENT_ICON_CACHE_UPDATE == 0) + { + EFREET_EVENT_ICON_CACHE_UPDATE = ecore_event_type_new(); + EFREET_EVENT_DESKTOP_CACHE_UPDATE = ecore_event_type_new(); + EFREET_EVENT_DESKTOP_CACHE_BUILD = ecore_event_type_new(); + } themes = eina_hash_string_superfast_new(EINA_FREE_CB(efreet_cache_icon_theme_free)); icons = eina_hash_string_superfast_new(EINA_FREE_CB(efreet_cache_icon_free)); @@ -342,6 +345,10 @@ efreet_cache_shutdown(void) { Efreet_Old_Cache *d; + ecore_event_type_flush(EFREET_EVENT_ICON_CACHE_UPDATE, + EFREET_EVENT_DESKTOP_CACHE_UPDATE, + EFREET_EVENT_DESKTOP_CACHE_BUILD); + IF_RELEASE(theme_name); icon_cache = efreet_cache_close(icon_cache); |