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:47:54 +0100 |
commit | a60a65eeeb5033d3de4e4803b2ef5ed6c6919b51 (patch) | |
tree | 43131277f19ee8cb4e6f5ff1e2503cdbd36d76b6 | |
parent | 752c73ab4857f6ca852e5fc4d2700adc585edf07 (diff) | |
download | pacrunner-a60a65eeeb5033d3de4e4803b2ef5ed6c6919b51.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) |