summaryrefslogtreecommitdiffstats
path: root/remote-curl.c
diff options
context:
space:
mode:
authorJeff King <peff@peff.net>2013-09-28 10:35:10 +0200
committerJonathan Nieder <jrnieder@gmail.com>2013-10-15 01:57:04 +0200
commitc65d5692cd3434133c2e8f1a20074a261e0267f0 (patch)
tree27456795da2f1a648e4268d70687310bb7964b9f /remote-curl.c
parenthttp: update base URLs when we see redirects (diff)
downloadgit-c65d5692cd3434133c2e8f1a20074a261e0267f0.tar.xz
git-c65d5692cd3434133c2e8f1a20074a261e0267f0.zip
remote-curl: make refs_url a strbuf
In the discover_refs function, we use a strbuf named "buffer" for multiple purposes. First we build the info/refs URL in it, and then detach that to a bare pointer. Then, we use the same strbuf to store the result of fetching the refs. Let's instead keep a separate refs_url strbuf. This is less confusing, as the "buffer" strbuf is now used for only one thing. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Jonathan Nieder <jrnieder@gmail.com>
Diffstat (limited to 'remote-curl.c')
-rw-r--r--remote-curl.c15
1 files changed, 7 insertions, 8 deletions
diff --git a/remote-curl.c b/remote-curl.c
index 8ffd7ff7a7..af087267d6 100644
--- a/remote-curl.c
+++ b/remote-curl.c
@@ -185,8 +185,8 @@ static struct discovery* discover_refs(const char *service, int for_push)
struct strbuf exp = STRBUF_INIT;
struct strbuf type = STRBUF_INIT;
struct strbuf buffer = STRBUF_INIT;
+ struct strbuf refs_url = STRBUF_INIT;
struct discovery *last = last_discovery;
- char *refs_url;
int http_ret, maybe_smart = 0;
struct http_get_options options;
@@ -194,24 +194,23 @@ static struct discovery* discover_refs(const char *service, int for_push)
return last;
free_discovery(last);
- strbuf_addf(&buffer, "%sinfo/refs", url);
+ strbuf_addf(&refs_url, "%sinfo/refs", url);
if ((!prefixcmp(url, "http://") || !prefixcmp(url, "https://")) &&
git_env_bool("GIT_SMART_HTTP", 1)) {
maybe_smart = 1;
if (!strchr(url, '?'))
- strbuf_addch(&buffer, '?');
+ strbuf_addch(&refs_url, '?');
else
- strbuf_addch(&buffer, '&');
- strbuf_addf(&buffer, "service=%s", service);
+ strbuf_addch(&refs_url, '&');
+ strbuf_addf(&refs_url, "service=%s", service);
}
- refs_url = strbuf_detach(&buffer, NULL);
memset(&options, 0, sizeof(options));
options.content_type = &type;
options.no_cache = 1;
options.keep_error = 1;
- http_ret = http_get_strbuf(refs_url, &buffer, &options);
+ http_ret = http_get_strbuf(refs_url.buf, &buffer, &options);
switch (http_ret) {
case HTTP_OK:
break;
@@ -264,7 +263,7 @@ static struct discovery* discover_refs(const char *service, int for_push)
else
last->refs = parse_info_refs(last);
- free(refs_url);
+ strbuf_release(&refs_url);
strbuf_release(&exp);
strbuf_release(&type);
strbuf_release(&buffer);