summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Stenberg <daniel@haxx.se>2018-11-02 23:46:01 +0100
committerDaniel Stenberg <daniel@haxx.se>2018-11-03 00:16:53 +0100
commit8e8b1c5a33796e5b08138689c0a24b3bfb5693fb (patch)
tree5173dac13278084a73559a974a772a021cccaa07
parentb28094833a971870fd8c07960b3b12bf6fbbaad3 (diff)
downloadcurl-bagder/url-shorthost-plus-port.tar.gz
url: a short host name + port is not a schemebagder/url-shorthost-plus-port
The function identifying a leading "scheme" part of the URL considered a few letters ending with a colon to be a scheme, making something like "short:80" to become an unknown scheme instead of a short host name and a port number. Extended test 1560 to verify. Reported-by: Hagai Auro Fixes #3220
-rw-r--r--lib/urlapi.c2
-rw-r--r--tests/libtest/lib1560.c3
2 files changed, 4 insertions, 1 deletions
diff --git a/lib/urlapi.c b/lib/urlapi.c
index 18a6076ff..e877dc726 100644
--- a/lib/urlapi.c
+++ b/lib/urlapi.c
@@ -238,7 +238,7 @@ bool Curl_is_absolute_url(const char *url, char *buf, size_t buflen)
#endif
for(i = 0; i < buflen && url[i]; ++i) {
char s = url[i];
- if(s == ':') {
+ if((s == ':') && (url[i + 1] == '/')) {
if(buf)
buf[i] = 0;
return TRUE;
diff --git a/tests/libtest/lib1560.c b/tests/libtest/lib1560.c
index 57469a906..6557e0567 100644
--- a/tests/libtest/lib1560.c
+++ b/tests/libtest/lib1560.c
@@ -128,6 +128,9 @@ struct querycase {
};
static struct testcase get_parts_list[] ={
+ {"boing:80",
+ "https | [11] | [12] | [13] | boing | 80 | / | [16] | [17]",
+ CURLU_DEFAULT_SCHEME, 0, CURLUE_OK},
{"http://[fd00:a41::50]:8080",
"http | [11] | [12] | [13] | [fd00:a41::50] | 8080 | / | [16] | [17]",
CURLU_DEFAULT_SCHEME, 0, CURLUE_OK},