[tracker/wip/carlosg/sparql-parser-ng: 7/43] libtracker-data: Bring back custom sparql syntax
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/wip/carlosg/sparql-parser-ng: 7/43] libtracker-data: Bring back custom sparql syntax
- Date: Sat, 3 Nov 2018 13:08:07 +0000 (UTC)
commit 84309ce4a966a8549aeb93711ce04e528895d280
Author: Carlos Garnacho <carlosg gnome org>
Date: Mon Mar 19 13:27:42 2018 +0100
libtracker-data: Bring back custom sparql syntax
Tracker used to accept plain Expression in SelectClause, i.e.
no parentheses, and "AS ?var" being optional. Bring that back.
src/libtracker-data/tracker-sparql-grammar.h | 15 ++++++--
src/libtracker-data/tracker-sparql.c | 52 ++++++++++++++++++++--------
2 files changed, 50 insertions(+), 17 deletions(-)
---
diff --git a/src/libtracker-data/tracker-sparql-grammar.h b/src/libtracker-data/tracker-sparql-grammar.h
index c9b80faa3..e649acf54 100644
--- a/src/libtracker-data/tracker-sparql-grammar.h
+++ b/src/libtracker-data/tracker-sparql-grammar.h
@@ -1399,10 +1399,19 @@ static const TrackerGrammarRule helper_ConstructQuery_or[] = { S (helper_Constru
static const TrackerGrammarRule rule_ConstructQuery[] = { L(CONSTRUCT), OR(helper_ConstructQuery_or), NIL };
/* SelectClause ::= 'SELECT' ( 'DISTINCT' | 'REDUCED' )? ( ( Var | ( '(' Expression 'AS' Var ')' ) )+ | '*' )
- */
-static const TrackerGrammarRule helper_SelectClause_seq[] = { L(OPEN_PARENS), R(Expression), L(AS), R(Var),
L(CLOSE_PARENS), NIL };
+ *
+ * TRACKER EXTENSION:
+ * Variable set also accepts the following syntax:
+ * Expression ('AS' Var)?
+ * Var ('AS' Var)?
+ */
+static const TrackerGrammarRule ext_SelectClause_seq_1[] = { L(AS), R(Var), NIL };
+static const TrackerGrammarRule ext_SelectClause_opt[] = { S(ext_SelectClause_seq_1), NIL };
+static const TrackerGrammarRule ext_SelectClause_seq_2[] = { R(Var), OPT(ext_SelectClause_opt), NIL };
+static const TrackerGrammarRule ext_SelectClause_seq_3[] = { R(Expression), OPT(ext_SelectClause_opt), NIL };
+static const TrackerGrammarRule helper_SelectClause_seq_1[] = { L(OPEN_PARENS), R(Expression), L(AS),
R(Var), L(CLOSE_PARENS), NIL };
static const TrackerGrammarRule helper_SelectClause_or_1[] = { L(DISTINCT), L(REDUCED), NIL };
-static const TrackerGrammarRule helper_SelectClause_or_2[] = { R(Var), S(helper_SelectClause_seq), NIL };
+static const TrackerGrammarRule helper_SelectClause_or_2[] = { S(ext_SelectClause_seq_2),
S(ext_SelectClause_seq_3), R(Var), S(helper_SelectClause_seq_1), NIL };
static const TrackerGrammarRule helper_SelectClause_gt0[] = { OR(helper_SelectClause_or_2), NIL };
static const TrackerGrammarRule helper_SelectClause_opt[] = { OR(helper_SelectClause_or_1), NIL };
static const TrackerGrammarRule helper_SelectClause_or_3[] = { L(GLOB), GT0(helper_SelectClause_gt0), NIL };
diff --git a/src/libtracker-data/tracker-sparql.c b/src/libtracker-data/tracker-sparql.c
index 84e545f2b..e0778b68a 100644
--- a/src/libtracker-data/tracker-sparql.c
+++ b/src/libtracker-data/tracker-sparql.c
@@ -1641,6 +1641,29 @@ tracker_sparql_add_select_var (TrackerSparql *sparql,
g_array_append_val (sparql->var_types, type);
}
+static gboolean
+handle_as (TrackerSparql *sparql,
+ TrackerPropertyType type,
+ GError **error)
+{
+ TrackerBinding *binding;
+ TrackerVariable *var;
+
+ _call_rule (sparql, NAMED_RULE_Var, error);
+ var = _last_node_variable (sparql);
+
+ binding = tracker_variable_binding_new (var, NULL, NULL);
+ tracker_binding_set_data_type (binding, type);
+ tracker_variable_set_sample_binding (var, TRACKER_VARIABLE_BINDING (binding));
+ _append_string_printf (sparql, "AS %s ",
+ tracker_variable_get_sql_expression (var));
+
+ if (sparql->current_state.select_context == sparql->context)
+ tracker_sparql_add_select_var (sparql, var->name, type);
+
+ return TRUE;
+}
+
static gboolean
translate_SelectClause (TrackerSparql *sparql,
GError **error)
@@ -1650,6 +1673,10 @@ translate_SelectClause (TrackerSparql *sparql,
gboolean first = TRUE;
/* SelectClause ::= 'SELECT' ( 'DISTINCT' | 'REDUCED' )? ( ( Var | ( '(' Expression 'AS' Var ')' ) )+
| '*' )
+ *
+ * TRACKER EXTENSION:
+ * Variable set also accepts the following syntax:
+ * Expression ('AS' Var)?
*/
_expect (sparql, RULE_TYPE_LITERAL, LITERAL_SELECT);
_append_string (sparql, "SELECT ");
@@ -1717,13 +1744,17 @@ translate_SelectClause (TrackerSparql *sparql,
select_context->type = binding->data_type;
- if (sparql->current_state.select_context == sparql->context) {
+ if (_accept (sparql, RULE_TYPE_LITERAL, LITERAL_AS)) {
+ if (!handle_as (sparql, binding->data_type, error))
+ return FALSE;
+ } else if (sparql->current_state.select_context == sparql->context) {
convert_expression_to_string (sparql, binding->data_type);
tracker_sparql_add_select_var (sparql, var->name, binding->data_type);
}
tracker_sparql_swap_builder (sparql, old);
- } else if (_accept (sparql, RULE_TYPE_LITERAL, LITERAL_OPEN_PARENS)) {
+ } else if (_accept (sparql, RULE_TYPE_LITERAL, LITERAL_OPEN_PARENS) ||
+ _check_in_rule (sparql, NAMED_RULE_Expression)) {
if (!first)
_append_string (sparql, ", ");
@@ -1738,22 +1769,15 @@ translate_SelectClause (TrackerSparql *sparql,
select_context->type = sparql->current_state.expression_type;
- _expect (sparql, RULE_TYPE_LITERAL, LITERAL_AS);
- _call_rule (sparql, NAMED_RULE_Var, error);
- var = _last_node_variable (sparql);
-
- if (sparql->current_state.select_context == sparql->context) {
- _append_string_printf (sparql, "AS \"%s\" ", var->name);
+ if (_accept (sparql, RULE_TYPE_LITERAL, LITERAL_AS)) {
+ if (!handle_as (sparql, sparql->current_state.expression_type, error))
+ return FALSE;
} else {
- binding = tracker_variable_binding_new (var, NULL, NULL);
- tracker_binding_set_data_type (binding,
sparql->current_state.expression_type);
- tracker_variable_set_sample_binding (var, TRACKER_VARIABLE_BINDING
(binding));
- _append_string_printf (sparql, "AS %s ",
- tracker_variable_get_sql_expression (var));
+ tracker_sparql_add_select_var (sparql, "",
sparql->current_state.expression_type);
}
tracker_sparql_swap_builder (sparql, old);
- _expect (sparql, RULE_TYPE_LITERAL, LITERAL_CLOSE_PARENS);
+ _accept (sparql, RULE_TYPE_LITERAL, LITERAL_CLOSE_PARENS);
} else {
break;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]