elput: fix seat cleanup
authorMike Blumenkrantz <zmike@osg.samsung.com>
Fri, 28 Jul 2017 19:44:43 +0000 (15:44 -0400)
committerMike Blumenkrantz <zmike@osg.samsung.com>
Fri, 28 Jul 2017 19:40:47 +0000 (15:40 -0400)
ensure seat deletion does not conflict with elput shutdown

@fix

src/lib/elput/elput_input.c

index 9024611..5134a67 100644 (file)
@@ -123,8 +123,14 @@ _udev_seat_destroy(Elput_Seat *eseat)
      _evdev_device_destroy(edev);
 
    if (eseat->kbd) _evdev_keyboard_destroy(eseat->kbd);
+   eseat->kbd = NULL;
    if (eseat->ptr) _evdev_pointer_destroy(eseat->ptr);
+   eseat->ptr = NULL;
    if (eseat->touch) _evdev_touch_destroy(eseat->touch);
+   eseat->touch = NULL;
+   if (eseat->manager->input.seats)
+     eseat->manager->input.seats = eina_list_remove(eseat->manager->input.seats, eseat);
+   if (eseat->refs) return;
 
    eina_stringshare_del(eseat->name);
    free(eseat);
@@ -429,12 +435,13 @@ EAPI void
 elput_input_shutdown(Elput_Manager *manager)
 {
    Elput_Seat *seat;
+   Eina_List *l, *ll;
 
    EINA_SAFETY_ON_NULL_RETURN(manager);
 
    ecore_main_fd_handler_del(manager->input.hdlr);
 
-   EINA_LIST_FREE(manager->input.seats, seat)
+   EINA_LIST_FOREACH_SAFE(manager->input.seats, l, ll, seat)
      _udev_seat_destroy(seat);
 
    if (manager->input.thread)