[tracker-miners/wip/carlosg/speed-track: 17/22] libtracker-miner: Pass GFileInfo via TrackerFileNotifier::created/updated
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker-miners/wip/carlosg/speed-track: 17/22] libtracker-miner: Pass GFileInfo via TrackerFileNotifier::created/updated
- Date: Thu, 22 Oct 2020 14:45:56 +0000 (UTC)
commit d95dcd8c6b0133bef3fd53a15b9d787e703e7c9e
Author: Carlos Garnacho <carlosg gnome org>
Date: Sat Oct 17 17:32:53 2020 +0200
libtracker-miner: Pass GFileInfo via TrackerFileNotifier::created/updated
We are duplicating work, we have the TrackerCrawler inspecting every folder
and file, just to queue changed files, and then we go through these again
querying info individually.
This can be streamlined by pushing the GFileInfos from the TrackerCrawler
instead, so we don't need to query that info again. This commit just
does one step forward, letting this information available outside the
TrackerFileNotifier.
src/libtracker-miner/tracker-file-notifier.c | 34 ++++++++++++----------
src/libtracker-miner/tracker-file-notifier.h | 4 ++-
src/libtracker-miner/tracker-miner-fs.c | 8 ++---
.../libtracker-miner/tracker-file-notifier-test.c | 4 +--
4 files changed, 28 insertions(+), 22 deletions(-)
---
diff --git a/src/libtracker-miner/tracker-file-notifier.c b/src/libtracker-miner/tracker-file-notifier.c
index fdc870d5d..efd1e8096 100644
--- a/src/libtracker-miner/tracker-file-notifier.c
+++ b/src/libtracker-miner/tracker-file-notifier.c
@@ -267,22 +267,26 @@ file_notifier_notify (GFile *file,
gpointer user_data)
{
TrackerFileNotifier *notifier;
+ TrackerFileNotifierPrivate *priv;
gboolean stop = FALSE;
- gboolean is_dir;
notifier = user_data;
- is_dir = file_data->is_dir_in_disk;
+ priv = tracker_file_notifier_get_instance_private (notifier);
if (file_data->state == FILE_STATE_DELETE) {
/* In store but not in disk, delete */
- g_signal_emit (notifier, signals[FILE_DELETED], 0, file, is_dir);
+ g_signal_emit (notifier, signals[FILE_DELETED], 0, file,
+ file_data->is_dir_in_store);
stop = TRUE;
} else if (file_data->state == FILE_STATE_CREATE) {
/* In disk but not in store, create */
- g_signal_emit (notifier, signals[FILE_CREATED], 0, file, is_dir);
+ g_signal_emit (notifier, signals[FILE_CREATED], 0, file,
+ tracker_crawler_get_file_info (priv->crawler, file));
} else if (file_data->state == FILE_STATE_UPDATE) {
/* File changed, update */
- g_signal_emit (notifier, signals[FILE_UPDATED], 0, file, FALSE, is_dir);
+ g_signal_emit (notifier, signals[FILE_UPDATED], 0, file,
+ tracker_crawler_get_file_info (priv->crawler, file),
+ FALSE);
}
return stop;
@@ -934,7 +938,7 @@ monitor_item_created_cb (TrackerMonitor *monitor,
}
}
- g_signal_emit (notifier, signals[FILE_CREATED], 0, file, is_directory);
+ g_signal_emit (notifier, signals[FILE_CREATED], 0, file, NULL);
}
static void
@@ -954,7 +958,7 @@ monitor_item_updated_cb (TrackerMonitor *monitor,
return;
}
- g_signal_emit (notifier, signals[FILE_UPDATED], 0, file, FALSE, is_directory);
+ g_signal_emit (notifier, signals[FILE_UPDATED], 0, file, NULL, FALSE);
}
static void
@@ -974,7 +978,7 @@ monitor_item_attribute_updated_cb (TrackerMonitor *monitor,
return;
}
- g_signal_emit (notifier, signals[FILE_UPDATED], 0, file, TRUE, is_directory);
+ g_signal_emit (notifier, signals[FILE_UPDATED], 0, file, NULL, TRUE);
}
static void
@@ -1130,7 +1134,7 @@ monitor_item_moved_cb (TrackerMonitor *monitor,
/* Source file was not stored, check dest file as new */
if (!is_directory || !dest_is_recursive) {
- g_signal_emit (notifier, signals[FILE_CREATED], 0, other_file,
is_directory);
+ g_signal_emit (notifier, signals[FILE_CREATED], 0, other_file, NULL);
} else if (is_directory) {
/* Crawl dest directory */
notifier_queue_root (notifier, other_file, flags, FALSE);
@@ -1175,7 +1179,7 @@ monitor_item_moved_cb (TrackerMonitor *monitor,
g_signal_emit (notifier, signals[FILE_MOVED], 0, file, other_file, is_directory);
if (extension_changed (file, other_file))
- g_signal_emit (notifier, signals[FILE_UPDATED], 0, other_file, FALSE,
is_directory);
+ g_signal_emit (notifier, signals[FILE_UPDATED], 0, other_file, NULL, FALSE);
}
g_object_unref (other_file);
@@ -1242,7 +1246,7 @@ indexing_tree_directory_removed (TrackerIndexingTree *indexing_tree,
} else if (tracker_indexing_tree_file_is_root (indexing_tree,
parent)) {
g_signal_emit (notifier, signals[FILE_CREATED],
- 0, directory, TRUE);
+ 0, directory, NULL);
}
g_object_unref (parent);
@@ -1313,8 +1317,8 @@ indexing_tree_child_updated (TrackerIndexingTree *indexing_tree,
notifier_queue_root (notifier, child, flags, FALSE);
} else if (tracker_indexing_tree_file_is_indexable (priv->indexing_tree,
child, child_info)) {
- g_signal_emit (notifier, signals[FILE_UPDATED], 0, child, FALSE,
- child_type == G_FILE_TYPE_DIRECTORY);
+ g_signal_emit (notifier, signals[FILE_UPDATED], 0,
+ child, child_info, FALSE);
}
}
@@ -1491,7 +1495,7 @@ tracker_file_notifier_class_init (TrackerFileNotifierClass *klass)
NULL, NULL,
NULL,
G_TYPE_NONE,
- 2, G_TYPE_FILE, G_TYPE_BOOLEAN);
+ 2, G_TYPE_FILE, G_TYPE_FILE_INFO);
signals[FILE_UPDATED] =
g_signal_new ("file-updated",
G_TYPE_FROM_CLASS (klass),
@@ -1501,7 +1505,7 @@ tracker_file_notifier_class_init (TrackerFileNotifierClass *klass)
NULL, NULL,
NULL,
G_TYPE_NONE,
- 3, G_TYPE_FILE, G_TYPE_BOOLEAN, G_TYPE_BOOLEAN);
+ 3, G_TYPE_FILE, G_TYPE_FILE_INFO, G_TYPE_BOOLEAN);
signals[FILE_DELETED] =
g_signal_new ("file-deleted",
G_TYPE_FROM_CLASS (klass),
diff --git a/src/libtracker-miner/tracker-file-notifier.h b/src/libtracker-miner/tracker-file-notifier.h
index f5d8cf0bb..e563f3320 100644
--- a/src/libtracker-miner/tracker-file-notifier.h
+++ b/src/libtracker-miner/tracker-file-notifier.h
@@ -51,9 +51,11 @@ struct _TrackerFileNotifierClass {
GObjectClass parent_class;
void (* file_created) (TrackerFileNotifier *notifier,
- GFile *file);
+ GFile *file,
+ GFileInfo *info);
void (* file_updated) (TrackerFileNotifier *notifier,
GFile *file,
+ GFileInfo *info,
gboolean attributes_only);
void (* file_deleted) (TrackerFileNotifier *notifier,
GFile *file);
diff --git a/src/libtracker-miner/tracker-miner-fs.c b/src/libtracker-miner/tracker-miner-fs.c
index d368d5532..b3db85ebf 100644
--- a/src/libtracker-miner/tracker-miner-fs.c
+++ b/src/libtracker-miner/tracker-miner-fs.c
@@ -211,7 +211,7 @@ static void indexing_tree_directory_removed (TrackerIndexingTree
gpointer user_data);
static void file_notifier_file_created (TrackerFileNotifier *notifier,
GFile *file,
- gboolean is_dir,
+ GFileInfo *info,
gpointer user_data);
static void file_notifier_file_deleted (TrackerFileNotifier *notifier,
GFile *file,
@@ -219,8 +219,8 @@ static void file_notifier_file_deleted (TrackerFileNotifier
gpointer user_data);
static void file_notifier_file_updated (TrackerFileNotifier *notifier,
GFile *file,
+ GFileInfo *info,
gboolean attributes_only,
- gboolean is_dir,
gpointer user_data);
static void file_notifier_file_moved (TrackerFileNotifier *notifier,
GFile *source,
@@ -2011,7 +2011,7 @@ miner_fs_queue_event (TrackerMinerFS *fs,
static void
file_notifier_file_created (TrackerFileNotifier *notifier,
GFile *file,
- gboolean is_dir,
+ GFileInfo *info,
gpointer user_data)
{
TrackerMinerFS *fs = user_data;
@@ -2044,8 +2044,8 @@ file_notifier_file_deleted (TrackerFileNotifier *notifier,
static void
file_notifier_file_updated (TrackerFileNotifier *notifier,
GFile *file,
+ GFileInfo *info,
gboolean attributes_only,
- gboolean is_dir,
gpointer user_data)
{
TrackerMinerFS *fs = user_data;
diff --git a/tests/libtracker-miner/tracker-file-notifier-test.c
b/tests/libtracker-miner/tracker-file-notifier-test.c
index cc78e48b3..4451ef251 100644
--- a/tests/libtracker-miner/tracker-file-notifier-test.c
+++ b/tests/libtracker-miner/tracker-file-notifier-test.c
@@ -122,7 +122,7 @@ perform_file_operation (TestCommonContext *fixture,
static void
file_notifier_file_created_cb (TrackerFileNotifier *notifier,
GFile *file,
- gboolean is_dir,
+ GFileInfo *info,
gpointer user_data)
{
TestCommonContext *fixture = user_data;
@@ -143,8 +143,8 @@ file_notifier_file_created_cb (TrackerFileNotifier *notifier,
static void
file_notifier_file_updated_cb (TrackerFileNotifier *notifier,
GFile *file,
+ GFileInfo *info,
gboolean attributes_only,
- gboolean is_dir,
gpointer user_data)
{
TestCommonContext *fixture = user_data;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]