[tracker] libtracker-miner: When a moved dir event detected, cancel all monitors in the dir
- From: Aleksander Morgado <aleksm src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker] libtracker-miner: When a moved dir event detected, cancel all monitors in the dir
- Date: Fri, 17 Dec 2010 17:23:47 +0000 (UTC)
commit 41724677fa44110f195c9a4c2f0f5ee85ec923cb
Author: Aleksander Morgado <aleksander lanedo com>
Date: Mon Dec 13 13:44:22 2010 +0100
libtracker-miner: When a moved dir event detected, cancel all monitors in the dir
src/libtracker-miner/tracker-monitor.c | 44 +++++++++++++++++++++++++++++--
1 files changed, 41 insertions(+), 3 deletions(-)
---
diff --git a/src/libtracker-miner/tracker-monitor.c b/src/libtracker-miner/tracker-monitor.c
index ff5c1fc..31eb12a 100644
--- a/src/libtracker-miner/tracker-monitor.c
+++ b/src/libtracker-miner/tracker-monitor.c
@@ -117,6 +117,8 @@ static void directory_monitor_cancel (GFileMonitor *dir_monito
static void event_data_free (gpointer data);
static void emit_signal_for_event (TrackerMonitor *monitor,
EventData *event_data);
+static gboolean monitor_cancel_recursively (TrackerMonitor *monitor,
+ GFile *file);
static guint signals[LAST_SIGNAL] = { 0, };
@@ -671,15 +673,20 @@ emit_signal_for_event (TrackerMonitor *monitor,
event_data->is_directory ? "DIRECTORY" : "FILE",
event_data->file_uri,
event_data->other_file_uri);
+ /* Note that in any case we should be moving the monitors
+ * here to the new place, as the new place may be ignored.
+ * We should leave this to the upper layers. But one thing
+ * we must do is actually CANCEL all these monitors. */
+ if (event_data->is_directory) {
+ monitor_cancel_recursively (monitor,
+ event_data->file);
+ }
g_signal_emit (monitor,
signals[ITEM_MOVED], 0,
event_data->file,
event_data->other_file,
event_data->is_directory,
TRUE);
- /* Note that in any case we should be moving the monitors
- * here to the new place, as the new place may be ignored.
- * We should leave this to the upper layers. */
break;
case G_FILE_MONITOR_EVENT_PRE_UNMOUNT:
@@ -1364,6 +1371,37 @@ tracker_monitor_remove_recursively (TrackerMonitor *monitor,
return items_removed > 0;
}
+static gboolean
+monitor_cancel_recursively (TrackerMonitor *monitor,
+ GFile *file)
+{
+ GHashTableIter iter;
+ gpointer iter_file, iter_file_monitor;
+ guint items_cancelled = 0;
+
+ g_return_val_if_fail (TRACKER_IS_MONITOR (monitor), FALSE);
+ g_return_val_if_fail (G_IS_FILE (file), FALSE);
+
+ g_hash_table_iter_init (&iter, monitor->private->monitors);
+ while (g_hash_table_iter_next (&iter, &iter_file, &iter_file_monitor)) {
+ gchar *uri;
+
+ if (!g_file_has_prefix (iter_file, file) &&
+ !g_file_equal (iter_file, file)) {
+ continue;
+ }
+
+ uri = g_file_get_uri (iter_file);
+ g_file_monitor_cancel (G_FILE_MONITOR (iter_file_monitor));
+ g_debug ("Cancelled monitor for path:'%s'", uri);
+ g_free (uri);
+
+ items_cancelled++;
+ }
+
+ return items_cancelled > 0;
+}
+
gboolean
tracker_monitor_is_watched (TrackerMonitor *monitor,
GFile *file)
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]