summaryrefslogtreecommitdiff
path: root/remote-curl.c
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2012-09-30 05:28:24 (GMT)
committerJunio C Hamano <gitster@pobox.com>2012-09-30 05:28:25 (GMT)
commitfb1e4a85bf7eb2df819a888d7db3ecececa1b7fc (patch)
tree0d684a95ff8879c5fbfcf93475c46c7a7255279d /remote-curl.c
parentc318040a3633475b591d9b9ece5877df415cf1d8 (diff)
parent02572c2e3afcc200936260f48863447726212a7c (diff)
downloadgit-fb1e4a85bf7eb2df819a888d7db3ecececa1b7fc.zip
git-fb1e4a85bf7eb2df819a888d7db3ecececa1b7fc.tar.gz
git-fb1e4a85bf7eb2df819a888d7db3ecececa1b7fc.tar.bz2
Merge branch 'jk/smart-http-switch'
Allows users to turn off smart-http when talking to dumb-only servers. * jk/smart-http-switch: remote-curl: let users turn off smart http remote-curl: rename is_http variable
Diffstat (limited to 'remote-curl.c')
-rw-r--r--remote-curl.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/remote-curl.c b/remote-curl.c
index a269608..10fa8f1 100644
--- a/remote-curl.c
+++ b/remote-curl.c
@@ -95,15 +95,16 @@ static struct discovery* discover_refs(const char *service)
struct strbuf buffer = STRBUF_INIT;
struct discovery *last = last_discovery;
char *refs_url;
- int http_ret, is_http = 0;
+ int http_ret, maybe_smart = 0;
if (last && !strcmp(service, last->service))
return last;
free_discovery(last);
strbuf_addf(&buffer, "%sinfo/refs", url);
- if (!prefixcmp(url, "http://") || !prefixcmp(url, "https://")) {
- is_http = 1;
+ if ((!prefixcmp(url, "http://") || !prefixcmp(url, "https://")) &&
+ git_env_bool("GIT_SMART_HTTP", 1)) {
+ maybe_smart = 1;
if (!strchr(url, '?'))
strbuf_addch(&buffer, '?');
else
@@ -131,7 +132,7 @@ static struct discovery* discover_refs(const char *service)
last->buf_alloc = strbuf_detach(&buffer, &last->len);
last->buf = last->buf_alloc;
- if (is_http && 5 <= last->len && last->buf[4] == '#') {
+ if (maybe_smart && 5 <= last->len && last->buf[4] == '#') {
/* smart HTTP response; validate that the service
* pkt-line matches our request.
*/