summaryrefslogtreecommitdiff
path: root/src/libtracker-data/tracker-sparql.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/libtracker-data/tracker-sparql.c')
-rw-r--r--src/libtracker-data/tracker-sparql.c14
1 files changed, 13 insertions, 1 deletions
diff --git a/src/libtracker-data/tracker-sparql.c b/src/libtracker-data/tracker-sparql.c
index db8d74222..72a601b95 100644
--- a/src/libtracker-data/tracker-sparql.c
+++ b/src/libtracker-data/tracker-sparql.c
@@ -2790,15 +2790,18 @@ static gboolean
translate_InsertClause (TrackerSparql *sparql,
GError **error)
{
+ TrackerToken old_graph;
+
/* InsertClause ::= 'INSERT' QuadPattern
*
* TRACKER EXTENSION:
* Clause may start with:
- * 'INSERT' ('OR' 'REPLACE')? ('SILENT')?
+ * 'INSERT' ('OR' 'REPLACE')? ('SILENT')? ('INTO' iri)?
*/
sparql->current_state.blank_node_map =
g_hash_table_new_full (g_str_hash, g_str_equal,
g_free, g_free);
+ old_graph = sparql->current_state.graph;
sparql->current_state.type = TRACKER_SPARQL_TYPE_INSERT;
_expect (sparql, RULE_TYPE_LITERAL, LITERAL_INSERT);
@@ -2812,8 +2815,17 @@ translate_InsertClause (TrackerSparql *sparql,
sparql->silent = _accept (sparql, RULE_TYPE_LITERAL, LITERAL_SILENT);
+ if (_accept (sparql, RULE_TYPE_LITERAL, LITERAL_INTO)) {
+ _call_rule (sparql, NAMED_RULE_iri, error);
+ _init_token (&sparql->current_state.graph,
+ sparql->current_state.prev_node, sparql);
+ }
+
_call_rule (sparql, NAMED_RULE_QuadPattern, error);
+ tracker_token_unset (&sparql->current_state.graph);
+ sparql->current_state.graph = old_graph;
+
if (sparql->blank_nodes) {
GHashTableIter iter;
gpointer key, value;