summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCedric BAIL <cedric@osg.samsung.com>2017-03-09 16:17:10 -0800
committerCedric BAIL <cedric@osg.samsung.com>2017-03-09 16:17:58 -0800
commitc91b4c70653527546afbc324b94e4ed60cdfd784 (patch)
tree6481ff95e5eac80a0781f3fd06b5be78bc0d8a6a
parent93b63b48e862c1ee5c217abeede05a5533c96ed7 (diff)
downloadefl-c91b4c70653527546afbc324b94e4ed60cdfd784.tar.gz
elput: avoid crash during shutdown due to Ecore_Event queue.
-rw-r--r--src/lib/elput/elput.c45
1 files changed, 24 insertions, 21 deletions
diff --git a/src/lib/elput/elput.c b/src/lib/elput/elput.c
index 561c98addd..f0c7a9027b 100644
--- a/src/lib/elput/elput.c
+++ b/src/lib/elput/elput.c
@@ -6,13 +6,13 @@ static int _elput_init_count = 0;
/* external variables */
int _elput_log_dom = -1;
-EAPI int ELPUT_EVENT_SEAT_CAPS = -1;
-EAPI int ELPUT_EVENT_SEAT_FRAME = -1;
-EAPI int ELPUT_EVENT_KEYMAP_SEND = -1;
-EAPI int ELPUT_EVENT_MODIFIERS_SEND = -1;
-EAPI int ELPUT_EVENT_DEVICE_CHANGE = -1;
-EAPI int ELPUT_EVENT_SESSION_ACTIVE = -1;
-EAPI int ELPUT_EVENT_POINTER_MOTION = -1;
+EAPI int ELPUT_EVENT_SEAT_CAPS = 0;
+EAPI int ELPUT_EVENT_SEAT_FRAME = 0;
+EAPI int ELPUT_EVENT_KEYMAP_SEND = 0;
+EAPI int ELPUT_EVENT_MODIFIERS_SEND = 0;
+EAPI int ELPUT_EVENT_DEVICE_CHANGE = 0;
+EAPI int ELPUT_EVENT_SESSION_ACTIVE = 0;
+EAPI int ELPUT_EVENT_POINTER_MOTION = 0;
EAPI int
elput_init(void)
@@ -31,13 +31,16 @@ elput_init(void)
goto log_err;
}
- ELPUT_EVENT_SEAT_CAPS = ecore_event_type_new();
- ELPUT_EVENT_SEAT_FRAME = ecore_event_type_new();
- ELPUT_EVENT_KEYMAP_SEND = ecore_event_type_new();
- ELPUT_EVENT_MODIFIERS_SEND = ecore_event_type_new();
- ELPUT_EVENT_DEVICE_CHANGE = ecore_event_type_new();
- ELPUT_EVENT_SESSION_ACTIVE = ecore_event_type_new();
- ELPUT_EVENT_POINTER_MOTION = ecore_event_type_new();
+ if (ELPUT_EVENT_SEAT_CAPS == 0)
+ {
+ ELPUT_EVENT_SEAT_CAPS = ecore_event_type_new();
+ ELPUT_EVENT_SEAT_FRAME = ecore_event_type_new();
+ ELPUT_EVENT_KEYMAP_SEND = ecore_event_type_new();
+ ELPUT_EVENT_MODIFIERS_SEND = ecore_event_type_new();
+ ELPUT_EVENT_DEVICE_CHANGE = ecore_event_type_new();
+ ELPUT_EVENT_SESSION_ACTIVE = ecore_event_type_new();
+ ELPUT_EVENT_POINTER_MOTION = ecore_event_type_new();
+ }
return _elput_init_count;
@@ -59,13 +62,13 @@ elput_shutdown(void)
if (_elput_init_count < 1) return 0;
if (--_elput_init_count != 0) return _elput_init_count;
- ELPUT_EVENT_SEAT_CAPS = -1;
- ELPUT_EVENT_SEAT_FRAME = -1;
- ELPUT_EVENT_KEYMAP_SEND = -1;
- ELPUT_EVENT_MODIFIERS_SEND = -1;
- ELPUT_EVENT_DEVICE_CHANGE = -1;
- ELPUT_EVENT_SESSION_ACTIVE = -1;
- ELPUT_EVENT_POINTER_MOTION = -1;
+ ecore_event_type_flush(ELPUT_EVENT_SEAT_CAPS,
+ ELPUT_EVENT_SEAT_FRAME,
+ ELPUT_EVENT_KEYMAP_SEND,
+ ELPUT_EVENT_MODIFIERS_SEND,
+ ELPUT_EVENT_DEVICE_CHANGE,
+ ELPUT_EVENT_SESSION_ACTIVE,
+ ELPUT_EVENT_POINTER_MOTION);
eina_log_domain_unregister(_elput_log_dom);
_elput_log_dom = -1;