summaryrefslogtreecommitdiffstats
path: root/transport.c
diff options
context:
space:
mode:
authorBrandon Williams <bmwill@google.com>2018-05-17 00:57:55 +0200
committerJunio C Hamano <gitster@pobox.com>2018-05-17 23:19:42 +0200
commite03c4e084d89f31dd4569b085d88b60758a54cd1 (patch)
treed7ea8f64e79f760a8e9cf48524308d63d3acebb7 /transport.c
parentpull: convert get_tracking_branch to use refspec_item_init (diff)
downloadgit-e03c4e084d89f31dd4569b085d88b60758a54cd1.tar.xz
git-e03c4e084d89f31dd4569b085d88b60758a54cd1.zip
transport: convert transport_push to use struct refspec
Convert the logic in 'transport_push()' which calculates a list of ref-prefixes to use 'struct refspec'. Signed-off-by: Brandon Williams <bmwill@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to '')
-rw-r--r--transport.c17
1 files changed, 9 insertions, 8 deletions
diff --git a/transport.c b/transport.c
index 3ad4d37dc0..181db4d4d0 100644
--- a/transport.c
+++ b/transport.c
@@ -1111,21 +1111,22 @@ int transport_push(struct transport *transport,
int porcelain = flags & TRANSPORT_PUSH_PORCELAIN;
int pretend = flags & TRANSPORT_PUSH_DRY_RUN;
int push_ret, ret, err;
- struct refspec_item *tmp_rs;
+ struct refspec tmp_rs = REFSPEC_INIT_PUSH;
struct argv_array ref_prefixes = ARGV_ARRAY_INIT;
int i;
if (check_push_refs(local_refs, refspec_nr, refspec) < 0)
return -1;
- tmp_rs = parse_push_refspec(refspec_nr, refspec);
- for (i = 0; i < refspec_nr; i++) {
+ refspec_appendn(&tmp_rs, refspec, refspec_nr);
+ for (i = 0; i < tmp_rs.nr; i++) {
+ const struct refspec_item *item = &tmp_rs.items[i];
const char *prefix = NULL;
- if (tmp_rs[i].dst)
- prefix = tmp_rs[i].dst;
- else if (tmp_rs[i].src && !tmp_rs[i].exact_sha1)
- prefix = tmp_rs[i].src;
+ if (item->dst)
+ prefix = item->dst;
+ else if (item->src && !item->exact_sha1)
+ prefix = item->src;
if (prefix) {
const char *glob = strchr(prefix, '*');
@@ -1142,7 +1143,7 @@ int transport_push(struct transport *transport,
&ref_prefixes);
argv_array_clear(&ref_prefixes);
- free_refspec(refspec_nr, tmp_rs);
+ refspec_clear(&tmp_rs);
if (flags & TRANSPORT_PUSH_ALL)
match_flags |= MATCH_REFS_ALL;