1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

Merge pull request #18723 from benpicco/sock_util-find_hoststart

sys/net/sock_util: fix _find_hoststart()
This commit is contained in:
Marian Buschsieweke 2022-10-11 03:53:45 +02:00 committed by GitHub
commit 2476a3b3a7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 5 additions and 6 deletions

View File

@ -98,7 +98,6 @@ static char* _find_hoststart(const char *url)
} }
break; break;
} }
urlpos++;
} }
return NULL; return NULL;
} }
@ -184,7 +183,7 @@ int _parse_netif(sock_udp_ep_t *ep_out, char *netifstart)
char netifbuf[NETIF_STR_LEN + 1] = {0}; char netifbuf[NETIF_STR_LEN + 1] = {0};
for (netifend = netifstart; *netifend && *netifend != ']'; for (netifend = netifstart; *netifend && *netifend != ']';
netifend++); netifend++) {}
netiflen = netifend - netifstart; netiflen = netifend - netifstart;
if (!*netifend || (netiflen >= NETIF_STR_LEN) || (netiflen == 0)) { if (!*netifend || (netiflen >= NETIF_STR_LEN) || (netiflen == 0)) {
/* no netif found, bail out */ /* no netif found, bail out */
@ -213,7 +212,7 @@ int sock_tl_str2ep(struct _sock_tl_ep *ep_out, const char *str)
brackets_flag = 1; brackets_flag = 1;
for (hostend = ++hoststart; for (hostend = ++hoststart;
*hostend && *hostend != ']' && *hostend != '%'; *hostend && *hostend != ']' && *hostend != '%';
hostend++); hostend++) {}
if (! *hostend || ((size_t)(hostend - hoststart) >= sizeof(hostbuf))) { if (! *hostend || ((size_t)(hostend - hoststart) >= sizeof(hostbuf))) {
/* none found, bail out */ /* none found, bail out */
return -EINVAL; return -EINVAL;

View File

@ -47,7 +47,7 @@
#define TEST_URL_DNS_HOSTPART "test.local" #define TEST_URL_DNS_HOSTPART "test.local"
#define TEST_URL_INVALID "[2001:db8::1]://local" #define TEST_URL_INVALID "[2001:db8::1]://local"
#define TEST_URL_INVALID2 "[2001:db8::1]/local" #define TEST_URL_INVALID2 "[2001:db8::1]/local"
#define TEST_URL_LONG_HOSTPORT "http://veryveryvery.long.hostname.that." \ #define TEST_URL_LONG_HOSTPORT "https://veryveryvery.long.hostname.that." \
"doesnt.fit.inside.sixtyfour.characters." \ "doesnt.fit.inside.sixtyfour.characters." \
"of.buffer.space/localpart" "of.buffer.space/localpart"
#define TEST_URL_LONG_URLPATH "http://shorthostname/very/very/long/ " \ #define TEST_URL_LONG_URLPATH "http://shorthostname/very/very/long/ " \