summaryrefslogtreecommitdiff
path: root/uclient.c
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2014-03-22 15:35:50 +0100
committerFelix Fietkau <nbd@openwrt.org>2014-03-22 15:35:50 +0100
commit5f2e60972941c1ca1a6fa572b39e18cbc58137d9 (patch)
tree227a3c1ab87979008d5f74ab7ff37e3d323cca3f /uclient.c
parent7401d5c1100a35dd5eafa602fad6d334dea98225 (diff)
downloaduclient-5f2e60972941c1ca1a6fa572b39e18cbc58137d9.tar.gz
pass the initial / from uclient core to the proto handler
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
Diffstat (limited to 'uclient.c')
-rw-r--r--uclient.c34
1 files changed, 20 insertions, 14 deletions
diff --git a/uclient.c b/uclient.c
index 095fc93..4125dc2 100644
--- a/uclient.c
+++ b/uclient.c
@@ -12,8 +12,9 @@ static struct uclient_url *uclient_get_url(const char *url_str)
const struct uclient_backend *backend;
const char * const *prefix = NULL;
struct uclient_url *url;
- char *url_buf, *next;
- int i;
+ const char *location;
+ char *host_buf, *uri_buf, *next;
+ int i, host_len;
for (i = 0; i < ARRAY_SIZE(backends); i++) {
int prefix_len = 0;
@@ -36,28 +37,33 @@ static struct uclient_url *uclient_get_url(const char *url_str)
if (!*prefix)
return NULL;
- url = calloc_a(sizeof(*url), &url_buf, strlen(url_str) + 1);
- url->backend = backend;
- strcpy(url_buf, url_str);
-
- next = strchr(url_buf, '/');
+ next = strchr(url_str, '/');
if (next) {
- *next = 0;
- url->location = next + 1;
+ location = next;
+ host_len = next - url_str;
} else {
- url->location = "";
+ location = "/";
+ host_len = strlen(url_str);
}
- url->host = url_buf;
- next = strchr(url_buf, '@');
+ url = calloc_a(sizeof(*url),
+ &host_buf, host_len + 1,
+ &uri_buf, strlen(location) + 1);
+
+ url->backend = backend;
+ url->location = strcpy(uri_buf, location);
+
+ url->host = strncpy(host_buf, url_str, host_len);
+
+ next = strchr(host_buf, '@');
if (next) {
*next = 0;
url->host = next + 1;
- if (uclient_urldecode(url_buf, url_buf, false) < 0)
+ if (uclient_urldecode(host_buf, host_buf, false) < 0)
goto free;
- url->auth = url_buf;
+ url->auth = host_buf;
}
/* Literal IPv6 address */