fetch: convert get_ref_map to take a struct refspec
Convert 'get_ref_map()' to take a 'struct refspec' as a parameter instead of a list of 'struct refspec_item'. Signed-off-by: Brandon Williams <bmwill@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
65a1301f2e
commit
65d96c8b7d
@ -337,7 +337,7 @@ static void find_non_local_tags(struct transport *transport,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static struct ref *get_ref_map(struct transport *transport,
|
static struct ref *get_ref_map(struct transport *transport,
|
||||||
struct refspec_item *refspecs, int refspec_count,
|
struct refspec *rs,
|
||||||
int tags, int *autotags)
|
int tags, int *autotags)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
@ -351,15 +351,16 @@ static struct ref *get_ref_map(struct transport *transport,
|
|||||||
|
|
||||||
const struct ref *remote_refs;
|
const struct ref *remote_refs;
|
||||||
|
|
||||||
for (i = 0; i < refspec_count; i++) {
|
for (i = 0; i < rs->nr; i++) {
|
||||||
if (!refspecs[i].exact_sha1) {
|
const struct refspec_item *item = &rs->items[i];
|
||||||
const char *glob = strchr(refspecs[i].src, '*');
|
if (!item->exact_sha1) {
|
||||||
|
const char *glob = strchr(item->src, '*');
|
||||||
if (glob)
|
if (glob)
|
||||||
argv_array_pushf(&ref_prefixes, "%.*s",
|
argv_array_pushf(&ref_prefixes, "%.*s",
|
||||||
(int)(glob - refspecs[i].src),
|
(int)(glob - item->src),
|
||||||
refspecs[i].src);
|
item->src);
|
||||||
else
|
else
|
||||||
expand_ref_prefix(&ref_prefixes, refspecs[i].src);
|
expand_ref_prefix(&ref_prefixes, item->src);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -367,13 +368,12 @@ static struct ref *get_ref_map(struct transport *transport,
|
|||||||
|
|
||||||
argv_array_clear(&ref_prefixes);
|
argv_array_clear(&ref_prefixes);
|
||||||
|
|
||||||
if (refspec_count) {
|
if (rs->nr) {
|
||||||
struct refspec_item *fetch_refspec;
|
struct refspec *fetch_refspec;
|
||||||
int fetch_refspec_nr;
|
|
||||||
|
|
||||||
for (i = 0; i < refspec_count; i++) {
|
for (i = 0; i < rs->nr; i++) {
|
||||||
get_fetch_map(remote_refs, &refspecs[i], &tail, 0);
|
get_fetch_map(remote_refs, &rs->items[i], &tail, 0);
|
||||||
if (refspecs[i].dst && refspecs[i].dst[0])
|
if (rs->items[i].dst && rs->items[i].dst[0])
|
||||||
*autotags = 1;
|
*autotags = 1;
|
||||||
}
|
}
|
||||||
/* Merge everything on the command line (but not --tags) */
|
/* Merge everything on the command line (but not --tags) */
|
||||||
@ -400,16 +400,13 @@ static struct ref *get_ref_map(struct transport *transport,
|
|||||||
* by ref_remove_duplicates() in favor of one of these
|
* by ref_remove_duplicates() in favor of one of these
|
||||||
* opportunistic entries with FETCH_HEAD_IGNORE.
|
* opportunistic entries with FETCH_HEAD_IGNORE.
|
||||||
*/
|
*/
|
||||||
if (refmap.nr) {
|
if (refmap.nr)
|
||||||
fetch_refspec = refmap.items;
|
fetch_refspec = &refmap;
|
||||||
fetch_refspec_nr = refmap.nr;
|
else
|
||||||
} else {
|
fetch_refspec = &transport->remote->fetch;
|
||||||
fetch_refspec = transport->remote->fetch.items;
|
|
||||||
fetch_refspec_nr = transport->remote->fetch.nr;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (i = 0; i < fetch_refspec_nr; i++)
|
for (i = 0; i < fetch_refspec->nr; i++)
|
||||||
get_fetch_map(ref_map, &fetch_refspec[i], &oref_tail, 1);
|
get_fetch_map(ref_map, &fetch_refspec->items[i], &oref_tail, 1);
|
||||||
} else if (refmap.nr) {
|
} else if (refmap.nr) {
|
||||||
die("--refmap option is only meaningful with command-line refspec(s).");
|
die("--refmap option is only meaningful with command-line refspec(s).");
|
||||||
} else {
|
} else {
|
||||||
@ -1136,7 +1133,7 @@ static int do_fetch(struct transport *transport,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
ref_map = get_ref_map(transport, rs->items, rs->nr, tags, &autotags);
|
ref_map = get_ref_map(transport, rs, tags, &autotags);
|
||||||
if (!update_head_ok)
|
if (!update_head_ok)
|
||||||
check_not_current_branch(ref_map);
|
check_not_current_branch(ref_map);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user