[tracker/wip/garnacho/sparql1.1: 15/23] libtracker-data: Add SparqlRand sqlite function



commit afbef87a54814099d5ebde4589ef01530ed7fe52
Author: Carlos Garnacho <carlosg gnome org>
Date:   Tue Jul 28 23:59:45 2015 +0200

    libtracker-data: Add SparqlRand sqlite function
    
    This will be used to back up the RAND() sparql 1.1 function. Unlike
    the random() sqlite builtin function, g_random_double() gives us
    the random number in the same range than described in the
    recommendation, so it seems a better fit.

 src/libtracker-data/tracker-db-interface-sqlite.c |   19 +++++++++++++++++++
 1 files changed, 19 insertions(+), 0 deletions(-)
---
diff --git a/src/libtracker-data/tracker-db-interface-sqlite.c 
b/src/libtracker-data/tracker-db-interface-sqlite.c
index 0408549..c72ef30 100644
--- a/src/libtracker-data/tracker-db-interface-sqlite.c
+++ b/src/libtracker-data/tracker-db-interface-sqlite.c
@@ -1011,6 +1011,21 @@ function_sparql_floor (sqlite3_context *context,
        sqlite3_result_double (context, floor (value));
 }
 
+static void
+function_sparql_rand (sqlite3_context *context,
+                      int              argc,
+                      sqlite3_value   *argv[])
+{
+       gdouble value;
+
+       if (argc != 0) {
+               sqlite3_result_error (context, "Invalid argument count", -1);
+               return;
+       }
+
+       sqlite3_result_double (context, g_random_double ());
+}
+
 static inline int
 stmt_step (sqlite3_stmt *stmt)
 {
@@ -1152,6 +1167,10 @@ open_database (TrackerDBInterface  *db_interface,
                                 db_interface, &function_sparql_floor,
                                 NULL, NULL);
 
+       sqlite3_create_function (db_interface->db, "SparqlRand", 0, SQLITE_ANY,
+                                db_interface, &function_sparql_rand,
+                                NULL, NULL);
+
        sqlite3_extended_result_codes (db_interface->db, 0);
        sqlite3_busy_timeout (db_interface->db, 100000);
 }


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