diff options
| author | Junio C Hamano <gitster@pobox.com> | 2011-10-21 10:49:26 -0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2011-10-21 10:49:26 -0700 | 
| commit | d25a265220f7e9a50693d0ec4bb05c7be0539d69 (patch) | |
| tree | 34bf878cbc1181b0614ad7ba210d48f0ad550fa3 /http-push.c | |
| parent | e63f87a6f7a4e55f50e67b112f26d9a1e4e7f3ab (diff) | |
| parent | baf18fc261ca475343fe3cb9cd2c0dded4bc1bb7 (diff) | |
| download | git-d25a265220f7e9a50693d0ec4bb05c7be0539d69.tar.gz | |
Merge branch 'nd/maint-autofix-tag-in-head' into maint
* nd/maint-autofix-tag-in-head:
  Accept tags in HEAD or MERGE_HEAD
  merge: remove global variable head[]
  merge: use return value of resolve_ref() to determine if HEAD is invalid
  merge: keep stash[] a local variable
Conflicts:
	builtin/merge.c
Diffstat (limited to 'http-push.c')
| -rw-r--r-- | http-push.c | 8 | 
1 files changed, 4 insertions, 4 deletions
| diff --git a/http-push.c b/http-push.c index 376331a76f..44f814cda2 100644 --- a/http-push.c +++ b/http-push.c @@ -1606,10 +1606,10 @@ static void fetch_symref(const char *path, char **symref, unsigned char *sha1)  	strbuf_release(&buffer);  } -static int verify_merge_base(unsigned char *head_sha1, unsigned char *branch_sha1) +static int verify_merge_base(unsigned char *head_sha1, struct ref *remote)  { -	struct commit *head = lookup_commit(head_sha1); -	struct commit *branch = lookup_commit(branch_sha1); +	struct commit *head = lookup_commit_or_die(head_sha1, "HEAD"); +	struct commit *branch = lookup_commit_or_die(remote->old_sha1, remote->name);  	struct commit_list *merge_bases = get_merge_bases(head, branch, 1);  	return (merge_bases && !merge_bases->next && merge_bases->item == branch); @@ -1680,7 +1680,7 @@ static int delete_remote_branch(const char *pattern, int force)  			return error("Remote branch %s resolves to object %s\nwhich does not exist locally, perhaps you need to fetch?", remote_ref->name, sha1_to_hex(remote_ref->old_sha1));  		/* Remote branch must be an ancestor of remote HEAD */ -		if (!verify_merge_base(head_sha1, remote_ref->old_sha1)) { +		if (!verify_merge_base(head_sha1, remote_ref)) {  			return error("The branch '%s' is not an ancestor "  				     "of your current HEAD.\n"  				     "If you are sure you want to delete it," | 
