diff options
author | Daniel Barkalow <barkalow@iabervon.org> | 2008-04-26 21:53:12 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2008-04-27 02:36:18 +0200 |
commit | be885d96fe0ebed47e637f3b0dd24fc5902f7081 (patch) | |
tree | b4c0c29c4b58ffe95c7765ebd38e6089973d7b44 /http.c | |
parent | Make walker.fetch_ref() take a struct ref. (diff) | |
download | git-be885d96fe0ebed47e637f3b0dd24fc5902f7081.tar.xz git-be885d96fe0ebed47e637f3b0dd24fc5902f7081.zip |
Make ls-remote http://... list HEAD, like for git://...
This makes a struct ref able to represent a symref, and makes http.c
able to recognize one, and makes transport.c look for "HEAD" as a ref
in the list, and makes it dereference symrefs for the resulting ref,
if any.
Signed-off-by: Daniel Barkalow <barkalow@iabervon.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'http.c')
-rw-r--r-- | http.c | 5 |
1 files changed, 4 insertions, 1 deletions
@@ -626,7 +626,10 @@ int http_fetch_ref(const char *base, struct ref *ref) strbuf_rtrim(&buffer); if (buffer.len == 40) ret = get_sha1_hex(buffer.buf, ref->old_sha1); - else + else if (!prefixcmp(buffer.buf, "ref: ")) { + ref->symref = xstrdup(buffer.buf + 5); + ret = 0; + } else ret = 1; } else { ret = error("Couldn't get %s for %s\n%s", |