[tracker-miners/wip/carlosg/speed-track: 37/40] libtracker-miner: Add file-attributes argument to TrackerFileNotifier




commit 796acb0c90cd8f0fc16f6860689ef12b86f45676
Author: Carlos Garnacho <carlosg gnome org>
Date:   Sat Oct 17 17:59:08 2020 +0200

    libtracker-miner: Add file-attributes argument to TrackerFileNotifier
    
    We want to specify file attributes up in the miner, so add a way to
    let these further down to the TrackerCrawler.

 src/libtracker-miner/tracker-file-notifier.c       | 28 ++++++++++++++++++----
 src/libtracker-miner/tracker-file-notifier.h       |  3 ++-
 src/libtracker-miner/tracker-miner-fs.c            |  4 +++-
 .../libtracker-miner/tracker-file-notifier-test.c  |  3 ++-
 4 files changed, 30 insertions(+), 8 deletions(-)
---
diff --git a/src/libtracker-miner/tracker-file-notifier.c b/src/libtracker-miner/tracker-file-notifier.c
index 0923a8f94..60ab41e30 100644
--- a/src/libtracker-miner/tracker-file-notifier.c
+++ b/src/libtracker-miner/tracker-file-notifier.c
@@ -33,7 +33,8 @@ enum {
        PROP_0,
        PROP_INDEXING_TREE,
        PROP_DATA_PROVIDER,
-       PROP_CONNECTION
+       PROP_CONNECTION,
+       PROP_FILE_ATTRIBUTES,
 };
 
 enum {
@@ -98,6 +99,7 @@ typedef struct {
        TrackerSparqlStatement *content_query;
 
        GTimer *timer;
+       gchar *file_attributes;
 
        /* List of pending directory
         * trees to get data from
@@ -135,6 +137,9 @@ tracker_file_notifier_set_property (GObject      *object,
        case PROP_CONNECTION:
                priv->connection = g_value_dup_object (value);
                break;
+       case PROP_FILE_ATTRIBUTES:
+               priv->file_attributes = g_value_dup_string (value);
+               break;
        default:
                G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
                break;
@@ -161,6 +166,9 @@ tracker_file_notifier_get_property (GObject    *object,
        case PROP_CONNECTION:
                g_value_set_object (value, priv->connection);
                break;
+       case PROP_FILE_ATTRIBUTES:
+               g_value_set_string (value, priv->file_attributes);
+               break;
        default:
                G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
                break;
@@ -1341,6 +1349,7 @@ tracker_file_notifier_finalize (GObject *object)
 
        g_queue_clear (&priv->queue);
        g_hash_table_destroy (priv->cache);
+       g_free (priv->file_attributes);
 
        if (priv->indexing_tree) {
                g_object_unref (priv->indexing_tree);
@@ -1459,9 +1468,7 @@ tracker_file_notifier_constructed (GObject *object)
        tracker_crawler_set_check_func (priv->crawler,
                                        crawler_check_func,
                                        object, NULL);
-       tracker_crawler_set_file_attributes (priv->crawler,
-                                            G_FILE_ATTRIBUTE_TIME_MODIFIED ","
-                                            G_FILE_ATTRIBUTE_STANDARD_TYPE);
+       tracker_crawler_set_file_attributes (priv->crawler, priv->file_attributes);
 
        check_disable_monitor (TRACKER_FILE_NOTIFIER (object));
 }
@@ -1594,6 +1601,15 @@ tracker_file_notifier_class_init (TrackerFileNotifierClass *klass)
                                                              G_PARAM_READWRITE |
                                                              G_PARAM_CONSTRUCT_ONLY |
                                                              G_PARAM_STATIC_STRINGS));
+       g_object_class_install_property (object_class,
+                                        PROP_FILE_ATTRIBUTES,
+                                        g_param_spec_string ("file-attributes",
+                                                             "File attributes",
+                                                             "File attributes",
+                                                             NULL,
+                                                             G_PARAM_READWRITE |
+                                                             G_PARAM_CONSTRUCT_ONLY |
+                                                             G_PARAM_STATIC_STRINGS));
 }
 
 static void
@@ -1634,7 +1650,8 @@ tracker_file_notifier_init (TrackerFileNotifier *notifier)
 TrackerFileNotifier *
 tracker_file_notifier_new (TrackerIndexingTree     *indexing_tree,
                            TrackerDataProvider     *data_provider,
-                           TrackerSparqlConnection *connection)
+                           TrackerSparqlConnection *connection,
+                           const gchar             *file_attributes)
 {
        g_return_val_if_fail (TRACKER_IS_INDEXING_TREE (indexing_tree), NULL);
 
@@ -1642,6 +1659,7 @@ tracker_file_notifier_new (TrackerIndexingTree     *indexing_tree,
                             "indexing-tree", indexing_tree,
                             "data-provider", data_provider,
                             "connection", connection,
+                            "file-attributes", file_attributes,
                             NULL);
 }
 
diff --git a/src/libtracker-miner/tracker-file-notifier.h b/src/libtracker-miner/tracker-file-notifier.h
index e563f3320..c6081bfda 100644
--- a/src/libtracker-miner/tracker-file-notifier.h
+++ b/src/libtracker-miner/tracker-file-notifier.h
@@ -81,7 +81,8 @@ GType         tracker_file_notifier_get_type     (void) G_GNUC_CONST;
 TrackerFileNotifier *
               tracker_file_notifier_new          (TrackerIndexingTree     *indexing_tree,
                                                   TrackerDataProvider     *data_provider,
-                                                  TrackerSparqlConnection *connection);
+                                                  TrackerSparqlConnection *connection,
+                                                  const gchar             *file_attributes);
 
 gboolean      tracker_file_notifier_start        (TrackerFileNotifier     *notifier);
 void          tracker_file_notifier_stop         (TrackerFileNotifier     *notifier);
diff --git a/src/libtracker-miner/tracker-miner-fs.c b/src/libtracker-miner/tracker-miner-fs.c
index 85a55efac..128769deb 100644
--- a/src/libtracker-miner/tracker-miner-fs.c
+++ b/src/libtracker-miner/tracker-miner-fs.c
@@ -653,7 +653,9 @@ miner_fs_initable_init (GInitable     *initable,
        /* Create the file notifier */
        priv->file_notifier = tracker_file_notifier_new (priv->indexing_tree,
                                                         priv->data_provider,
-                                                        tracker_miner_get_connection (TRACKER_MINER 
(initable)));
+                                                        tracker_miner_get_connection (TRACKER_MINER 
(initable)),
+                                                        G_FILE_ATTRIBUTE_TIME_MODIFIED ","
+                                                        G_FILE_ATTRIBUTE_STANDARD_TYPE);
 
        if (!priv->file_notifier) {
                g_set_error (error,
diff --git a/tests/libtracker-miner/tracker-file-notifier-test.c 
b/tests/libtracker-miner/tracker-file-notifier-test.c
index 4451ef251..211eb8d82 100644
--- a/tests/libtracker-miner/tracker-file-notifier-test.c
+++ b/tests/libtracker-miner/tracker-file-notifier-test.c
@@ -292,7 +292,8 @@ test_common_context_setup (TestCommonContext *fixture,
 
        fixture->main_loop = g_main_loop_new (NULL, FALSE);
        fixture->notifier = tracker_file_notifier_new (fixture->indexing_tree, FALSE,
-                                                      fixture->connection);
+                                                      fixture->connection,
+                                                      G_FILE_ATTRIBUTE_STANDARD_TYPE);
 
        g_signal_connect (fixture->notifier, "file-created",
                          G_CALLBACK (file_notifier_file_created_cb), fixture);


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]