diff options
Diffstat (limited to 'builtin/clone.c')
| -rw-r--r-- | builtin/clone.c | 17 | 
1 files changed, 8 insertions, 9 deletions
| diff --git a/builtin/clone.c b/builtin/clone.c index 7df5932b85..99e73dae85 100644 --- a/builtin/clone.c +++ b/builtin/clone.c @@ -14,6 +14,7 @@  #include "parse-options.h"  #include "fetch-pack.h"  #include "refs.h" +#include "refspec.h"  #include "tree.h"  #include "tree-walk.h"  #include "unpack-trees.h" @@ -546,7 +547,7 @@ static struct ref *find_remote_branch(const struct ref *refs, const char *branch  }  static struct ref *wanted_peer_refs(const struct ref *refs, -		struct refspec *refspec) +		struct refspec_item *refspec)  {  	struct ref *head = copy_ref(find_ref_by_name(refs, "HEAD"));  	struct ref *local_refs = head; @@ -823,7 +824,7 @@ static void write_refspec_config(const char *src_ref_prefix,  			} else if (remote_head_points_at) {  				const char *head = remote_head_points_at->name;  				if (!skip_prefix(head, "refs/heads/", &head)) -					die("BUG: remote HEAD points at non-head?"); +					BUG("remote HEAD points at non-head?");  				strbuf_addf(&value, "+%s:%s%s", remote_head_points_at->name,  						branch_top->buf, head); @@ -894,8 +895,7 @@ int cmd_clone(int argc, const char **argv, const char *prefix)  	int err = 0, complete_refs_before_fetch = 1;  	int submodule_progress; -	struct refspec *refspec; -	const char *fetch_pattern; +	struct refspec_item refspec;  	fetch_if_missing = 0; @@ -1077,8 +1077,7 @@ int cmd_clone(int argc, const char **argv, const char *prefix)  	if (option_required_reference.nr || option_optional_reference.nr)  		setup_reference(); -	fetch_pattern = value.buf; -	refspec = parse_fetch_refspec(1, &fetch_pattern); +	refspec_item_init(&refspec, value.buf, REFSPEC_FETCH);  	strbuf_reset(&value); @@ -1135,10 +1134,10 @@ int cmd_clone(int argc, const char **argv, const char *prefix)  	if (transport->smart_options && !deepen && !filter_options.choice)  		transport->smart_options->check_self_contained_and_connected = 1; -	refs = transport_get_remote_refs(transport); +	refs = transport_get_remote_refs(transport, NULL);  	if (refs) { -		mapped_refs = wanted_peer_refs(refs, refspec); +		mapped_refs = wanted_peer_refs(refs, &refspec);  		/*  		 * transport_get_remote_refs() may return refs with null sha-1  		 * in mapped_refs (see struct transport->get_refs_list @@ -1232,6 +1231,6 @@ int cmd_clone(int argc, const char **argv, const char *prefix)  	strbuf_release(&value);  	junk_mode = JUNK_LEAVE_ALL; -	free(refspec); +	refspec_item_clear(&refspec);  	return err;  } | 
