[evolution-data-server/openismus-work-3-8] EDataBookCursorSqlite: New cursor step() API
- From: Tristan Van Berkom <tvb src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution-data-server/openismus-work-3-8] EDataBookCursorSqlite: New cursor step() API
- Date: Thu, 24 Oct 2013 20:41:14 +0000 (UTC)
commit 1e94ec6bb648bd3cda1caab261594ac1b370b51f
Author: Tristan Van Berkom <tristanvb openismus com>
Date: Fri Oct 18 22:40:55 2013 +0200
EDataBookCursorSqlite: New cursor step() API
.../libedata-book/e-data-book-cursor-sqlite.c | 72 ++++++++++++++------
1 files changed, 51 insertions(+), 21 deletions(-)
---
diff --git a/addressbook/libedata-book/e-data-book-cursor-sqlite.c
b/addressbook/libedata-book/e-data-book-cursor-sqlite.c
index c9b24ba..12e6d7d 100644
--- a/addressbook/libedata-book/e-data-book-cursor-sqlite.c
+++ b/addressbook/libedata-book/e-data-book-cursor-sqlite.c
@@ -47,8 +47,9 @@ static void e_data_book_cursor_sqlite_set_property (GObject *object,
static gboolean e_data_book_cursor_sqlite_set_sexp (EDataBookCursor *cursor,
const gchar *sexp,
GError **error);
-static gint e_data_book_cursor_sqlite_move_by (EDataBookCursor *cursor,
+static gint e_data_book_cursor_sqlite_step (EDataBookCursor *cursor,
const gchar *revision_guard,
+ EBookCursorStepFlags flags,
EBookCursorOrigin origin,
gint count,
GSList **results,
@@ -99,7 +100,7 @@ e_data_book_cursor_sqlite_class_init (EDataBookCursorSqliteClass *class)
cursor_class = E_DATA_BOOK_CURSOR_CLASS (class);
cursor_class->set_sexp = e_data_book_cursor_sqlite_set_sexp;
- cursor_class->move_by = e_data_book_cursor_sqlite_move_by;
+ cursor_class->step = e_data_book_cursor_sqlite_step;
cursor_class->set_alphabetic_index = e_data_book_cursor_sqlite_set_alphabetic_index;
cursor_class->get_position = e_data_book_cursor_sqlite_get_position;
cursor_class->compare_contact = e_data_book_cursor_sqlite_compare_contact;
@@ -252,11 +253,11 @@ convert_origin (EBookCursorOrigin src_origin,
case E_BOOK_CURSOR_ORIGIN_CURRENT:
*dest_origin = EBSDB_CURSOR_ORIGIN_CURRENT;
break;
- case E_BOOK_CURSOR_ORIGIN_PREVIOUS:
- *dest_origin = EBSDB_CURSOR_ORIGIN_PREVIOUS;
+ case E_BOOK_CURSOR_ORIGIN_BEGIN:
+ *dest_origin = EBSDB_CURSOR_ORIGIN_BEGIN;
break;
- case E_BOOK_CURSOR_ORIGIN_RESET:
- *dest_origin = EBSDB_CURSOR_ORIGIN_RESET;
+ case E_BOOK_CURSOR_ORIGIN_END:
+ *dest_origin = EBSDB_CURSOR_ORIGIN_END;
break;
default:
success = FALSE;
@@ -270,18 +271,31 @@ convert_origin (EBookCursorOrigin src_origin,
return success;
}
+static void
+convert_flags (EBookCursorStepFlags src_flags,
+ EbSdbCursorStepFlags *dest_flags)
+{
+ if (src_flags & E_BOOK_CURSOR_STEP_MOVE)
+ *dest_flags |= EBSDB_CURSOR_STEP_MOVE;
+
+ if (src_flags & E_BOOK_CURSOR_STEP_FETCH)
+ *dest_flags |= EBSDB_CURSOR_STEP_FETCH;
+}
+
static gint
-e_data_book_cursor_sqlite_move_by (EDataBookCursor *cursor,
- const gchar *revision_guard,
- EBookCursorOrigin origin,
- gint count,
- GSList **results,
- GError **error)
+e_data_book_cursor_sqlite_step (EDataBookCursor *cursor,
+ const gchar *revision_guard,
+ EBookCursorStepFlags flags,
+ EBookCursorOrigin origin,
+ gint count,
+ GSList **results,
+ GError **error)
{
EDataBookCursorSqlite *cursor_sqlite;
EDataBookCursorSqlitePrivate *priv;
GSList *local_results = NULL, *local_converted_results = NULL, *l;
EbSdbCursorOrigin sqlitedb_origin = EBSDB_CURSOR_ORIGIN_CURRENT;
+ EbSdbCursorStepFlags sqlitedb_flags = 0;
gchar *revision = NULL;
gboolean success = FALSE;
gint n_results = -1;
@@ -292,6 +306,8 @@ e_data_book_cursor_sqlite_move_by (EDataBookCursor *cursor,
if (!convert_origin (origin, &sqlitedb_origin, error))
return FALSE;
+ convert_flags (flags, &sqlitedb_flags);
+
/* Here we check the EBookBackendSqliteDB revision
* against the revision_guard with an atomic transaction
* with the sqlite.
@@ -318,17 +334,31 @@ e_data_book_cursor_sqlite_move_by (EDataBookCursor *cursor,
}
if (success) {
+ GError *local_error = NULL;
+
+ n_results = e_book_backend_sqlitedb_cursor_step (priv->ebsdb,
+ priv->cursor,
+ sqlitedb_flags,
+ sqlitedb_origin,
+ count,
+ &local_results,
+ &local_error);
+
+ if (n_results < 0) {
+
+ /* Convert the SQLite backend error to an EClient error */
+ if (g_error_matches (local_error,
+ E_BOOK_SDB_ERROR,
+ E_BOOK_SDB_ERROR_END_OF_LIST)) {
+ g_set_error_literal (error, E_CLIENT_ERROR,
+ E_CLIENT_ERROR_END_OF_LIST,
+ local_error->message);
+ g_clear_error (&local_error);
+ } else
+ g_propagate_error (error, local_error);
- /* Only pass 'local_results' if the caller passed 'results'
- */
- n_results = e_book_backend_sqlitedb_cursor_move_by (priv->ebsdb,
- priv->cursor,
- sqlitedb_origin,
- count,
- results ? &local_results : NULL,
- error);
- if (n_results < 0)
success = FALSE;
+ }
}
if (success) {
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]