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 /wt-status.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 'wt-status.c')
| -rw-r--r-- | wt-status.c | 29 | 
1 files changed, 15 insertions, 14 deletions
diff --git a/wt-status.c b/wt-status.c index 5db53775ab..c43d17355c 100644 --- a/wt-status.c +++ b/wt-status.c @@ -1082,29 +1082,29 @@ static char *read_line_from_git_path(const char *filename)  static int split_commit_in_progress(struct wt_status *s)  {  	int split_in_progress = 0; -	char *head = read_line_from_git_path("HEAD"); -	char *orig_head = read_line_from_git_path("ORIG_HEAD"); -	char *rebase_amend = read_line_from_git_path("rebase-merge/amend"); -	char *rebase_orig_head = read_line_from_git_path("rebase-merge/orig-head"); +	char *head, *orig_head, *rebase_amend, *rebase_orig_head; -	if (!head || !orig_head || !rebase_amend || !rebase_orig_head || +	if ((!s->amend && !s->nowarn && !s->workdir_dirty) ||  	    !s->branch || strcmp(s->branch, "HEAD")) -		return split_in_progress; +		return 0; -	if (!strcmp(rebase_amend, rebase_orig_head)) { -		if (strcmp(head, rebase_amend)) -			split_in_progress = 1; -	} else if (strcmp(orig_head, rebase_orig_head)) { -		split_in_progress = 1; -	} +	head = read_line_from_git_path("HEAD"); +	orig_head = read_line_from_git_path("ORIG_HEAD"); +	rebase_amend = read_line_from_git_path("rebase-merge/amend"); +	rebase_orig_head = read_line_from_git_path("rebase-merge/orig-head"); -	if (!s->amend && !s->nowarn && !s->workdir_dirty) -		split_in_progress = 0; +	if (!head || !orig_head || !rebase_amend || !rebase_orig_head) +		; /* fall through, no split in progress */ +	else if (!strcmp(rebase_amend, rebase_orig_head)) +		split_in_progress = !!strcmp(head, rebase_amend); +	else if (strcmp(orig_head, rebase_orig_head)) +		split_in_progress = 1;  	free(head);  	free(orig_head);  	free(rebase_amend);  	free(rebase_orig_head); +  	return split_in_progress;  } @@ -1168,6 +1168,7 @@ static int read_rebase_todolist(const char *fname, struct string_list *lines)  		abbrev_sha1_in_line(&line);  		string_list_append(lines, line.buf);  	} +	fclose(f);  	return 0;  }  | 
