/* Scans the list of missing subscriptions checking if they * are available yet. */ static gboolean im_scan_missing (gpointer user_data) { GList *nolonger_missing = NULL; GList *l; G_LOCK (inotify_lock); IM_W ("scanning missing list with %d items\n", g_list_length (missing_sub_list)); for (l = missing_sub_list; l; l = l->next) { inotify_sub *sub = l->data; gboolean not_m = FALSE; IM_W ("checking %p\n", sub); g_assert (sub); g_assert (sub->dirname); not_m = _ip_start_watching (sub); if (not_m) { missing_cb (sub); IM_W ("removed %s from missing list\n", sub->dirname); /* We have to build a list of list nodes to remove from the * missing_sub_list. We do the removal outside of this loop. */ nolonger_missing = g_list_prepend (nolonger_missing, l); } } for (l = nolonger_missing; l ; l = l->next) { GList *llink = l->data; missing_sub_list = g_list_remove_link (missing_sub_list, llink); g_list_free_1 (llink); } g_list_free (nolonger_missing); /* If the missing list is now empty, we disable the timeout */ if (missing_sub_list == NULL) { scan_missing_running = FALSE; G_UNLOCK (inotify_lock); return FALSE; } else { G_UNLOCK (inotify_lock); return TRUE; } }
/* inotify_lock must be held before calling */ void im_rm (ih_sub_t *sub) { GList *link; link = g_list_find (missing_sub_list, sub); if (!link) { IM_W("asked to remove %s from missing list but it isn't on the list!\n", sub->pathname); return; } IM_W("removing %s from missing list\n", sub->dirname); missing_sub_list = g_list_remove_link (missing_sub_list, link); g_list_free_1 (link); }
/* inotify_lock must be held before calling */ void im_add (ih_sub_t *sub) { if (g_list_find (missing_sub_list, sub)) { IM_W("asked to add %s to missing list but it's already on the list!\n", sub->pathname); return; } IM_W("adding %s to missing list\n", sub->dirname); missing_sub_list = g_list_prepend (missing_sub_list, sub); /* If the timeout is turned off, we turn it back on */ if (!scan_missing_running) { scan_missing_running = TRUE; g_timeout_add (SCAN_MISSING_TIME, im_scan_missing, NULL); } }
/* inotify_lock must be held before calling */ void _im_add (inotify_sub *sub) { if (g_list_find (missing_sub_list, sub)) { IM_W ("asked to add %s to missing list but it's already on the list!\n", sub->dirname); return; } IM_W ("adding %s to missing list\n", sub->dirname); missing_sub_list = g_list_prepend (missing_sub_list, sub); /* If the timeout is turned off, we turn it back on */ if (!scan_missing_running) { GSource *source; scan_missing_running = TRUE; source = g_timeout_source_new_seconds (SCAN_MISSING_TIME); g_source_set_callback (source, im_scan_missing, NULL, NULL); g_source_attach (source, GLIB_PRIVATE_CALL (g_get_worker_context) ()); g_source_unref (source); } }