[tracker/return-types: 23/28] libtracker-sparql, -data: Add boolean to ValueType and add typed convenience APIs
- From: Martyn James Russell <mr src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/return-types: 23/28] libtracker-sparql, -data: Add boolean to ValueType and add typed convenience APIs
- Date: Wed, 15 Sep 2010 15:39:03 +0000 (UTC)
commit b4b29a629c23f593607bf9b959bf4670ce6b0d99
Author: Philip Van Hoof <philip codeminded be>
Date: Mon Sep 13 17:02:38 2010 +0200
libtracker-sparql, -data: Add boolean to ValueType and add typed convenience APIs
src/libtracker-data/tracker-db-interface-sqlite.c | 2 +
src/libtracker-sparql/tracker-cursor.vala | 71 ++++++++++++++++++++-
2 files changed, 71 insertions(+), 2 deletions(-)
---
diff --git a/src/libtracker-data/tracker-db-interface-sqlite.c b/src/libtracker-data/tracker-db-interface-sqlite.c
index 089c86c..bb11871 100644
--- a/src/libtracker-data/tracker-db-interface-sqlite.c
+++ b/src/libtracker-data/tracker-db-interface-sqlite.c
@@ -1395,6 +1395,8 @@ tracker_db_cursor_get_value_type (TrackerDBCursor *cursor, guint column)
return TRACKER_SPARQL_VALUE_TYPE_DOUBLE;
case TRACKER_PROPERTY_TYPE_DATETIME:
return TRACKER_SPARQL_VALUE_TYPE_DATETIME;
+ case TRACKER_PROPERTY_TYPE_BOOLEAN:
+ return TRACKER_SPARQL_VALUE_TYPE_BOOLEAN;
default:
return TRACKER_SPARQL_VALUE_TYPE_STRING;
}
diff --git a/src/libtracker-sparql/tracker-cursor.vala b/src/libtracker-sparql/tracker-cursor.vala
index ac41fb2..0103e4a 100644
--- a/src/libtracker-sparql/tracker-cursor.vala
+++ b/src/libtracker-sparql/tracker-cursor.vala
@@ -43,13 +43,14 @@
* Enumeration with the possible types of the cursor's cells
*/
public enum Tracker.Sparql.ValueType {
- UNBOUND ,
+ UNBOUND,
URI,
STRING,
INTEGER,
DOUBLE,
DATETIME,
- BLANK_NODE
+ BLANK_NODE,
+ BOOLEAN
}
/**
@@ -179,4 +180,70 @@ public abstract class Tracker.Sparql.Cursor : Object {
* Resets the iterator to point back to the first result.
*/
public abstract void rewind ();
+
+
+ /**
+ * tracker_sparql_cursor_get_integer:
+ * @self: a #TrackerSparqlCursor
+ * @column: column number to retrieve (first one is 0)
+ *
+ * Returns the integer at @column in the current row being iterated.
+ *
+ * Returns: a integer.
+ */
+ public virtual int get_integer (int column) {
+ return_val_if_fail (get_value_type (column) == ValueType.INTEGER, 0);
+ unowned string as_str = get_string (column);
+ return_val_if_fail (as_str != null, 0);
+ return as_str.to_int();
+ }
+
+ /**
+ * tracker_sparql_cursor_get_double:
+ * @self: a #TrackerSparqlCursor
+ * @column: column number to retrieve (first one is 0)
+ *
+ * Returns the double at @column in the current row being iterated.
+ *
+ * Returns: a double.
+ */
+ public virtual double get_double (int column) {
+ return_val_if_fail (get_value_type (column) == ValueType.DOUBLE, 0);
+ unowned string as_str = get_string (column);
+ return_val_if_fail (as_str != null, 0);
+ return as_str.to_double();
+ }
+
+ /**
+ * tracker_sparql_cursor_get_boolean:
+ * @self: a #TrackerSparqlCursor
+ * @column: column number to retrieve (first one is 0)
+ *
+ * Returns the boolean at @column in the current row being iterated.
+ *
+ * Returns: a boolean.
+ */
+ public virtual bool get_boolean (int column) {
+ ValueType type = get_value_type (column);
+ return_val_if_fail (type == ValueType.BOOLEAN, 0);
+ unowned string as_str = get_string (column);
+ return_val_if_fail (as_str != null, false);
+ return (strcmp (as_str, "true") == 0);
+ }
+
+ /**
+ * tracker_sparql_cursor_get_unbound:
+ * @self: a #TrackerSparqlCursor
+ * @column: column number to retrieve (first one is 0)
+ *
+ * Returns true when @column at the current row being iterated is unbound
+ *
+ * Returns: a boolean.
+ */
+ public virtual bool get_unbound (int column) {
+ if (get_value_type (column) == ValueType.UNBOUND) {
+ return true;
+ }
+ return false;
+ }
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]