[tracker] Make tracker_miner_fs_file_add() take a check_parents arg.
- From: Martyn James Russell <mr src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker] Make tracker_miner_fs_file_add() take a check_parents arg.
- Date: Tue, 24 Aug 2010 16:04:27 +0000 (UTC)
commit 7e64c76f876271a35b3b3ffc8b3dfd24a84e1983
Author: Carlos Garnacho <carlosg gnome org>
Date: Thu Aug 19 14:55:46 2010 +0200
Make tracker_miner_fs_file_add() take a check_parents arg.
src/libtracker-miner/tracker-miner-fs.c | 63 ++++++++++++++++++++++++++++-
src/libtracker-miner/tracker-miner-fs.h | 3 +-
src/miners/fs/tracker-main.c | 2 +-
src/miners/fs/tracker-miner-files-index.c | 2 +-
4 files changed, 66 insertions(+), 4 deletions(-)
---
diff --git a/src/libtracker-miner/tracker-miner-fs.c b/src/libtracker-miner/tracker-miner-fs.c
index 395e810..bfe7023 100644
--- a/src/libtracker-miner/tracker-miner-fs.c
+++ b/src/libtracker-miner/tracker-miner-fs.c
@@ -1218,6 +1218,30 @@ file_is_crawl_directory (TrackerMinerFS *fs,
return FALSE;
}
+static DirectoryData *
+find_config_directory (TrackerMinerFS *fs,
+ GFile *file)
+{
+ GList *dirs;
+
+ dirs = fs->private->config_directories;
+
+ while (dirs) {
+ DirectoryData *data;
+
+ data = dirs->data;
+ dirs = dirs->next;
+
+ if (g_file_equal (data->file, file) ||
+ (data->recurse && (g_file_has_prefix (file, data->file)))) {
+ return data;
+ }
+ }
+
+ return NULL;
+}
+
+
static void
ensure_iri_cache (TrackerMinerFS *fs,
GFile *file)
@@ -3571,7 +3595,8 @@ tracker_miner_fs_directory_remove_full (TrackerMinerFS *fs,
**/
void
tracker_miner_fs_file_add (TrackerMinerFS *fs,
- GFile *file)
+ GFile *file,
+ gboolean check_parents)
{
gboolean should_process;
gchar *path;
@@ -3588,6 +3613,42 @@ tracker_miner_fs_file_add (TrackerMinerFS *fs,
path);
if (should_process) {
+ if (check_parents) {
+ DirectoryData *data;
+ GFile *parent;
+ GList *parents = NULL, *p;
+
+ parent = g_file_get_parent (file);
+
+ if (!parent) {
+ return;
+ }
+
+ data = find_config_directory (fs, parent);
+
+ if (!data) {
+ return;
+ }
+
+ /* Add parent directories until we're past the config dir */
+ while (parent &&
+ !g_file_has_prefix (data->file, parent)) {
+ parents = g_list_prepend (parents, parent);
+ parent = g_file_get_parent (parent);
+ }
+
+ /* Last parent fetched is not added to the list */
+ if (parent) {
+ g_object_unref (parent);
+ }
+
+ for (p = parents; p; p = p->next) {
+ g_queue_push_tail (fs->private->items_updated, p->data);
+ }
+
+ g_list_free (parents);
+ }
+
g_queue_push_tail (fs->private->items_updated,
g_object_ref (file));
diff --git a/src/libtracker-miner/tracker-miner-fs.h b/src/libtracker-miner/tracker-miner-fs.h
index 2188d63..a959809 100644
--- a/src/libtracker-miner/tracker-miner-fs.h
+++ b/src/libtracker-miner/tracker-miner-fs.h
@@ -103,7 +103,8 @@ gboolean tracker_miner_fs_directory_remove (TrackerMinerFS *fs,
gboolean tracker_miner_fs_directory_remove_full (TrackerMinerFS *fs,
GFile *file);
void tracker_miner_fs_file_add (TrackerMinerFS *fs,
- GFile *file);
+ GFile *file,
+ gboolean check_parents);
void tracker_miner_fs_file_notify (TrackerMinerFS *fs,
GFile *file,
const GError *error);
diff --git a/src/miners/fs/tracker-main.c b/src/miners/fs/tracker-main.c
index 1d08403..676faad 100644
--- a/src/miners/fs/tracker-main.c
+++ b/src/miners/fs/tracker-main.c
@@ -636,7 +636,7 @@ main (gint argc, gchar *argv[])
file = g_file_new_for_commandline_arg (add_file);
miner_files = tracker_miner_files_new (NULL);
- tracker_miner_fs_file_add (TRACKER_MINER_FS (miner_files), file);
+ tracker_miner_fs_file_add (TRACKER_MINER_FS (miner_files), file, FALSE);
g_object_unref (file);
}
diff --git a/src/miners/fs/tracker-miner-files-index.c b/src/miners/fs/tracker-miner-files-index.c
index b725c0f..003c171 100644
--- a/src/miners/fs/tracker-miner-files-index.c
+++ b/src/miners/fs/tracker-miner-files-index.c
@@ -184,7 +184,7 @@ mime_types_cb (GObject *object,
url = tracker_sparql_cursor_get_string (cursor, 0, NULL);
file = g_file_new_for_uri (url);
- tracker_miner_fs_file_add (TRACKER_MINER_FS (mtd->miner_files), file);
+ tracker_miner_fs_file_add (TRACKER_MINER_FS (mtd->miner_files), file, FALSE);
g_object_unref (file);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]