[tracker/multi-insert: 9/16] tracker-store: multi-insert: Fix various problems in server impl.
- From: Aleksander Morgado <aleksm src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/multi-insert: 9/16] tracker-store: multi-insert: Fix various problems in server impl.
- Date: Wed, 13 Oct 2010 14:55:00 +0000 (UTC)
commit a76047e607a1ceb67be1ee548cd9a9f63ec1036e
Author: Philip Van Hoof <philip codeminded be>
Date: Thu Oct 7 14:31:28 2010 +0200
tracker-store: multi-insert: Fix various problems in server impl.
src/tracker-store/tracker-steroids.c | 46 ++++++++++++++++++++++++---------
1 files changed, 33 insertions(+), 13 deletions(-)
---
diff --git a/src/tracker-store/tracker-steroids.c b/src/tracker-store/tracker-steroids.c
index 54dadee..33c7163 100644
--- a/src/tracker-store/tracker-steroids.c
+++ b/src/tracker-store/tracker-steroids.c
@@ -186,9 +186,10 @@ update_array_callback (GError *error, gpointer user_data)
info->array_info.seen++;
+ if (!info->array_info.errors)
+ info->array_info.errors = g_ptr_array_new ();
+
if (error) {
- if (!info->array_info.errors)
- info->array_info.errors = g_ptr_array_new ();
g_ptr_array_add (info->array_info.errors, g_error_copy (error));
} else {
g_ptr_array_add (info->array_info.errors, NULL);
@@ -204,7 +205,7 @@ update_array_callback (GError *error, gpointer user_data)
dbus_message_iter_init_append (reply, &iter);
dbus_message_iter_open_container (&iter, DBUS_TYPE_ARRAY, "ss", &subiter);
- for (i = 0; info->array_info.errors->len; i++) {
+ for (i = 0; i < info->array_info.errors->len; i++) {
GError *error = g_ptr_array_index (info->array_info.errors, i);
const gchar *str = "";
const gchar *message = "";
@@ -526,7 +527,7 @@ steroids_query (TrackerSteroids *steroids,
return;
}
- info = g_slice_new (ClientInfo);
+ info = g_slice_new0 (ClientInfo);
info->connection = dbus_connection_ref (connection);
info->call_message = dbus_message_ref (message);
info->request_id = request_id;
@@ -632,7 +633,7 @@ steroids_update (TrackerSteroids *steroids,
__FUNCTION__,
fd);
- info = g_slice_new (ClientInfo);
+ info = g_slice_new0 (ClientInfo);
info->connection = dbus_connection_ref (connection);
info->call_message = dbus_message_ref (message);
info->request_id = request_id;
@@ -809,7 +810,7 @@ steroids_update_array (TrackerSteroids *steroids,
__FUNCTION__,
fd);
- info = g_slice_new (ClientInfo);
+ info = g_slice_new0 (ClientInfo);
info->connection = dbus_connection_ref (connection);
info->call_message = dbus_message_ref (message);
info->request_id = request_id;
@@ -822,9 +823,29 @@ steroids_update_array (TrackerSteroids *steroids,
g_buffered_input_stream_set_buffer_size (G_BUFFERED_INPUT_STREAM (data_input_stream),
TRACKER_STEROIDS_BUFFER_SIZE);
- info->array_info.query_count = g_data_input_stream_read_int32 (data_input_stream,
- NULL,
- &error);
+ info->array_info.query_count = g_data_input_stream_read_uint32 (data_input_stream,
+ NULL,
+ &error);
+
+ if (error) {
+ reply = dbus_message_new_error (info->call_message,
+ TRACKER_STEROIDS_INTERFACE ".UpdateError",
+ error->message);
+ dbus_connection_send (connection, reply, NULL);
+ dbus_message_unref (reply);
+
+ tracker_dbus_request_failed (request_id,
+ NULL,
+ NULL,
+ error->message);
+
+ g_object_unref (data_input_stream);
+ g_object_unref (input_stream);
+ g_error_free (error);
+ client_info_destroy (info);
+
+ return;
+ }
info->array_info.seen = 0;
query_array = g_new0 (gchar*, info->array_info.query_count + 1);
@@ -889,12 +910,11 @@ steroids_update_array (TrackerSteroids *steroids,
return;
}
- g_object_unref (data_input_stream);
- g_object_unref (input_stream);
-
- info->array_info.query_count++;
}
+ g_object_unref (data_input_stream);
+ g_object_unref (input_stream);
+
for (i = 0; query_array[i] != NULL; i++) {
tracker_dbus_request_debug (request_id,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]