forked from enlightenment/efl
eio: start implement fallback monitor.
SVN revision: 68473
This commit is contained in:
parent
45bd2a60cd
commit
1a82751cf1
|
@ -196,6 +196,7 @@ void eio_monitor_backend_add(Eio_Monitor *monitor)
|
||||||
backend->hwnd = inotify_add_watch(ecore_main_fd_handler_fd_get(_inotify_fdh), monitor->path, mask);
|
backend->hwnd = inotify_add_watch(ecore_main_fd_handler_fd_get(_inotify_fdh), monitor->path, mask);
|
||||||
if (!backend->hwnd)
|
if (!backend->hwnd)
|
||||||
return eio_monitor_fallback_add(monitor);
|
return eio_monitor_fallback_add(monitor);
|
||||||
|
monitor->backend = backend;
|
||||||
|
|
||||||
eina_hash_direct_add(_inotify_monitors, &backend->hwnd, backend);
|
eina_hash_direct_add(_inotify_monitors, &backend->hwnd, backend);
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,8 +22,17 @@
|
||||||
|
|
||||||
struct _Eio_Monitor_Backend
|
struct _Eio_Monitor_Backend
|
||||||
{
|
{
|
||||||
|
Eio_Monitor *parent;
|
||||||
|
|
||||||
|
Ecore_Timer *timer;
|
||||||
|
Ecore_Idler *idler;
|
||||||
|
Ecore_Thread *work;
|
||||||
|
|
||||||
|
Eina_Bool delete_me : 1;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static Eina_Bool _eio_monitor_fallback_timer_cb(void *data);
|
||||||
|
|
||||||
#if !defined HAVE_INOTIFY && !defined HAVE_NOTIFY_WIN32
|
#if !defined HAVE_INOTIFY && !defined HAVE_NOTIFY_WIN32
|
||||||
void eio_monitor_backend_init(void)
|
void eio_monitor_backend_init(void)
|
||||||
{
|
{
|
||||||
|
@ -44,6 +53,59 @@ void eio_monitor_backend_del(Eio_Monitor *monitor)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static void
|
||||||
|
_eio_monitor_fallback_heavy_cb(void *data, Ecore_Thread *thread)
|
||||||
|
{
|
||||||
|
/* FIXME : copy ecore_file_monitor_poll here */
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
_eio_monitor_fallback_end_cb(void *data, Ecore_Thread *thread)
|
||||||
|
{
|
||||||
|
Eio_Monitor_Backend *backend = data;
|
||||||
|
|
||||||
|
backend->work = NULL;
|
||||||
|
backend->timer = ecore_timer_add(60.0, _eio_monitor_fallback_timer_cb, backend);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
_eio_monitor_fallback_cancel_cb(void *data, Ecore_Thread *thread)
|
||||||
|
{
|
||||||
|
Eio_Monitor_Backend *backend = data;
|
||||||
|
|
||||||
|
backend->work = NULL;
|
||||||
|
if (backend->delete_me)
|
||||||
|
{
|
||||||
|
free(backend);
|
||||||
|
return ;
|
||||||
|
}
|
||||||
|
backend->timer = ecore_timer_add(60.0, _eio_monitor_fallback_timer_cb, backend);
|
||||||
|
}
|
||||||
|
|
||||||
|
static Eina_Bool
|
||||||
|
_eio_monitor_fallback_idler_cb(void *data)
|
||||||
|
{
|
||||||
|
Eio_Monitor_Backend *backend = data;
|
||||||
|
|
||||||
|
backend->idler = NULL;
|
||||||
|
backend->work = ecore_thread_run(_eio_monitor_fallback_heavy_cb,
|
||||||
|
_eio_monitor_fallback_end_cb,
|
||||||
|
_eio_monitor_fallback_cancel_cb,
|
||||||
|
backend);
|
||||||
|
return EINA_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static Eina_Bool
|
||||||
|
_eio_monitor_fallback_timer_cb(void *data)
|
||||||
|
{
|
||||||
|
Eio_Monitor_Backend *backend = data;
|
||||||
|
|
||||||
|
backend->timer = NULL;
|
||||||
|
backend->idler = ecore_idler_add(_eio_monitor_fallback_idler_cb, backend);
|
||||||
|
|
||||||
|
return EINA_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
eio_monitor_fallback_init(void)
|
eio_monitor_fallback_init(void)
|
||||||
{
|
{
|
||||||
|
@ -55,11 +117,40 @@ eio_monitor_fallback_shutdown(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
eio_monitor_fallback_add(Eio_Monitor *monitor __UNUSED__)
|
eio_monitor_fallback_add(Eio_Monitor *monitor)
|
||||||
{
|
{
|
||||||
|
Eio_Monitor_Backend *backend;
|
||||||
|
|
||||||
|
monitor->backend = NULL;
|
||||||
|
|
||||||
|
backend = calloc(1, sizeof (Eio_Monitor_Backend));
|
||||||
|
if (!backend) return ;
|
||||||
|
|
||||||
|
backend->parent = monitor;
|
||||||
|
monitor->backend = backend;
|
||||||
|
backend->timer = ecore_timer_add(60.0, _eio_monitor_fallback_timer_cb, backend);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
eio_monitor_fallback_del(Eio_Monitor *monitor __UNUSED__)
|
eio_monitor_fallback_del(Eio_Monitor *monitor)
|
||||||
{
|
{
|
||||||
|
Eio_Monitor_Backend *backend;
|
||||||
|
|
||||||
|
backend = monitor->backend;
|
||||||
|
monitor->backend = NULL;
|
||||||
|
|
||||||
|
if (!backend) return ;
|
||||||
|
|
||||||
|
backend->parent = NULL;
|
||||||
|
if (backend->timer) ecore_timer_del(backend->timer);
|
||||||
|
backend->timer = NULL;
|
||||||
|
if (backend->idler) ecore_idler_del(backend->idler);
|
||||||
|
backend->idler = NULL;
|
||||||
|
if (backend->work)
|
||||||
|
{
|
||||||
|
backend->delete_me = EINA_TRUE;
|
||||||
|
ecore_thread_cancel(backend->work);
|
||||||
|
return ;
|
||||||
|
}
|
||||||
|
free(backend);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue