[tracker/async-queries-cursor-review: 6/6] libtracker-db, tracker-store: Code style changes
- From: Philip Van Hoof <pvanhoof src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/async-queries-cursor-review: 6/6] libtracker-db, tracker-store: Code style changes
- Date: Wed, 21 Apr 2010 15:09:34 +0000 (UTC)
commit 043b147945cc582e2dd161e5aaf18fe055909d43
Author: Philip Van Hoof <philip codeminded be>
Date: Wed Apr 21 16:59:52 2010 +0200
libtracker-db, tracker-store: Code style changes
src/libtracker-db/tracker-db-interface-sqlite.c | 15 ++++-
src/tracker-store/tracker-resources.c | 77 +++++++++++++----------
2 files changed, 55 insertions(+), 37 deletions(-)
---
diff --git a/src/libtracker-db/tracker-db-interface-sqlite.c b/src/libtracker-db/tracker-db-interface-sqlite.c
index 07545d9..897970a 100644
--- a/src/libtracker-db/tracker-db-interface-sqlite.c
+++ b/src/libtracker-db/tracker-db-interface-sqlite.c
@@ -1059,11 +1059,20 @@ tracker_db_cursor_sqlite_iter_next (TrackerDBCursor *cursor,
}
if (result == SQLITE_INTERRUPT) {
- g_set_error (error, TRACKER_DB_INTERFACE_ERROR, TRACKER_DB_INTERRUPTED,
+ g_set_error (error,
+ TRACKER_DB_INTERFACE_ERROR,
+ TRACKER_DB_INTERRUPTED,
"Interrupted");
} else if (result != SQLITE_ROW && result != SQLITE_DONE) {
- g_set_error (error, TRACKER_DB_INTERFACE_ERROR, TRACKER_DB_QUERY_ERROR,
- "%s", sqlite3_errmsg (priv->ref_stmt->priv->db_interface->priv->db));
+ TrackerDBStatementSqlite *stmt = priv->ref_stmt;
+ TrackerDBStatementSqlitePrivate *stmt_priv = TRACKER_DB_STATEMENT_SQLITE_GET_PRIVATE (stmt);
+ TrackerDBInterfaceSqlite *iface = stmt_priv->db_interface;
+ TrackerDBInterfaceSqlitePrivate *iface_priv = TRACKER_DB_INTERFACE_SQLITE_GET_PRIVATE (iface);
+
+ g_set_error (error,
+ TRACKER_DB_INTERFACE_ERROR,
+ TRACKER_DB_QUERY_ERROR,
+ "%s", sqlite3_errmsg (iface_priv->db));
}
priv->finished = (result != SQLITE_ROW);
diff --git a/src/tracker-store/tracker-resources.c b/src/tracker-store/tracker-resources.c
index 0f65d17..9ff29f5 100644
--- a/src/tracker-store/tracker-resources.c
+++ b/src/tracker-store/tracker-resources.c
@@ -46,6 +46,30 @@
#define RDF_PREFIX TRACKER_RDF_PREFIX
#define RDF_TYPE RDF_PREFIX "type"
+/* I *know* that this is some arbitrary number that doesn't seem to
+ * resemble anything. In fact it's what I experimentally measured to
+ * be a good value on a default Debian testing which has
+ * max_message_size set to 1 000 000 000 in session.conf. I didn't have
+ * the feeling that this value was very much respected, as the size
+ * of the DBusMessage when libdbus decided to exit() the process was
+ * around 160 MB, and not ~ 1000 MB. So if you take 160 MB and you
+ * devide it by 1475760 you have an average string size of ~ 108
+ * bytes plus DBusMessage's overhead. If that makes this number less
+ * arbitrary for you, then fine.
+ *
+ * I really hope that the libdbus people get to their senses and
+ * either stop doing their exit() nonsense in a library, and instead
+ * return a clean DBusError or something, or create crystal clear
+ * clarity about the maximum size of a message. And make it both so
+ * that I can get this length at runtime (without having to parse
+ * libdbus's own configuration files) and my DBusMessage's current
+ * total length. As far as I know are both not possible. So that for
+ * me means that libdbus's exit() is unacceptable.
+ *
+ * Note for the debugger of the future, the "Disconnected" signal gets
+ * sent to us by the bus, which in turn makes libdbus-glib perform exit(). */
+
+#define DBUS_ARBITRARY_MAX_MSG_SIZE 1475760
G_DEFINE_TYPE(TrackerResources, tracker_resources, G_TYPE_OBJECT)
@@ -187,6 +211,7 @@ query_callback (TrackerDBCursor *cursor, GError *error, gpointer user_data)
guint cols;
GError *loop_error = NULL;
guint length = 0;
+ gboolean cont;
if (error) {
tracker_dbus_request_failed (info->request_id,
@@ -203,10 +228,14 @@ query_callback (TrackerDBCursor *cursor, GError *error, gpointer user_data)
cols = tracker_db_cursor_get_n_columns (cursor);
- dbus_message_iter_open_container (&iter, DBUS_TYPE_ARRAY,
- "as", &rows_iter);
+ dbus_message_iter_open_container (&iter,
+ DBUS_TYPE_ARRAY,
+ "as",
+ &rows_iter);
+
+ cont = TRUE;
- while (tracker_db_cursor_iter_next (cursor, &loop_error)) {
+ while (tracker_db_cursor_iter_next (cursor, &loop_error) && cont) {
DBusMessageIter cols_iter;
guint i;
@@ -214,42 +243,24 @@ query_callback (TrackerDBCursor *cursor, GError *error, gpointer user_data)
break;
}
- dbus_message_iter_open_container (&rows_iter, DBUS_TYPE_ARRAY,
- "s", &cols_iter);
+ dbus_message_iter_open_container (&rows_iter,
+ DBUS_TYPE_ARRAY,
+ "s",
+ &cols_iter);
- for (i = 0; i < cols; i++) {
+ for (i = 0; i < cols && cont; i++, length++) {
const gchar *result_str;
result_str = tracker_db_cursor_get_string (cursor, i);
- length++;
-
dbus_message_iter_append_basic (&cols_iter, DBUS_TYPE_STRING, &result_str);
- /* I *know* that this is some arbitrary number that doesn't seem to
- * resemble anything. In fact it's what I experimentally measured to
- * be a good value on a default Debian testing which has
- * max_message_size set to 1 000 000 000 in session.conf. I didn't have
- * the feeling that this value was very much respected, as the size
- * of the DBusMessage when libdbus decided to exit() the process was
- * around 160 MB, and not ~ 1000 MB. So if you take 160 MB and you
- * devide it by 1475760 you have an average string size of ~ 108
- * bytes plus DBusMessage's overhead. If that makes this number less
- * arbitrary for you, then fine.
- *
- * I really hope that the libdbus people get to their senses and
- * either stop doing their exit() nonsense in a library, and instead
- * return a clean DBusError or something, or create crystal clear
- * clarity about the maximum size of a message. And make it both so
- * that I can get this length at runtime (without having to parse
- * libdbus's own configuration files) and my DBusMessage's current
- * total length. As far as I know are both not possible. So that for
- * me means that libdbus's exit() is unacceptable.*/
-
- if (length > 1475760) {
- g_set_error (&loop_error, TRACKER_DB_INTERFACE_ERROR, TRACKER_DB_INTERRUPTED,
+ if (length > DBUS_ARBITRARY_MAX_MSG_SIZE) {
+ g_set_error (&loop_error,
+ TRACKER_DB_INTERFACE_ERROR,
+ TRACKER_DB_INTERRUPTED,
"resultset of the query is too large");
- dbus_message_iter_close_container (&rows_iter, &cols_iter);
- goto breakout;
+
+ cont = FALSE;
}
}
@@ -257,8 +268,6 @@ query_callback (TrackerDBCursor *cursor, GError *error, gpointer user_data)
dbus_message_iter_close_container (&rows_iter, &cols_iter);
}
-breakout:
-
dbus_message_iter_close_container (&iter, &rows_iter);
if (loop_error == NULL) {
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]