[tracker/wip/carlosg/anonymous-nodes: 8/24] libtracker-data: Use TrackerProperty for predicate in tracker_data_*_statement()




commit 97220d940197421868d132c12564a20c8ad8496f
Author: Carlos Garnacho <carlosg gnome org>
Date:   Tue Sep 21 18:26:06 2021 +0200

    libtracker-data: Use TrackerProperty for predicate in tracker_data_*_statement()
    
    These strings may only be URIs identifying properties set in the ontology.
    Make it the caller's business to find the corresponding TrackerProperty.

 src/libtracker-data/tracker-data-manager.c |  45 +++-
 src/libtracker-data/tracker-data-update.c  | 325 +++++++++++++----------------
 src/libtracker-data/tracker-data-update.h  |   6 +-
 src/libtracker-data/tracker-sparql.c       |  27 ++-
 4 files changed, 213 insertions(+), 190 deletions(-)
---
diff --git a/src/libtracker-data/tracker-data-manager.c b/src/libtracker-data/tracker-data-manager.c
index ad14c468d..3f2e635bb 100644
--- a/src/libtracker-data/tracker-data-manager.c
+++ b/src/libtracker-data/tracker-data-manager.c
@@ -501,6 +501,8 @@ update_property_value (TrackerDataManager  *manager,
                        TrackerProperty     *property,
                        GError             **error_in)
 {
+       TrackerOntologies *ontologies;
+       TrackerProperty *pred;
        GError *error = NULL;
        gboolean needed = TRUE;
        gboolean is_new = FALSE;
@@ -521,6 +523,16 @@ update_property_value (TrackerDataManager  *manager,
                column_no = tracker_property_get_definition_column_no (property);
        }
 
+       ontologies = tracker_data_manager_get_ontologies (manager);
+       pred = tracker_ontologies_get_property_by_uri (ontologies, predicate);
+       if (!pred) {
+               g_set_error (error_in, TRACKER_SPARQL_ERROR,
+                            TRACKER_SPARQL_ERROR_UNKNOWN_PROPERTY,
+                            "Property '%s' not found in the ontology",
+                            predicate);
+               return FALSE;
+       }
+
        if (!is_new) {
                gchar *query = NULL;
                TrackerDBCursor *cursor;
@@ -557,7 +569,7 @@ update_property_value (TrackerDataManager  *manager,
 
                                if (!unsup_onto_err) {
                                        bytes = g_bytes_new (str, strlen (str) + 1);
-                                       tracker_data_delete_statement (manager->data_update, NULL, subject, 
predicate, bytes, &error);
+                                       tracker_data_delete_statement (manager->data_update, NULL, subject, 
pred, bytes, &error);
                                        g_bytes_unref (bytes);
 
                                        if (!error)
@@ -584,7 +596,7 @@ update_property_value (TrackerDataManager  *manager,
        if (!error && needed && object) {
                bytes = g_bytes_new (object, strlen (object) + 1);
                tracker_data_insert_statement (manager->data_update, NULL, subject,
-                                              predicate, bytes,
+                                              pred, bytes,
                                               &error);
                g_bytes_unref (bytes);
 
@@ -1440,7 +1452,8 @@ check_for_deleted_domain_index (TrackerDataManager *manager,
                                 TrackerClass       *class,
                                 GError            **error)
 {
-       TrackerProperty **last_domain_indexes;
+       TrackerProperty **last_domain_indexes, *property;
+       TrackerOntologies *ontologies;
        GSList *hfound = NULL, *deleted = NULL;
 
        last_domain_indexes = tracker_class_get_last_domain_indexes (class);
@@ -1449,6 +1462,11 @@ check_for_deleted_domain_index (TrackerDataManager *manager,
                return;
        }
 
+       ontologies = tracker_data_manager_get_ontologies (manager);
+       property = tracker_ontologies_get_property_by_uri (ontologies,
+                                                          TRACKER_PREFIX_NRL "domainIndex");
+       g_assert (property);
+
        while (*last_domain_indexes) {
                TrackerProperty *last_domain_index = *last_domain_indexes;
                gboolean found = FALSE;
@@ -1517,7 +1535,7 @@ check_for_deleted_domain_index (TrackerDataManager *manager,
                        bytes = g_bytes_new (uri, strlen (uri) + 1);
                        tracker_data_delete_statement (manager->data_update, NULL,
                                                       tracker_class_get_uri (class),
-                                                      TRACKER_PREFIX_NRL "domainIndex",
+                                                      property,
                                                       bytes,
                                                       error);
                        g_bytes_unref (bytes);
@@ -1641,8 +1659,10 @@ check_for_deleted_super_properties (TrackerDataManager  *manager,
                                     GError             **error)
 {
        TrackerProperty **last_super_properties;
+       TrackerOntologies *ontologies;
        GList *to_remove = NULL;
 
+       ontologies = tracker_data_manager_get_ontologies (manager);
        last_super_properties = tracker_property_get_last_super_properties (property);
 
        if (!last_super_properties) {
@@ -1683,12 +1703,21 @@ check_for_deleted_super_properties (TrackerDataManager  *manager,
                        const gchar *subject = tracker_property_get_uri (property);
                        GBytes *bytes;
 
+                       property = tracker_ontologies_get_property_by_uri (ontologies,
+                                                                          TRACKER_PREFIX_RDFS 
"subPropertyOf");
+                       if (!property) {
+                               g_set_error (error, TRACKER_SPARQL_ERROR,
+                                            TRACKER_SPARQL_ERROR_UNKNOWN_PROPERTY,
+                                            "Property '%s' not found in the ontology",
+                                            TRACKER_PREFIX_RDFS "subPropertyOf");
+                               return;
+                       }
+
                        tracker_property_del_super_property (property, prop_to_remove);
 
                        bytes = g_bytes_new (object, strlen (object) + 1);
                        tracker_data_delete_statement (manager->data_update, NULL, subject,
-                                                      TRACKER_PREFIX_RDFS "subPropertyOf",
-                                                      bytes, &n_error);
+                                                      property, bytes, &n_error);
                        g_bytes_unref (bytes);
 
                        if (!n_error) {
@@ -2229,11 +2258,11 @@ tracker_data_ontology_process_statement (TrackerDataManager *manager,
        if (tracker_property_get_is_new (property) ||
            tracker_property_get_multiple_values (property)) {
                tracker_data_insert_statement (manager->data_update, NULL,
-                                              subject, predicate, bytes,
+                                              subject, property, bytes,
                                               error);
        } else {
                tracker_data_update_statement (manager->data_update, NULL,
-                                              subject, predicate, bytes,
+                                              subject, property, bytes,
                                               error);
        }
 
diff --git a/src/libtracker-data/tracker-data-update.c b/src/libtracker-data/tracker-data-update.c
index 761e47a01..df05593f9 100644
--- a/src/libtracker-data/tracker-data-update.c
+++ b/src/libtracker-data/tracker-data-update.c
@@ -164,18 +164,18 @@ static gboolean update_resource_single (TrackerData      *data,
                                         GHashTable       *bnodes,
                                         GError          **error);
 
-void tracker_data_insert_statement_with_uri    (TrackerData  *data,
-                                                const gchar  *graph,
-                                                const gchar  *subject,
-                                                const gchar  *predicate,
-                                                GBytes       *object,
-                                                GError      **error);
-void tracker_data_insert_statement_with_string (TrackerData  *data,
-                                                const gchar  *graph,
-                                                const gchar  *subject,
-                                                const gchar  *predicate,
-                                                GBytes       *object,
-                                                GError      **error);
+void tracker_data_insert_statement_with_uri    (TrackerData      *data,
+                                                const gchar      *graph,
+                                                const gchar      *subject,
+                                                TrackerProperty  *predicate,
+                                                GBytes           *object,
+                                                GError          **error);
+void tracker_data_insert_statement_with_string (TrackerData      *data,
+                                                const gchar      *graph,
+                                                const gchar      *subject,
+                                                TrackerProperty  *predicate,
+                                                GBytes           *object,
+                                                GError          **error);
 
 
 void
@@ -2367,12 +2367,12 @@ resource_buffer_switch (TrackerData  *data,
 }
 
 void
-tracker_data_delete_statement (TrackerData  *data,
-                               const gchar  *graph,
-                               const gchar  *subject,
-                               const gchar  *predicate,
-                               GBytes       *object,
-                               GError      **error)
+tracker_data_delete_statement (TrackerData      *data,
+                               const gchar      *graph,
+                               const gchar      *subject,
+                               TrackerProperty  *predicate,
+                               GBytes           *object,
+                               GError          **error)
 {
        TrackerClass       *class;
        gint                subject_id = 0;
@@ -2399,7 +2399,8 @@ tracker_data_delete_statement (TrackerData  *data,
 
        object_str = g_bytes_get_data (object, NULL);
 
-       if (object && g_strcmp0 (predicate, TRACKER_PREFIX_RDF "type") == 0) {
+       if (object &&
+           predicate == tracker_ontologies_get_rdf_type (ontologies)) {
                class = tracker_ontologies_get_class_by_uri (ontologies, object_str);
                if (class != NULL) {
                        data->has_persistent = TRUE;
@@ -2410,19 +2411,11 @@ tracker_data_delete_statement (TrackerData  *data,
                                     "Class '%s' not found in the ontology", object_str);
                }
        } else {
-               gint pred_id = 0;
-               TrackerProperty *field;
+               gint pred_id;
 
-               field = tracker_ontologies_get_property_by_uri (ontologies, predicate);
-               if (field != NULL) {
-                       pred_id = tracker_property_get_id (field);
-                       data->has_persistent = TRUE;
-                       change = delete_metadata_decomposed (data, field, object, error);
-               } else {
-                       g_set_error (error, TRACKER_SPARQL_ERROR, TRACKER_SPARQL_ERROR_UNKNOWN_PROPERTY,
-                                    "Property '%s' not found in the ontology", predicate);
-                       return;
-               }
+               pred_id = tracker_property_get_id (predicate);
+               data->has_persistent = TRUE;
+               change = delete_metadata_decomposed (data, predicate, object, error);
 
                if (change) {
                        tracker_data_dispatch_delete_statement_callbacks (data,
@@ -2551,46 +2544,43 @@ tracker_data_delete_all (TrackerData  *data,
 }
 
 static gboolean
-delete_single_valued (TrackerData  *data,
-                      const gchar  *graph,
-                      const gchar  *subject,
-                      const gchar  *predicate,
-                      gboolean      super_is_single_valued,
-                      GError      **error)
-{
-       TrackerProperty *field, **super_properties;
-       TrackerOntologies *ontologies;
+delete_single_valued (TrackerData      *data,
+                      const gchar      *graph,
+                      const gchar      *subject,
+                      TrackerProperty  *predicate,
+                      gboolean          super_is_single_valued,
+                      GError          **error)
+{
+       TrackerProperty **super_properties;
        gboolean multiple_values;
 
-       ontologies = tracker_data_manager_get_ontologies (data->manager);
-       field = tracker_ontologies_get_property_by_uri (ontologies, predicate);
-       super_properties = tracker_property_get_super_properties (field);
-       multiple_values = tracker_property_get_multiple_values (field);
+       super_properties = tracker_property_get_super_properties (predicate);
+       multiple_values = tracker_property_get_multiple_values (predicate);
 
        if (super_is_single_valued && multiple_values) {
                cache_delete_all_values (data,
-                                        tracker_property_get_table_name (field),
-                                        tracker_property_get_name (field));
-               if (tracker_property_get_data_type (field) == TRACKER_PROPERTY_TYPE_RESOURCE) {
-                       if (!tracker_data_resource_unref_all (data, field, error))
+                                        tracker_property_get_table_name (predicate),
+                                        tracker_property_get_name (predicate));
+               if (tracker_property_get_data_type (predicate) == TRACKER_PROPERTY_TYPE_RESOURCE) {
+                       if (!tracker_data_resource_unref_all (data, predicate, error))
                                return FALSE;
                }
        } else if (!multiple_values) {
                GError *inner_error = NULL;
                GArray *old_values;
 
-               old_values = get_old_property_values (data, field, &inner_error);
+               old_values = get_old_property_values (data, predicate, &inner_error);
 
                if (old_values && old_values->len == 1) {
                        GValue *value;
 
                        value = &g_array_index (old_values, GValue, 0);
                        cache_delete_value (data,
-                                           tracker_property_get_table_name (field),
-                                           tracker_property_get_name (field),
+                                           tracker_property_get_table_name (predicate),
+                                           tracker_property_get_name (predicate),
                                            value,
                                            FALSE);
-                       if (tracker_property_get_data_type (field) == TRACKER_PROPERTY_TYPE_RESOURCE)
+                       if (tracker_property_get_data_type (predicate) == TRACKER_PROPERTY_TYPE_RESOURCE)
                                tracker_data_resource_unref (data, g_value_get_int64 (value), 
multiple_values);
                } else {
                        /* no need to error out if statement does not exist for any reason */
@@ -2600,7 +2590,7 @@ delete_single_valued (TrackerData  *data,
 
        while (*super_properties) {
                if (!delete_single_valued (data, graph, subject,
-                                          tracker_property_get_uri (*super_properties),
+                                          *super_properties,
                                           super_is_single_valued,
                                           error))
                        return FALSE;
@@ -2612,47 +2602,35 @@ delete_single_valued (TrackerData  *data,
 }
 
 void
-tracker_data_insert_statement (TrackerData  *data,
-                               const gchar  *graph,
-                               const gchar  *subject,
-                               const gchar  *predicate,
-                               GBytes       *object,
-                               GError      **error)
+tracker_data_insert_statement (TrackerData      *data,
+                               const gchar      *graph,
+                               const gchar      *subject,
+                               TrackerProperty  *predicate,
+                               GBytes           *object,
+                               GError          **error)
 {
-       TrackerProperty *property;
-       TrackerOntologies *ontologies;
-
        g_return_if_fail (subject != NULL);
        g_return_if_fail (predicate != NULL);
        g_return_if_fail (object != NULL);
        g_return_if_fail (data->in_transaction);
 
-       ontologies = tracker_data_manager_get_ontologies (data->manager);
-
-       property = tracker_ontologies_get_property_by_uri (ontologies, predicate);
-       if (property != NULL) {
-               if (tracker_property_get_data_type (property) == TRACKER_PROPERTY_TYPE_RESOURCE) {
-                       tracker_data_insert_statement_with_uri (data, graph, subject, predicate, object, 
error);
-               } else {
-                       tracker_data_insert_statement_with_string (data, graph, subject, predicate, object, 
error);
-               }
+       if (tracker_property_get_data_type (predicate) == TRACKER_PROPERTY_TYPE_RESOURCE) {
+               tracker_data_insert_statement_with_uri (data, graph, subject, predicate, object, error);
        } else {
-               g_set_error (error, TRACKER_SPARQL_ERROR, TRACKER_SPARQL_ERROR_UNKNOWN_PROPERTY,
-                            "Property '%s' not found in the ontology", predicate);
+               tracker_data_insert_statement_with_string (data, graph, subject, predicate, object, error);
        }
 }
 
 void
-tracker_data_insert_statement_with_uri (TrackerData  *data,
-                                        const gchar  *graph,
-                                        const gchar  *subject,
-                                        const gchar  *predicate,
-                                        GBytes       *object,
-                                        GError      **error)
+tracker_data_insert_statement_with_uri (TrackerData      *data,
+                                        const gchar      *graph,
+                                        const gchar      *subject,
+                                        TrackerProperty  *predicate,
+                                        GBytes           *object,
+                                        GError          **error)
 {
        GError          *actual_error = NULL;
        TrackerClass    *class;
-       TrackerProperty *property;
        gint             prop_id = 0;
        gboolean change = FALSE;
        TrackerOntologies *ontologies;
@@ -2663,21 +2641,11 @@ tracker_data_insert_statement_with_uri (TrackerData  *data,
        g_return_if_fail (object != NULL);
        g_return_if_fail (data->in_transaction);
 
-       ontologies = tracker_data_manager_get_ontologies (data->manager);
+       g_assert (tracker_property_get_data_type (predicate) ==
+                 TRACKER_PROPERTY_TYPE_RESOURCE);
 
-       property = tracker_ontologies_get_property_by_uri (ontologies, predicate);
-       if (property == NULL) {
-               g_set_error (error, TRACKER_SPARQL_ERROR, TRACKER_SPARQL_ERROR_UNKNOWN_PROPERTY,
-                            "Property '%s' not found in the ontology", predicate);
-               return;
-       } else {
-               if (tracker_property_get_data_type (property) != TRACKER_PROPERTY_TYPE_RESOURCE) {
-                       g_set_error (error, TRACKER_SPARQL_ERROR, TRACKER_SPARQL_ERROR_TYPE,
-                                    "Property '%s' does not accept URIs", predicate);
-                       return;
-               }
-               prop_id = tracker_property_get_id (property);
-       }
+       ontologies = tracker_data_manager_get_ontologies (data->manager);
+       prop_id = tracker_property_get_id (predicate);
 
        data->has_persistent = TRUE;
 
@@ -2686,7 +2654,7 @@ tracker_data_insert_statement_with_uri (TrackerData  *data,
 
        object_str = g_bytes_get_data (object, NULL);
 
-       if (property == tracker_ontologies_get_rdf_type (ontologies)) {
+       if (predicate == tracker_ontologies_get_rdf_type (ontologies)) {
                /* handle rdf:type statements specially to
                   cope with inference and insert blank rows */
                class = tracker_ontologies_get_class_by_uri (ontologies, object_str);
@@ -2700,7 +2668,7 @@ tracker_data_insert_statement_with_uri (TrackerData  *data,
                }
        } else {
                /* add value to metadata database */
-               change = cache_insert_metadata_decomposed (data, property, object, &actual_error);
+               change = cache_insert_metadata_decomposed (data, predicate, object, &actual_error);
 
                if (actual_error) {
                        g_propagate_error (error, actual_error);
@@ -2716,47 +2684,33 @@ tracker_data_insert_statement_with_uri (TrackerData  *data,
 }
 
 void
-tracker_data_insert_statement_with_string (TrackerData  *data,
-                                           const gchar  *graph,
-                                           const gchar  *subject,
-                                           const gchar  *predicate,
-                                           GBytes       *object,
-                                           GError      **error)
+tracker_data_insert_statement_with_string (TrackerData      *data,
+                                           const gchar      *graph,
+                                           const gchar      *subject,
+                                           TrackerProperty  *predicate,
+                                           GBytes           *object,
+                                           GError          **error)
 {
        GError          *actual_error = NULL;
-       TrackerProperty *property;
        gboolean         change;
        gint             pred_id = 0;
-       TrackerOntologies *ontologies;
 
        g_return_if_fail (subject != NULL);
        g_return_if_fail (predicate != NULL);
        g_return_if_fail (object != NULL);
        g_return_if_fail (data->in_transaction);
 
-       ontologies = tracker_data_manager_get_ontologies (data->manager);
-
-       property = tracker_ontologies_get_property_by_uri (ontologies, predicate);
-       if (property == NULL) {
-               g_set_error (error, TRACKER_SPARQL_ERROR, TRACKER_SPARQL_ERROR_UNKNOWN_PROPERTY,
-                            "Property '%s' not found in the ontology", predicate);
-               return;
-       } else {
-               if (tracker_property_get_data_type (property) == TRACKER_PROPERTY_TYPE_RESOURCE) {
-                       g_set_error (error, TRACKER_SPARQL_ERROR, TRACKER_SPARQL_ERROR_TYPE,
-                                    "Property '%s' only accepts URIs", predicate);
-                       return;
-               }
-               pred_id = tracker_property_get_id (property);
-       }
+       g_assert (tracker_property_get_data_type (predicate) !=
+                 TRACKER_PROPERTY_TYPE_RESOURCE);
 
+       pred_id = tracker_property_get_id (predicate);
        data->has_persistent = TRUE;
 
        if (!resource_buffer_switch (data, graph, subject, error))
                return;
 
        /* add value to metadata database */
-       change = cache_insert_metadata_decomposed (data, property, object, &actual_error);
+       change = cache_insert_metadata_decomposed (data, predicate, object, &actual_error);
 
        if (actual_error) {
                g_propagate_error (error, actual_error);
@@ -2771,14 +2725,13 @@ tracker_data_insert_statement_with_string (TrackerData  *data,
 }
 
 void
-tracker_data_update_statement (TrackerData  *data,
-                               const gchar  *graph,
-                               const gchar  *subject,
-                               const gchar  *predicate,
-                               GBytes       *object,
-                               GError      **error)
+tracker_data_update_statement (TrackerData      *data,
+                               const gchar      *graph,
+                               const gchar      *subject,
+                               TrackerProperty  *predicate,
+                               GBytes           *object,
+                               GError          **error)
 {
-       TrackerProperty *property;
        TrackerOntologies *ontologies;
        GError *new_error = NULL;
 
@@ -2787,64 +2740,59 @@ tracker_data_update_statement (TrackerData  *data,
        g_return_if_fail (data->in_transaction);
 
        ontologies = tracker_data_manager_get_ontologies (data->manager);
-       property = tracker_ontologies_get_property_by_uri (ontologies, predicate);
 
-       if (property != NULL) {
-               if (object == NULL) {
-                       if (property == tracker_ontologies_get_rdf_type (ontologies)) {
-                               g_set_error (error, TRACKER_SPARQL_ERROR, TRACKER_SPARQL_ERROR_UNSUPPORTED,
-                                            "Using 'null' with '%s' is not supported", predicate);
-                               return;
-                       }
-
-                       /* Flush upfront to make a null,x,null,y,z work: When x is set then
-                        * if a null comes, we need to be flushed */
+       if (object == NULL) {
+               if (predicate == tracker_ontologies_get_rdf_type (ontologies)) {
+                       g_set_error (error, TRACKER_SPARQL_ERROR, TRACKER_SPARQL_ERROR_UNSUPPORTED,
+                                    "Using 'null' with '%s' is not supported",
+                                    tracker_property_get_uri (predicate));
+                       return;
+               }
 
-                       tracker_data_update_buffer_flush (data, &new_error);
-                       if (new_error) {
-                               g_propagate_error (error, new_error);
-                               return;
-                       }
+               /* Flush upfront to make a null,x,null,y,z work: When x is set then
+                * if a null comes, we need to be flushed */
 
-                       if (!resource_buffer_switch (data, graph, subject, error))
-                               return;
-
-                       cache_delete_all_values (data,
-                                                tracker_property_get_table_name (property),
-                                                tracker_property_get_name (property));
-                       if (tracker_property_get_data_type (property) == TRACKER_PROPERTY_TYPE_RESOURCE) {
-                               if (!tracker_data_resource_unref_all (data, property, error))
-                                       return;
-                       }
-               } else {
-                       if (!resource_buffer_switch (data, graph, subject, error))
-                               return;
+               tracker_data_update_buffer_flush (data, &new_error);
+               if (new_error) {
+                       g_propagate_error (error, new_error);
+                       return;
+               }
 
-                       if (!delete_single_valued (data, graph, subject, predicate,
-                                                  !tracker_property_get_multiple_values (property),
-                                                  error))
-                               return;
+               if (!resource_buffer_switch (data, graph, subject, error))
+                       return;
 
-                       tracker_data_update_buffer_flush (data, &new_error);
-                       if (new_error) {
-                               g_propagate_error (error, new_error);
+               cache_delete_all_values (data,
+                                        tracker_property_get_table_name (predicate),
+                                        tracker_property_get_name (predicate));
+               if (tracker_property_get_data_type (predicate) == TRACKER_PROPERTY_TYPE_RESOURCE) {
+                       if (!tracker_data_resource_unref_all (data, predicate, error))
                                return;
-                       }
-
-                       if (tracker_property_get_data_type (property) == TRACKER_PROPERTY_TYPE_RESOURCE) {
-                               tracker_data_insert_statement_with_uri (data, graph, subject, predicate, 
object, error);
-                       } else {
-                               tracker_data_insert_statement_with_string (data, graph, subject, predicate, 
object, error);
-                       }
                }
+       } else {
+               if (!resource_buffer_switch (data, graph, subject, error))
+                       return;
+
+               if (!delete_single_valued (data, graph, subject, predicate,
+                                          !tracker_property_get_multiple_values (predicate),
+                                          error))
+                       return;
 
                tracker_data_update_buffer_flush (data, &new_error);
                if (new_error) {
                        g_propagate_error (error, new_error);
+                       return;
+               }
+
+               if (tracker_property_get_data_type (predicate) == TRACKER_PROPERTY_TYPE_RESOURCE) {
+                       tracker_data_insert_statement_with_uri (data, graph, subject, predicate, object, 
error);
+               } else {
+                       tracker_data_insert_statement_with_string (data, graph, subject, predicate, object, 
error);
                }
-       } else {
-               g_set_error (error, TRACKER_SPARQL_ERROR, TRACKER_SPARQL_ERROR_UNKNOWN_PROPERTY,
-                            "Property '%s' not found in the ontology", predicate);
+       }
+
+       tracker_data_update_buffer_flush (data, &new_error);
+       if (new_error) {
+               g_propagate_error (error, new_error);
        }
 }
 
@@ -3044,8 +2992,9 @@ tracker_data_load_turtle_file (TrackerData  *data,
                                GError      **error)
 {
        TrackerTurtleReader *reader = NULL;
+       TrackerOntologies *ontologies;
        GError *inner_error = NULL;
-       const gchar *subject, *predicate, *object_str, *langtag;
+       const gchar *subject, *predicate_str, *object_str, *langtag;
        gboolean object_is_uri;
        goffset last_parsed_line_no, last_parsed_column_no;
        gchar *ontology_uri = g_file_get_uri (file);
@@ -3054,19 +3003,31 @@ tracker_data_load_turtle_file (TrackerData  *data,
        if (inner_error)
                goto failed;
 
+       ontologies = tracker_data_manager_get_ontologies (data->manager);
+
        while (tracker_turtle_reader_next (reader,
                                           &subject,
-                                          &predicate,
+                                          &predicate_str,
                                           &object_str,
                                           &langtag,
                                           &object_is_uri,
                                           &last_parsed_line_no,
                                           &last_parsed_column_no,
                                           &inner_error)) {
+               TrackerProperty *predicate;
                GBytes *object;
 
                object = tracker_sparql_make_langstring (object_str, langtag);
 
+               predicate = tracker_ontologies_get_property_by_uri (ontologies, predicate_str);
+               if (predicate == NULL) {
+                       g_set_error (&inner_error, TRACKER_SPARQL_ERROR,
+                                    TRACKER_SPARQL_ERROR_UNKNOWN_PROPERTY,
+                                    "Property '%s' not found in the ontology",
+                                    predicate_str);
+                       goto failed;
+               }
+
                if (object_is_uri) {
                        tracker_data_insert_statement_with_uri (data, graph,
                                                                subject, predicate, object,
@@ -3199,6 +3160,8 @@ update_resource_property (TrackerData      *data,
                           GHashTable       *bnodes,
                           GError          **error)
 {
+       TrackerOntologies *ontologies;
+       TrackerProperty *predicate;
        GList *values, *v;
        gchar *property_uri;
        GError *inner_error = NULL;
@@ -3209,6 +3172,16 @@ update_resource_property (TrackerData      *data,
                                            NULL, NULL,
                                            &property_uri);
 
+       ontologies = tracker_data_manager_get_ontologies (data->manager);
+       predicate = tracker_ontologies_get_property_by_uri (ontologies, property_uri);
+       if (predicate == NULL) {
+               g_set_error (error, TRACKER_SPARQL_ERROR,
+                            TRACKER_SPARQL_ERROR_UNKNOWN_PROPERTY,
+                            "Property '%s' not found in the ontology",
+                            property_uri);
+               return FALSE;
+       }
+
        for (v = values; v && !inner_error; v = v->next) {
                GBytes *bytes = NULL;
 
@@ -3233,7 +3206,7 @@ update_resource_property (TrackerData      *data,
                tracker_data_insert_statement (data,
                                               graph_uri,
                                               subject,
-                                              property_uri,
+                                              predicate,
                                               bytes,
                                               &inner_error);
                g_bytes_unref (bytes);
diff --git a/src/libtracker-data/tracker-data-update.h b/src/libtracker-data/tracker-data-update.h
index 31283dbea..8cea7ef01 100644
--- a/src/libtracker-data/tracker-data-update.h
+++ b/src/libtracker-data/tracker-data-update.h
@@ -60,19 +60,19 @@ GQuark   tracker_data_error_quark                   (void);
 void     tracker_data_delete_statement              (TrackerData               *data,
                                                      const gchar               *graph,
                                                      const gchar               *subject,
-                                                     const gchar               *predicate,
+                                                     TrackerProperty           *predicate,
                                                      GBytes                    *object,
                                                      GError                   **error);
 void     tracker_data_insert_statement              (TrackerData               *data,
                                                      const gchar               *graph,
                                                      const gchar               *subject,
-                                                     const gchar               *predicate,
+                                                     TrackerProperty           *predicate,
                                                      GBytes                    *object,
                                                      GError                   **error);
 void     tracker_data_update_statement              (TrackerData               *data,
                                                      const gchar               *graph,
                                                      const gchar               *subject,
-                                                     const gchar               *predicate,
+                                                     TrackerProperty           *predicate,
                                                      GBytes                    *object,
                                                      GError                   **error);
 void     tracker_data_begin_transaction             (TrackerData               *data,
diff --git a/src/libtracker-data/tracker-sparql.c b/src/libtracker-data/tracker-sparql.c
index 334879486..62488b68a 100644
--- a/src/libtracker-data/tracker-sparql.c
+++ b/src/libtracker-data/tracker-sparql.c
@@ -2039,6 +2039,7 @@ tracker_sparql_apply_quad (TrackerSparql  *sparql,
                            GError        **error)
 {
        GError *inner_error = NULL;
+       TrackerProperty *predicate = NULL;
 
        if ((tracker_token_is_empty (&sparql->current_state->graph) &&
             sparql->policy.filter_unnamed_graph) ||
@@ -2049,6 +2050,26 @@ tracker_sparql_apply_quad (TrackerSparql  *sparql,
                        tracker_token_get_idstring (&sparql->current_state->graph));
        }
 
+       if (sparql->current_state->type == TRACKER_SPARQL_TYPE_INSERT ||
+           sparql->current_state->type == TRACKER_SPARQL_TYPE_DELETE ||
+           sparql->current_state->type == TRACKER_SPARQL_TYPE_UPDATE) {
+               TrackerOntologies *ontologies;
+               const gchar *property;
+
+               ontologies = tracker_data_manager_get_ontologies (sparql->data_manager);
+               property = tracker_token_get_idstring (&sparql->current_state->predicate);
+               predicate = tracker_ontologies_get_property_by_uri (ontologies,
+                                                                   property);
+
+               if (predicate == NULL) {
+                       g_set_error (error, TRACKER_SPARQL_ERROR,
+                                    TRACKER_SPARQL_ERROR_UNKNOWN_PROPERTY,
+                                    "Property '%s' not found in the ontology",
+                                    property);
+                       return FALSE;
+               }
+       }
+
        switch (sparql->current_state->type) {
        case TRACKER_SPARQL_TYPE_SELECT:
                _add_quad (sparql,
@@ -2070,7 +2091,7 @@ tracker_sparql_apply_quad (TrackerSparql  *sparql,
                tracker_data_insert_statement (tracker_data_manager_get_data (sparql->data_manager),
                                               tracker_token_get_idstring (&sparql->current_state->graph),
                                               tracker_token_get_idstring (&sparql->current_state->subject),
-                                              tracker_token_get_idstring (&sparql->current_state->predicate),
+                                              predicate,
                                               tracker_token_get_literal (&sparql->current_state->object),
                                               &inner_error);
                break;
@@ -2078,7 +2099,7 @@ tracker_sparql_apply_quad (TrackerSparql  *sparql,
                tracker_data_delete_statement (tracker_data_manager_get_data (sparql->data_manager),
                                               tracker_token_get_idstring (&sparql->current_state->graph),
                                               tracker_token_get_idstring (&sparql->current_state->subject),
-                                              tracker_token_get_idstring (&sparql->current_state->predicate),
+                                              predicate,
                                               tracker_token_get_literal (&sparql->current_state->object),
                                               &inner_error);
                break;
@@ -2086,7 +2107,7 @@ tracker_sparql_apply_quad (TrackerSparql  *sparql,
                tracker_data_update_statement (tracker_data_manager_get_data (sparql->data_manager),
                                               tracker_token_get_idstring (&sparql->current_state->graph),
                                               tracker_token_get_idstring (&sparql->current_state->subject),
-                                              tracker_token_get_idstring (&sparql->current_state->predicate),
+                                              predicate,
                                               tracker_token_get_literal (&sparql->current_state->object),
                                               &inner_error);
                break;


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