[tracker/multi-insert: 5/16] libtracker-bus: multi-insert: Handle memory for errors
- From: Aleksander Morgado <aleksm src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/multi-insert: 5/16] libtracker-bus: multi-insert: Handle memory for errors
- Date: Wed, 13 Oct 2010 14:54:40 +0000 (UTC)
commit 799a9968aa626d46006b59d96de40cc5d6f3ffd3
Author: Philip Van Hoof <philip codeminded be>
Date: Thu Oct 7 12:29:43 2010 +0200
libtracker-bus: multi-insert: Handle memory for errors
autogen.sh | 2 +-
src/libtracker-bus/tracker-bus-fd-update.c | 15 +++++++++++++--
2 files changed, 14 insertions(+), 3 deletions(-)
---
diff --git a/autogen.sh b/autogen.sh
index 4e919ac..c04cf49 100755
--- a/autogen.sh
+++ b/autogen.sh
@@ -8,7 +8,7 @@ test -z "$srcdir" && srcdir=.
PKG_NAME="tracker"
REQUIRED_AUTOMAKE_VERSION=1.11
-REQUIRED_VALA_VERSION=0.9.5
+REQUIRED_VALA_VERSION=0.11.0
(test -f $srcdir/configure.ac \
&& test -f $srcdir/README) || {
diff --git a/src/libtracker-bus/tracker-bus-fd-update.c b/src/libtracker-bus/tracker-bus-fd-update.c
index b1d0c26..2170c3c 100644
--- a/src/libtracker-bus/tracker-bus-fd-update.c
+++ b/src/libtracker-bus/tracker-bus-fd-update.c
@@ -204,6 +204,14 @@ sparql_update_fast_callback (DBusPendingCall *call,
}
static void
+sparql_update_array_error_free (gpointer data)
+{
+ if (data) {
+ g_error_free (data);
+ }
+}
+
+static void
sparql_update_array_fast_callback (DBusPendingCall *call,
void *user_data)
{
@@ -239,7 +247,7 @@ sparql_update_array_fast_callback (DBusPendingCall *call,
dbus_message_iter_init (reply, &iter);
dbus_message_iter_recurse (&iter, &subiter);
- errors = g_ptr_array_new_with_free_func ((GDestroyNotify) g_error_free);
+ errors = g_ptr_array_new_with_free_func (sparql_update_array_error_free);
while (dbus_message_iter_get_arg_type (&subiter) != DBUS_TYPE_INVALID) {
gchar *code, *message;
@@ -248,7 +256,10 @@ sparql_update_array_fast_callback (DBusPendingCall *call,
dbus_message_iter_get_basic (&subiter, &code);
dbus_message_iter_next (&subiter);
dbus_message_iter_get_basic (&subiter, &message);
- error = g_error_new_literal (TRACKER_SPARQL_ERROR, 0, message);
+ if (code && code[0] != '\0' && message && message[0] != '\0')
+ error = g_error_new_literal (TRACKER_SPARQL_ERROR, 0, message);
+ else
+ error = NULL;
g_free (code);
g_free (message);
g_ptr_array_add (errors, error);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]