diff options
author | Shawn O. Pearce <spearce@spearce.org> | 2007-09-25 00:13:25 -0400 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2007-09-24 23:25:26 -0700 |
commit | 4491e62ae932d5774f628d1bd3be663c11058a73 (patch) | |
tree | 4a47cf0b2da34de6a673703e388dadd3442c1a6b | |
parent | 7dfee372b08f653c2709c90bea986e4ed608f410 (diff) | |
download | git-4491e62ae932d5774f628d1bd3be663c11058a73.tar.gz git-4491e62ae932d5774f628d1bd3be663c11058a73.tar.xz |
Prevent send-pack from segfaulting when a branch doesn't match
If `git push url foo` can't find a local branch named foo we can't
match it to any remote branch as the local branch is NULL and its
name is probably at position 0x34 in memory. On most systems that
isn't a valid address for git-send-pack's virtual address space
and we segfault.
If we can't find a source match and we have no destination we
need to abort the match function early before we try to match the
destination against the remote.
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r-- | remote.c | 5 |
1 files changed, 4 insertions, 1 deletions
@@ -610,8 +610,11 @@ static int match_explicit(struct ref *src, struct ref *dst, if (!matched_src) errs = 1; - if (!dst_value) + if (!dst_value) { + if (!matched_src) + return errs; dst_value = matched_src->name; + } switch (count_refspec_match(dst_value, dst, &matched_dst)) { case 1: |