mirror of
git://erdgeist.org/opentracker
synced 2025-02-17 06:31:30 +08:00
support for questionmark in URL behind the initial one
This commit is contained in:
parent
a291ceda98
commit
99c1ba1896
@ -21,6 +21,7 @@ size_t scan_urlencoded_query(char **string, char *deststring, int flags) {
|
|||||||
unsigned char *d = (unsigned char*)deststring;
|
unsigned char *d = (unsigned char*)deststring;
|
||||||
register unsigned char b, c;
|
register unsigned char b, c;
|
||||||
|
|
||||||
|
retry_parsing:
|
||||||
while( is_unreserved( c = *s++) ) {
|
while( is_unreserved( c = *s++) ) {
|
||||||
if( c=='%') {
|
if( c=='%') {
|
||||||
if( ( c = scan_fromhex(*s++) ) == 0xff ) return -1;
|
if( ( c = scan_fromhex(*s++) ) == 0xff ) return -1;
|
||||||
@ -36,7 +37,9 @@ size_t scan_urlencoded_query(char **string, char *deststring, int flags) {
|
|||||||
--s;
|
--s;
|
||||||
break;
|
break;
|
||||||
case '?':
|
case '?':
|
||||||
if( flags != SCAN_PATH ) return -1;
|
if( flags == SCAN_PATH ) goto found_terminator;
|
||||||
|
*d++ = c;
|
||||||
|
goto retry_parsing;
|
||||||
break;
|
break;
|
||||||
case '=':
|
case '=':
|
||||||
if( flags != SCAN_SEARCHPATH_PARAM ) return -1;
|
if( flags != SCAN_SEARCHPATH_PARAM ) return -1;
|
||||||
@ -49,6 +52,7 @@ size_t scan_urlencoded_query(char **string, char *deststring, int flags) {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
found_terminator:
|
||||||
*string = (char *)s;
|
*string = (char *)s;
|
||||||
return d - (unsigned char*)deststring;
|
return d - (unsigned char*)deststring;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user