diff options
| author | Junio C Hamano <gitster@pobox.com> | 2017-05-29 12:34:44 +0900 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2017-05-29 12:34:44 +0900 | 
| commit | 849e671b52e11d4a2f70d577dd2c806f3ca756fe (patch) | |
| tree | f564d4d2782856efcdcff278b385a989c031a6c1 /builtin/receive-pack.c | |
| parent | 137a2613a07e556fd77fe374c6f4edd2d5e1b1fc (diff) | |
| parent | 443a12f37be1c5967785b83bf04935fe357afb9b (diff) | |
| download | git-849e671b52e11d4a2f70d577dd2c806f3ca756fe.tar.gz | |
Merge branch 'js/plug-leaks'
Fix memory leaks pointed out by Coverity (and people).
* js/plug-leaks: (26 commits)
  checkout: fix memory leak
  submodule_uses_worktrees(): plug memory leak
  show_worktree(): plug memory leak
  name-rev: avoid leaking memory in the `deref` case
  remote: plug memory leak in match_explicit()
  add_reflog_for_walk: avoid memory leak
  shallow: avoid memory leak
  line-log: avoid memory leak
  receive-pack: plug memory leak in update()
  fast-export: avoid leaking memory in handle_tag()
  mktree: plug memory leaks reported by Coverity
  pack-redundant: plug memory leak
  setup_discovered_git_dir(): plug memory leak
  setup_bare_git_dir(): help static analysis
  split_commit_in_progress(): simplify & fix memory leak
  checkout: fix memory leak
  cat-file: fix memory leak
  mailinfo & mailsplit: check for EOF while parsing
  status: close file descriptor after reading git-rebase-todo
  difftool: address a couple of resource/memory leaks
  ...
Diffstat (limited to 'builtin/receive-pack.c')
| -rw-r--r-- | builtin/receive-pack.c | 4 | 
1 files changed, 3 insertions, 1 deletions
diff --git a/builtin/receive-pack.c b/builtin/receive-pack.c index eb8b64bfce..b1706a5731 100644 --- a/builtin/receive-pack.c +++ b/builtin/receive-pack.c @@ -1028,7 +1028,8 @@ static const char *update(struct command *cmd, struct shallow_info *si)  {  	const char *name = cmd->ref_name;  	struct strbuf namespaced_name_buf = STRBUF_INIT; -	const char *namespaced_name, *ret; +	static char *namespaced_name; +	const char *ret;  	struct object_id *old_oid = &cmd->old_oid;  	struct object_id *new_oid = &cmd->new_oid; @@ -1039,6 +1040,7 @@ static const char *update(struct command *cmd, struct shallow_info *si)  	}  	strbuf_addf(&namespaced_name_buf, "%s%s", get_git_namespace(), name); +	free(namespaced_name);  	namespaced_name = strbuf_detach(&namespaced_name_buf, NULL);  	if (is_ref_checked_out(namespaced_name)) {  | 
