[tracker/wip/carlosg/sparql1.1: 35/56] libtracker-data: Add support for SERVICE{} syntax
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/wip/carlosg/sparql1.1: 35/56] libtracker-data: Add support for SERVICE{} syntax
- Date: Thu, 6 Jun 2019 11:19:06 +0000 (UTC)
commit c4816b8e8563426cdf04eb1c8897fa1d96134a03
Author: Carlos Garnacho <carlosg gnome org>
Date: Thu May 30 13:55:58 2019 +0200
libtracker-data: Add support for SERVICE{} syntax
src/libtracker-data/tracker-db-interface-sqlite.c | 2 ++
src/libtracker-data/tracker-sparql.c | 37 ++++++++++++++---------
2 files changed, 24 insertions(+), 15 deletions(-)
---
diff --git a/src/libtracker-data/tracker-db-interface-sqlite.c
b/src/libtracker-data/tracker-db-interface-sqlite.c
index 6b79023c0..f43b0cd9b 100644
--- a/src/libtracker-data/tracker-db-interface-sqlite.c
+++ b/src/libtracker-data/tracker-db-interface-sqlite.c
@@ -56,6 +56,7 @@
#include "tracker-db-manager.h"
#include "tracker-data-enum-types.h"
#include "tracker-uuid.h"
+#include "tracker-vtab-service.h"
#include "tracker-vtab-triples.h"
#include "tracker-vtab-union.h"
@@ -3173,6 +3174,7 @@ tracker_db_interface_init_vtabs (TrackerDBInterface *db_interface,
{
tracker_vtab_triples_init (db_interface->db, ontologies);
tracker_vtab_union_init (db_interface->db, ontologies);
+ tracker_vtab_service_init (db_interface->db, ontologies);
return TRUE;
}
diff --git a/src/libtracker-data/tracker-sparql.c b/src/libtracker-data/tracker-sparql.c
index d457a7603..ce730465a 100644
--- a/src/libtracker-data/tracker-sparql.c
+++ b/src/libtracker-data/tracker-sparql.c
@@ -2423,26 +2423,33 @@ translate_Create (TrackerSparql *sparql,
silent = TRUE;
_call_rule (sparql, NAMED_RULE_GraphRef, error);
+ g_assert (!tracker_token_is_empty (&sparql->current_state.graph));
- if (!tracker_token_is_empty (&sparql->current_state.graph)) {
- const gchar *graph_name;
+ graph_name = tracker_token_get_idstring (&sparql->current_state.graph);
- graph_name = tracker_token_get_idstring (&sparql->current_state.graph);
-
- if (!tracker_data_manager_create_graph (sparql->data_manager,
- graph_name,
- &inner_error)) {
- if (silent) {
- g_error_free (inner_error);
- return TRUE;
- } else {
- g_propagate_error (error, inner_error);
- return FALSE;
- }
- }
+ if (tracker_data_manager_find_graph (sparql->data_manager, graph_name) != 0) {
+ inner_error = g_error_new (TRACKER_SPARQL_ERROR,
+ TRACKER_SPARQL_ERROR_CONSTRAINT,
+ "Graph '%s' already exists",
+ graph_name);
+ goto error;
}
+ if (!tracker_data_manager_create_graph (sparql->data_manager,
+ graph_name,
+ &inner_error))
+ goto error;
+
return TRUE;
+
+error:
+ if (silent) {
+ g_error_free (inner_error);
+ return TRUE;
+ } else {
+ g_propagate_error (error, inner_error);
+ return FALSE;
+ }
}
static gboolean
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]