[tracker/miner-fs-refactor: 20/127] tracker-miner-fs: Set TrackerIndexingTree filters in TrackerMinerFiles
- From: Martyn James Russell <mr src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/miner-fs-refactor: 20/127] tracker-miner-fs: Set TrackerIndexingTree filters in TrackerMinerFiles
- Date: Wed, 7 Dec 2011 10:38:38 +0000 (UTC)
commit 4f0b142abeafb1864016cdec7223e41de0265e8b
Author: Carlos Garnacho <carlos lanedo com>
Date: Thu Sep 8 16:27:25 2011 +0200
tracker-miner-fs: Set TrackerIndexingTree filters in TrackerMinerFiles
src/miners/fs/tracker-miner-files.c | 48 +++++++++++++++++++++++++++++++++++
1 files changed, 48 insertions(+), 0 deletions(-)
---
diff --git a/src/miners/fs/tracker-miner-files.c b/src/miners/fs/tracker-miner-files.c
index 47ae5b1..c264308 100644
--- a/src/miners/fs/tracker-miner-files.c
+++ b/src/miners/fs/tracker-miner-files.c
@@ -217,6 +217,8 @@ static void miner_files_add_removable_or_optical_directory (TrackerMinerF
static void extractor_process_failsafe (TrackerMinerFiles *miner);
+static void miner_files_update_filters (TrackerMinerFiles *files);
+
static GInitableIface* miner_files_initable_parent_iface;
@@ -311,6 +313,7 @@ miner_files_initable_init (GInitable *initable,
{
TrackerMinerFiles *mf;
TrackerMinerFS *fs;
+ TrackerIndexingTree *indexing_tree;
GError *inner_error = NULL;
GSList *mounts = NULL;
GSList *dirs;
@@ -318,6 +321,10 @@ miner_files_initable_init (GInitable *initable,
mf = TRACKER_MINER_FILES (initable);
fs = TRACKER_MINER_FS (initable);
+ indexing_tree = tracker_miner_fs_get_indexing_tree (fs);
+ tracker_indexing_tree_set_filter_hidden (indexing_tree, TRUE);
+
+ miner_files_update_filters (mf);
/* Chain up parent's initable callback before calling child's one */
if (!miner_files_initable_parent_iface->init (initable, cancellable, &inner_error)) {
@@ -1506,6 +1513,45 @@ low_disk_space_limit_cb (GObject *gobject,
}
static void
+indexing_tree_update_filter (TrackerIndexingTree *indexing_tree,
+ TrackerFilterType filter,
+ GSList *new_elems)
+{
+ tracker_indexing_tree_clear_filters (indexing_tree, filter);
+
+ while (new_elems) {
+ tracker_indexing_tree_add_filter (indexing_tree, filter,
+ new_elems->data);
+ new_elems = new_elems->next;
+ }
+}
+
+static void
+miner_files_update_filters (TrackerMinerFiles *files)
+{
+ TrackerIndexingTree *indexing_tree;
+ GSList *list;
+
+ indexing_tree = tracker_miner_fs_get_indexing_tree (TRACKER_MINER_FS (files));
+
+ /* Ignored files */
+ list = tracker_config_get_ignored_files (files->private->config);
+ indexing_tree_update_filter (indexing_tree, TRACKER_FILTER_FILE, list);
+
+ /* Ignored directories */
+ list = tracker_config_get_ignored_directories (files->private->config);
+ indexing_tree_update_filter (indexing_tree,
+ TRACKER_FILTER_DIRECTORY,
+ list);
+
+ /* Directories with content */
+ list = tracker_config_get_ignored_directories_with_content (files->private->config);
+ indexing_tree_update_filter (indexing_tree,
+ TRACKER_FILTER_PARENT_DIRECTORY,
+ list);
+}
+
+static void
update_directories_from_new_config (TrackerMinerFS *mf,
GSList *new_dirs,
GSList *old_dirs,
@@ -1620,6 +1666,8 @@ miner_files_force_recheck_idle (gpointer user_data)
{
TrackerMinerFiles *miner_files = user_data;
+ miner_files_update_filters (miner_files);
+
/* Recheck all directories for compliance with the new config */
tracker_miner_fs_force_recheck (TRACKER_MINER_FS (miner_files));
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]