diff options
author | Jeff King <peff@peff.net> | 2008-10-29 05:17:55 +0000 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2008-11-01 23:48:39 -0700 |
commit | 30affa1e9a15e848f77c9c14544dd6dd593559d5 (patch) | |
tree | 88582765056b932f4ea9bb9cd93464cb7cf29830 | |
parent | 1442171bc913a9cddae5c6ad0d0a4be3a1ca86e8 (diff) | |
download | git-30affa1e9a15e848f77c9c14544dd6dd593559d5.tar.gz git-30affa1e9a15e848f77c9c14544dd6dd593559d5.tar.xz |
send-pack: do not send out single-level refs such as refs/stash
Since no version of receive-pack accepts these "funny refs", we should
mirror the check when considering the list of refs to send. IOW, don't
even make them eligible for matching or mirroring.
Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r-- | builtin-send-pack.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/builtin-send-pack.c b/builtin-send-pack.c index 2af9f2934..301f23043 100644 --- a/builtin-send-pack.c +++ b/builtin-send-pack.c @@ -132,7 +132,13 @@ static struct ref *remote_refs, **remote_tail; static int one_local_ref(const char *refname, const unsigned char *sha1, int flag, void *cb_data) { struct ref *ref; - int len = strlen(refname) + 1; + int len; + + /* we already know it starts with refs/ to get here */ + if (check_ref_format(refname + 5)) + return 0; + + len = strlen(refname) + 1; ref = xcalloc(1, sizeof(*ref) + len); hashcpy(ref->new_sha1, sha1); memcpy(ref->name, refname, len); |