mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-25 21:46:14 +01:00
gdbusmessage: Clean the cached arg0 when setting the message body
We're now caching arg0 but such value is not cleared when a new body is set as it's in the connection filter test cases where we've a leak as highlighted by both valgrind and leak sanitizer
This commit is contained in:
parent
c1fdfeddab
commit
8966099e9b
@ -1155,10 +1155,12 @@ g_dbus_message_set_body (GDBusMessage *message,
|
|||||||
|
|
||||||
if (message->body != NULL)
|
if (message->body != NULL)
|
||||||
g_variant_unref (message->body);
|
g_variant_unref (message->body);
|
||||||
|
|
||||||
|
g_clear_pointer (&message->arg0_cache, g_variant_unref);
|
||||||
|
|
||||||
if (body == NULL)
|
if (body == NULL)
|
||||||
{
|
{
|
||||||
message->body = NULL;
|
message->body = NULL;
|
||||||
message->arg0_cache = NULL;
|
|
||||||
g_dbus_message_set_signature (message, NULL);
|
g_dbus_message_set_signature (message, NULL);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -1172,8 +1174,6 @@ g_dbus_message_set_body (GDBusMessage *message,
|
|||||||
if (g_variant_is_of_type (message->body, G_VARIANT_TYPE_TUPLE) &&
|
if (g_variant_is_of_type (message->body, G_VARIANT_TYPE_TUPLE) &&
|
||||||
g_variant_n_children (message->body) > 0)
|
g_variant_n_children (message->body) > 0)
|
||||||
message->arg0_cache = g_variant_get_child_value (message->body, 0);
|
message->arg0_cache = g_variant_get_child_value (message->body, 0);
|
||||||
else
|
|
||||||
message->arg0_cache = NULL;
|
|
||||||
|
|
||||||
type_string = g_variant_get_type_string (body);
|
type_string = g_variant_get_type_string (body);
|
||||||
type_string_len = strlen (type_string);
|
type_string_len = strlen (type_string);
|
||||||
|
Loading…
Reference in New Issue
Block a user