(cc: Duy, who might enjoy this walk through history)
Hi,

Alexander Mills wrote:

> git clone --single-branch=<sha>
>
> doesn't seem to work?

I've occasionally wanted something like this (actually, I've wanted to
pass a refname like "refs/meta/config").  builtin/clone.c contains

        static struct ref *find_remote_branch(const struct ref *refs, const 
char *branch)
        {
                struct ref *ref;
                struct strbuf head = STRBUF_INIT;
                strbuf_addstr(&head, "refs/heads/");
                strbuf_addstr(&head, branch);
                ref = find_ref_by_name(refs, head.buf);
                strbuf_release(&head);

                if (ref)
                        return ref;

So far, what one would expect.

                strbuf_addstr(&head, "refs/tags/");
                strbuf_addstr(&head, branch);
                ref = find_ref_by_name(refs, head.buf);
                strbuf_release(&head);

Wait a second: a tag isn't a branch, so why do we accept it as a
value for --branch?  So this is stretching definitions a little
already.

"git log -L:find_remote_branch:builtin/clone.c" tells me this is from
v1.7.10-rc0~125^2~3 (clone: allow --branch to take a tag, 2012-01-16):

        Because a tag ref cannot be put to HEAD, HEAD will become detached.
        This is consistent with "git checkout <tag>".

I think ideally we could first check for a sha1 and then try the full
set of patterns from ref_rev_parse_rules.  What do you think?  Would
you be interested in taking a stab at it?

Thanks,
Jonathan

Reply via email to