[tracker/wip/carlosg/anonymous-nodes: 10/24] libtracker-data: Get resource URIs after failures
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/wip/carlosg/anonymous-nodes: 10/24] libtracker-data: Get resource URIs after failures
- Date: Fri, 8 Oct 2021 09:40:54 +0000 (UTC)
commit 932e9aa86ed3e375063efa5dcb3fe98fc800dce6
Author: Carlos Garnacho <carlosg gnome org>
Date: Thu Sep 23 22:46:08 2021 +0200
libtracker-data: Get resource URIs after failures
This avoids having to propagate the resource URI during insertion.
Also make those errors somewhat more legible.
src/libtracker-data/tracker-data-query.c | 31 +++++++++++++++++++++++++++++++
src/libtracker-data/tracker-data-query.h | 3 +++
src/libtracker-data/tracker-data-update.c | 28 ++++++++++++++++++++++++----
3 files changed, 58 insertions(+), 4 deletions(-)
---
diff --git a/src/libtracker-data/tracker-data-query.c b/src/libtracker-data/tracker-data-query.c
index ea3d56a0c..5fc1f885b 100644
--- a/src/libtracker-data/tracker-data-query.c
+++ b/src/libtracker-data/tracker-data-query.c
@@ -94,6 +94,37 @@ tracker_data_query_rdf_type (TrackerDataManager *manager,
return ret;
}
+gchar *
+tracker_data_query_resource_urn (TrackerDataManager *manager,
+ TrackerDBInterface *iface,
+ gint64 id)
+{
+ TrackerDBCursor *cursor = NULL;
+ TrackerDBStatement *stmt;
+ gchar *uri = NULL;
+
+ g_return_val_if_fail (id != 0, NULL);
+
+ stmt = tracker_db_interface_create_statement (iface, TRACKER_DB_STATEMENT_CACHE_TYPE_SELECT, NULL,
+ "SELECT Uri FROM Resource WHERE ID = ?");
+ if (!stmt)
+ return NULL;
+
+ tracker_db_statement_bind_int (stmt, 0, id);
+ cursor = tracker_db_statement_start_cursor (stmt, NULL);
+ g_object_unref (stmt);
+
+ if (!cursor)
+ return NULL;
+
+ if (tracker_db_cursor_iter_next (cursor, NULL, NULL))
+ uri = g_strdup (tracker_db_cursor_get_string (cursor, 0, NULL));
+
+ g_object_unref (cursor);
+
+ return uri;
+}
+
gint
tracker_data_query_resource_id (TrackerDataManager *manager,
TrackerDBInterface *iface,
diff --git a/src/libtracker-data/tracker-data-query.h b/src/libtracker-data/tracker-data-query.h
index a5b17ae13..d999c2ff1 100644
--- a/src/libtracker-data/tracker-data-query.h
+++ b/src/libtracker-data/tracker-data-query.h
@@ -34,6 +34,9 @@ G_BEGIN_DECLS
#error "only <libtracker-data/tracker-data.h> must be included directly."
#endif
+gchar * tracker_data_query_resource_urn (TrackerDataManager *manager,
+ TrackerDBInterface *iface,
+ gint64 id);
gint tracker_data_query_resource_id (TrackerDataManager *manager,
TrackerDBInterface *iface,
const gchar *uri,
diff --git a/src/libtracker-data/tracker-data-update.c b/src/libtracker-data/tracker-data-update.c
index 1f2aa3520..e1891e128 100644
--- a/src/libtracker-data/tracker-data-update.c
+++ b/src/libtracker-data/tracker-data-update.c
@@ -1574,11 +1574,22 @@ get_old_property_values (TrackerData *data,
old_values = g_hash_table_lookup (data->resource_buffer->predicates, property);
if (old_values == NULL) {
if (!check_property_domain (data, property)) {
+ TrackerDBInterface *iface;
+ gchar *resource;
+
+ iface = tracker_data_manager_get_writable_db_interface (data->manager);
+ resource = tracker_data_query_resource_urn (data->manager,
+ iface,
+ data->resource_buffer->id);
+
g_set_error (error, TRACKER_SPARQL_ERROR, TRACKER_SPARQL_ERROR_CONSTRAINT,
- "Subject `%s' is not in domain `%s' of property `%s'",
- data->resource_buffer->subject,
+ "%s %s is not is not a %s, cannot have property `%s'",
+ resource ? "Subject" : "Blank node",
+ resource ? resource : "",
tracker_class_get_name (tracker_property_get_domain (property)),
tracker_property_get_name (property));
+ g_free (resource);
+
return NULL;
}
@@ -1778,6 +1789,8 @@ cache_insert_metadata_decomposed (TrackerData *data,
/* value already inserted */
} else if (!multiple_values && old_values->len > 1) {
/* trying to add second value to single valued property */
+ TrackerDBInterface *iface;
+ gchar *resource;
GValue old_value = { 0 };
GValue new_value = { 0 };
GValue *v;
@@ -1799,14 +1812,21 @@ cache_insert_metadata_decomposed (TrackerData *data,
new_value_str = tracker_utf8_truncate (g_value_get_string (&new_value), 255);
}
+ iface = tracker_data_manager_get_writable_db_interface (data->manager);
+ resource = tracker_data_query_resource_urn (data->manager,
+ iface,
+ data->resource_buffer->id);
+
g_set_error (error, TRACKER_SPARQL_ERROR, TRACKER_SPARQL_ERROR_CONSTRAINT,
- "Unable to insert multiple values for subject `%s' and single valued property
`%s' "
+ "Unable to insert multiple values on single valued property `%s' for %s %s "
"(old_value: '%s', new value: '%s')",
- data->resource_buffer->subject,
field_name,
+ resource ? "resource" : "blank node",
+ resource ? resource : "",
old_value_str ? old_value_str : "<untransformable>",
new_value_str ? new_value_str : "<untransformable>");
+ g_free (resource);
g_free (old_value_str);
g_free (new_value_str);
g_value_unset (&old_value);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]