GDBusMessage: fix leak of GError
authorRyan Lortie <desrt@desrt.ca>
Fri, 21 Oct 2011 18:05:10 +0000 (14:05 -0400)
committerRyan Lortie <desrt@desrt.ca>
Fri, 21 Oct 2011 19:18:20 +0000 (15:18 -0400)
commit9c07e7dc90b1331dab9f0e960d119d0889c7d585
tree65e3df599ad85fed2eeba2ff30571bed3cef8821
parent3d13ee1b5ff2a2ad5f32704cc5f071167a8852a6
GDBusMessage: fix leak of GError

As part of the deserialisation process of a zero-length array in the
DBus wire format, parse_value_from_blob() recursively calls itself with
the expectation of failing (as can be seen by the assert immediately
following).

It passes &local_error to this always-failing call and then fails to
free it (indeed, to use it at all).  The result is that the GError is
leaked.

Fix it by passing in NULL instead, so that the GError is never created
in the first place.

https://bugzilla.gnome.org/show_bug.cgi?id=662411
gio/gdbusmessage.c