diff options
| author | Junio C Hamano <gitster@pobox.com> | 2010-08-31 16:23:35 -0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2010-08-31 16:23:35 -0700 | 
| commit | d7cc7c971f58091a2f2a15d2dca0fab0bd2ca310 (patch) | |
| tree | 3d626a01b1868e78e5a80ba58cadfcbdd9a608b3 | |
| parent | 633142d86874ee8ce79a23ee4346f32e6271faad (diff) | |
| parent | 730220de8be669257287e9a1f5dde349ace5426a (diff) | |
| download | git-d7cc7c971f58091a2f2a15d2dca0fab0bd2ca310.tar.gz | |
Merge branch 'tr/maint-no-unquote-plus'
* tr/maint-no-unquote-plus:
  Do not unquote + into ' ' in URLs
| -rwxr-xr-x | t/t5601-clone.sh | 10 | ||||
| -rw-r--r-- | url.c | 11 | 
2 files changed, 14 insertions, 7 deletions
| diff --git a/t/t5601-clone.sh b/t/t5601-clone.sh index 8abb71afcd..4431dfd02b 100755 --- a/t/t5601-clone.sh +++ b/t/t5601-clone.sh @@ -178,8 +178,14 @@ test_expect_success 'clone respects global branch.autosetuprebase' '  test_expect_success 'respect url-encoding of file://' '  	git init x+y && -	test_must_fail git clone "file://$PWD/x+y" xy-url && -	git clone "file://$PWD/x%2By" xy-url +	git clone "file://$PWD/x+y" xy-url-1 && +	git clone "file://$PWD/x%2By" xy-url-2 +' + +test_expect_success 'do not query-string-decode + in URLs' ' +	rm -rf x+y && +	git init "x y" && +	test_must_fail git clone "file://$PWD/x+y" xy-no-plus  '  test_expect_success 'do not respect url-encoding of non-url path' ' @@ -67,7 +67,8 @@ static int url_decode_char(const char *q)  	return val;  } -static char *url_decode_internal(const char **query, const char *stop_at, struct strbuf *out) +static char *url_decode_internal(const char **query, const char *stop_at, +				 struct strbuf *out, int decode_plus)  {  	const char *q = *query; @@ -90,7 +91,7 @@ static char *url_decode_internal(const char **query, const char *stop_at, struct  			}  		} -		if (c == '+') +		if (decode_plus && c == '+')  			strbuf_addch(out, ' ');  		else  			strbuf_addch(out, c); @@ -110,17 +111,17 @@ char *url_decode(const char *url)  		strbuf_add(&out, url, colon - url);  		url = colon;  	} -	return url_decode_internal(&url, NULL, &out); +	return url_decode_internal(&url, NULL, &out, 0);  }  char *url_decode_parameter_name(const char **query)  {  	struct strbuf out = STRBUF_INIT; -	return url_decode_internal(query, "&=", &out); +	return url_decode_internal(query, "&=", &out, 1);  }  char *url_decode_parameter_value(const char **query)  {  	struct strbuf out = STRBUF_INIT; -	return url_decode_internal(query, "&", &out); +	return url_decode_internal(query, "&", &out, 1);  } | 
