summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/libtracker-miner/tracker-miner-fs.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/src/libtracker-miner/tracker-miner-fs.c b/src/libtracker-miner/tracker-miner-fs.c
index ef53ff44a..72bba02e9 100644
--- a/src/libtracker-miner/tracker-miner-fs.c
+++ b/src/libtracker-miner/tracker-miner-fs.c
@@ -2884,6 +2884,30 @@ check_item_queues (TrackerMinerFS *fs,
cancel_writeback_task (fs, file);
}
+ if (tracker_file_notifier_get_file_type (fs->priv->file_notifier,
+ file) == G_FILE_TYPE_DIRECTORY) {
+ if (tracker_priority_queue_foreach_remove (fs->priv->items_updated,
+ (GEqualFunc) g_file_has_parent,
+ file,
+ (GDestroyNotify) g_object_unref)) {
+ g_debug (" Deleting previous unhandled UPDATED events on children");
+ }
+
+ if (tracker_priority_queue_foreach_remove (fs->priv->items_created,
+ (GEqualFunc) g_file_has_parent,
+ file,
+ (GDestroyNotify) g_object_unref)) {
+ g_debug (" Deleting previous unhandled CREATED events on children");
+ }
+
+ if (tracker_priority_queue_foreach_remove (fs->priv->items_deleted,
+ (GEqualFunc) g_file_has_parent,
+ file,
+ (GDestroyNotify) g_object_unref)) {
+ g_debug (" Deleting previous unhandled DELETED events on children");
+ }
+ }
+
/* Remove all previous updates */
if (tracker_priority_queue_foreach_remove (fs->priv->items_updated,
(GEqualFunc) g_file_equal,