diff options
author | Marcel Holtmann <marcel@holtmann.org> | 2012-12-16 01:06:33 +0100 |
---|---|---|
committer | Marcel Holtmann <marcel@holtmann.org> | 2012-12-16 01:06:33 +0100 |
commit | 60be3174a3cf5e9707c92e90d4adc007a31b9692 (patch) | |
tree | f0e0b07266d9f259e750ad925cfad6560d6eacfc /gdbus/client.c | |
parent | fefe4edf13f576523e130bc74916daf25f6fb557 (diff) | |
download | bluez-60be3174a3cf5e9707c92e90d4adc007a31b9692.tar.gz |
gdbus: Fix issue with unref of client while parsing interfaces
Diffstat (limited to 'gdbus/client.c')
-rw-r--r-- | gdbus/client.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/gdbus/client.c b/gdbus/client.c index 670f6a743..76e4cc17f 100644 --- a/gdbus/client.c +++ b/gdbus/client.c @@ -675,7 +675,11 @@ static void interfaces_added(GDBusClient *client, DBusMessage *msg) dbus_message_iter_get_basic(&iter, &path); dbus_message_iter_next(&iter); + g_dbus_client_ref(client); + parse_interfaces(client, path, &iter); + + g_dbus_client_unref(client); } static void interfaces_removed(GDBusClient *client, DBusMessage *msg) @@ -697,6 +701,8 @@ static void interfaces_removed(GDBusClient *client, DBusMessage *msg) dbus_message_iter_recurse(&iter, &entry); + g_dbus_client_ref(client); + while (dbus_message_iter_get_arg_type(&entry) == DBUS_TYPE_STRING) { const char *interface; @@ -704,6 +710,8 @@ static void interfaces_removed(GDBusClient *client, DBusMessage *msg) proxy_remove(client, path, interface); dbus_message_iter_next(&entry); } + + g_dbus_client_unref(client); } static void parse_managed_objects(GDBusClient *client, DBusMessage *msg) |