diff options
author | Junio C Hamano <gitster@pobox.com> | 2013-12-03 23:33:10 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2013-12-03 23:47:18 +0100 |
commit | 50d829c11a3c82a8b23f2e165ab6944dfd9bbb36 (patch) | |
tree | d6de8d726bda5ac95f8278aa9492cc83b31e23ce /builtin/push.c | |
parent | Sync with 1.8.5.1 (diff) | |
download | git-50d829c11a3c82a8b23f2e165ab6944dfd9bbb36.tar.xz git-50d829c11a3c82a8b23f2e165ab6944dfd9bbb36.zip |
builtin/push.c: use strbuf instead of manual allocation
The command line arguments given to "git push" are massaged into
a list of refspecs in set_refspecs() function. This was implemented
using xmalloc, strcpy and friends, but it is much easier to read if
done using strbuf.
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'builtin/push.c')
-rw-r--r-- | builtin/push.c | 35 |
1 files changed, 14 insertions, 21 deletions
diff --git a/builtin/push.c b/builtin/push.c index 7b1b66c36a..76e4400c4a 100644 --- a/builtin/push.c +++ b/builtin/push.c @@ -41,29 +41,22 @@ static void set_refspecs(const char **refs, int nr) for (i = 0; i < nr; i++) { const char *ref = refs[i]; if (!strcmp("tag", ref)) { - char *tag; - int len; + struct strbuf tagref = STRBUF_INIT; if (nr <= ++i) die(_("tag shorthand without <tag>")); - len = strlen(refs[i]) + 11; - if (deleterefs) { - tag = xmalloc(len+1); - strcpy(tag, ":refs/tags/"); - } else { - tag = xmalloc(len); - strcpy(tag, "refs/tags/"); - } - strcat(tag, refs[i]); - ref = tag; - } else if (deleterefs && !strchr(ref, ':')) { - char *delref; - int len = strlen(ref)+1; - delref = xmalloc(len+1); - strcpy(delref, ":"); - strcat(delref, ref); - ref = delref; - } else if (deleterefs) - die(_("--delete only accepts plain target ref names")); + ref = refs[i]; + if (deleterefs) + strbuf_addf(&tagref, ":refs/tags/%s", ref); + else + strbuf_addf(&tagref, "refs/tags/%s", ref); + ref = strbuf_detach(&tagref, NULL); + } else if (deleterefs) { + struct strbuf delref = STRBUF_INIT; + if (strchr(ref, ':')) + die(_("--delete only accepts plain target ref names")); + strbuf_addf(&delref, ":%s", ref); + ref = strbuf_detach(&delref, NULL); + } add_refspec(ref); } } |