diff options
author | Marcel Holtmann <marcel@holtmann.org> | 2012-12-16 01:06:33 +0100 |
---|---|---|
committer | Marcel Holtmann <marcel@holtmann.org> | 2012-12-19 03:46:39 +0100 |
commit | 026e64f084fe4cb03b12c47b40e500fd74a14ff4 (patch) | |
tree | 041a108b7ec3fde697092ee028547f4fea3e421c | |
parent | 5df60547e319259df4bfabf56ce0cc6e2a96eb42 (diff) | |
download | mmsd-026e64f084fe4cb03b12c47b40e500fd74a14ff4.tar.gz |
gdbus: Fix issue with unref of client while parsing interfaces
-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 670f6a7..76e4cc1 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) |