gio: fix small memory leak on local xattr

g_strconcat() allocates memory, it needs to be freed.

==10653== 1,400 bytes in 50 blocks are definitely lost in loss record
1,838 of 1,851
==10653==    at 0x4A0645D: malloc (in
/usr/lib64/valgrind/vgpreload_memcheck-amd64-linux.so)
==10653==    by 0x54ACB22: g_malloc (gmem.c:102)
==10653==    by 0x54ACE4D: g_malloc_n (gmem.c:343)
==10653==    by 0x54C8463: g_strconcat (gstrfuncs.c:589)
==10653==    by 0x4D6ED38: get_xattrs_from_fd (glocalfileinfo.c:660)
==10653==    by 0x4D71622:
_g_local_file_info_get_from_fd (glocalfileinfo.c:2028)
==10653==    by 0x4D731A0:
g_local_file_input_stream_query_info (glocalfileinputstream.c:356)
==10653==    by 0x4C996D8:
g_file_input_stream_query_info (gfileinputstream.c:148)
==10653==    by 0x4C863F6: file_copy_fallback (gfile.c:3120)
==10653==    by 0x4C86DD2: g_file_copy (gfile.c:3398)

https://bugzilla.gnome.org/show_bug.cgi?id=722357
This commit is contained in:
Marc-André Lureau 2014-01-16 18:02:18 +01:00 committed by Matthias Clasen
parent fabdf80c7d
commit d3c729bf0e

View File

@ -664,6 +664,7 @@ get_xattrs_from_fd (int fd,
g_free (escaped_attr); g_free (escaped_attr);
get_one_xattr_from_fd (fd, info, gio_attr, attr); get_one_xattr_from_fd (fd, info, gio_attr, attr);
g_free (gio_attr);
} }
len = strlen (attr) + 1; len = strlen (attr) + 1;