summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2017-06-13 20:27:06 (GMT)
committerJunio C Hamano <gitster@pobox.com>2017-06-13 20:27:06 (GMT)
commit9451a7b629478790ad621d41b3f12ab8aa9097cc (patch)
tree4474d8fccfd958727325fb57b02dd2d781cf30be
parent87d4fdd9805edfe582bcbe92da638bb7eeb1725d (diff)
parenta56eea28c45a8f76e4167c4e6baa87e89b7be3bc (diff)
downloadgit-9451a7b629478790ad621d41b3f12ab8aa9097cc.zip
git-9451a7b629478790ad621d41b3f12ab8aa9097cc.tar.gz
git-9451a7b629478790ad621d41b3f12ab8aa9097cc.tar.bz2
Merge branch 'jk/drop-free-refspecs' into maint
Code clean-up. * jk/drop-free-refspecs: remote: drop free_refspecs() function
-rw-r--r--remote.c28
1 files changed, 6 insertions, 22 deletions
diff --git a/remote.c b/remote.c
index 32f137e..16eb39e 100644
--- a/remote.c
+++ b/remote.c
@@ -477,26 +477,6 @@ static void read_config(void)
alias_all_urls();
}
-/*
- * This function frees a refspec array.
- * Warning: code paths should be checked to ensure that the src
- * and dst pointers are always freeable pointers as well
- * as the refspec pointer itself.
- */
-static void free_refspecs(struct refspec *refspec, int nr_refspec)
-{
- int i;
-
- if (!refspec)
- return;
-
- for (i = 0; i < nr_refspec; i++) {
- free(refspec[i].src);
- free(refspec[i].dst);
- }
- free(refspec);
-}
-
static struct refspec *parse_refspec_internal(int nr_refspec, const char **refspec, int fetch, int verify)
{
int i;
@@ -610,7 +590,7 @@ static struct refspec *parse_refspec_internal(int nr_refspec, const char **refsp
* since it is only possible to reach this point from within
* the for loop above.
*/
- free_refspecs(rs, i+1);
+ free_refspec(i+1, rs);
return NULL;
}
die("Invalid refspec '%s'", refspec[i]);
@@ -621,7 +601,7 @@ int valid_fetch_refspec(const char *fetch_refspec_str)
struct refspec *refspec;
refspec = parse_refspec_internal(1, &fetch_refspec_str, 1, 1);
- free_refspecs(refspec, 1);
+ free_refspec(1, refspec);
return !!refspec;
}
@@ -638,6 +618,10 @@ struct refspec *parse_push_refspec(int nr_refspec, const char **refspec)
void free_refspec(int nr_refspec, struct refspec *refspec)
{
int i;
+
+ if (!refspec)
+ return;
+
for (i = 0; i < nr_refspec; i++) {
free(refspec[i].src);
free(refspec[i].dst);