[tracker/return-types: 24/26] libtracker-data: Implement optimized versions for direct-access, for typed convenience funtions
- From: Martyn James Russell <mr src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/return-types: 24/26] libtracker-data: Implement optimized versions for direct-access, for typed convenience funtions
- Date: Wed, 15 Sep 2010 13:57:25 +0000 (UTC)
commit e5a859fc65eda2dc30e2b62bfa561d2d40aae0d8
Author: Philip Van Hoof <philip codeminded be>
Date: Mon Sep 13 17:20:15 2010 +0200
libtracker-data: Implement optimized versions for direct-access, for typed convenience funtions
src/libtracker-data/tracker-db-interface-sqlite.c | 23 +++++++++++++++++++++
1 files changed, 23 insertions(+), 0 deletions(-)
---
diff --git a/src/libtracker-data/tracker-db-interface-sqlite.c b/src/libtracker-data/tracker-db-interface-sqlite.c
index bb11871..4c4a9a7 100644
--- a/src/libtracker-data/tracker-db-interface-sqlite.c
+++ b/src/libtracker-data/tracker-db-interface-sqlite.c
@@ -96,6 +96,10 @@ static TrackerDBCursor *tracker_db_cursor_sqlite_new (sqlite3_stmt
TrackerPropertyType *types,
gint n_types);
static void tracker_db_statement_sqlite_reset (TrackerDBStatement *stmt);
+static gint tracker_db_cursor_get_integer (TrackerSparqlCursor *cursor,
+ guint column);
+static gboolean tracker_db_cursor_get_boolean (TrackerSparqlCursor *cursor,
+ guint column);
static gboolean db_cursor_iter_next (TrackerDBCursor *cursor,
GCancellable *cancellable,
GError **error);
@@ -1186,6 +1190,10 @@ tracker_db_cursor_class_init (TrackerDBCursorClass *class)
sparql_cursor_class->next_async = (void (*) (TrackerSparqlCursor *, GCancellable *, GAsyncReadyCallback, gpointer)) tracker_db_cursor_iter_next_async;
sparql_cursor_class->next_finish = (gboolean (*) (TrackerSparqlCursor *, GAsyncResult *, GError **)) tracker_db_cursor_iter_next_finish;
sparql_cursor_class->rewind = (void (*) (TrackerSparqlCursor *)) tracker_db_cursor_rewind;
+
+ sparql_cursor_class->get_integer = (gint (*) (TrackerSparqlCursor *, gint)) tracker_db_cursor_get_integer;
+ sparql_cursor_class->get_double = (gdouble (*) (TrackerSparqlCursor *, gint)) tracker_db_cursor_get_double;
+ sparql_cursor_class->get_boolean = (gboolean (*) (TrackerSparqlCursor *, gint)) tracker_db_cursor_get_boolean;
}
static TrackerDBCursor *
@@ -1376,6 +1384,21 @@ tracker_db_cursor_get_double (TrackerDBCursor *cursor, guint column)
return (gdouble) sqlite3_column_double (cursor->stmt, column);
}
+
+static gint
+tracker_db_cursor_get_integer (TrackerSparqlCursor *sparql_cursor, guint column)
+{
+ TrackerDBCursor *cursor = (TrackerDBCursor *) sparql_cursor;
+ return (gint) sqlite3_column_int64 (cursor->stmt, column);
+}
+
+static gboolean
+tracker_db_cursor_get_boolean (TrackerSparqlCursor *sparql_cursor, guint column)
+{
+ TrackerDBCursor *cursor = (TrackerDBCursor *) sparql_cursor;
+ return (g_strcmp0 (sqlite3_column_text (cursor->stmt, column), "true") == 0);
+}
+
TrackerSparqlValueType
tracker_db_cursor_get_value_type (TrackerDBCursor *cursor, guint column)
{
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]