summaryrefslogtreecommitdiffstats
path: root/daemon.c
diff options
context:
space:
mode:
authorRené Scharfe <l.s.r@web.de>2015-10-24 14:23:20 +0200
committerJunio C Hamano <gitster@pobox.com>2015-11-03 00:01:23 +0100
commitb1b49ff8d42a21ade6a72b40a147fd3eaff3db8d (patch)
tree89bcdf62b5ce148889b0517ff58c1996051624d6 /daemon.c
parentrun-command: factor out child_process_clear() (diff)
downloadgit-b1b49ff8d42a21ade6a72b40a147fd3eaff3db8d.tar.xz
git-b1b49ff8d42a21ade6a72b40a147fd3eaff3db8d.zip
daemon: plug memory leak
Call child_process_clear() when a child ends to release the memory allocated for its environment. This is necessary because unlike all other users of start_command() we don't call finish_command(), which would have taken care of that for us. This leak was introduced by f063d38b (daemon: use cld->env_array when re-spawning). Signed-off-by: Rene Scharfe <l.s.r@web.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to '')
-rw-r--r--daemon.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/daemon.c b/daemon.c
index 4be10914e6..385934d46e 100644
--- a/daemon.c
+++ b/daemon.c
@@ -802,6 +802,7 @@ static void check_dead_children(void)
/* remove the child */
*cradle = blanket->next;
live_children--;
+ child_process_clear(&blanket->cld);
free(blanket);
} else
cradle = &blanket->next;