aboutsummaryrefslogtreecommitdiffstats
path: root/src/directory.c
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2009-08-14 11:52:00 +0200
committerMax Kellermann <max@duempel.org>2009-08-14 11:52:00 +0200
commit7dddd9beda2bb0505758bb6a32cae6feb3215733 (patch)
treef3ec694012345f3e255c05c88771bee824aa3d3c /src/directory.c
parent5d6f7803e1059f527a70e541ed3945c19bd78c90 (diff)
downloadmpd-7dddd9beda2bb0505758bb6a32cae6feb3215733.tar.gz
mpd-7dddd9beda2bb0505758bb6a32cae6feb3215733.tar.xz
mpd-7dddd9beda2bb0505758bb6a32cae6feb3215733.zip
directory: free empty directories after removing them (memleak)
dirvec_delete() does not free the object, we have to call directory_free() afterwards.
Diffstat (limited to '')
-rw-r--r--src/directory.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/src/directory.c b/src/directory.c
index 85c24fd04..ef8c038a3 100644
--- a/src/directory.c
+++ b/src/directory.c
@@ -73,9 +73,14 @@ directory_prune_empty(struct directory *directory)
struct dirvec *dv = &directory->children;
for (i = dv->nr; --i >= 0; ) {
- directory_prune_empty(dv->base[i]);
- if (directory_is_empty(dv->base[i]))
- dirvec_delete(dv, dv->base[i]);
+ struct directory *child = dv->base[i];
+
+ directory_prune_empty(child);
+
+ if (directory_is_empty(child)) {
+ dirvec_delete(dv, child);
+ directory_free(child);
+ }
}
if (!dv->nr)
dirvec_destroy(dv);