Unidiff1 files changed, 5 insertions, 4 deletions
|
diff --git a/html.c b/html.c index 66ba65d..d86b2c1 100644 --- a/ html.c+++ b/ html.c |
|
@@ -231,37 +231,38 @@ int hextoint(char c) |
231 | if (c >= 'a' && c <= 'f') |
231 | if (c >= 'a' && c <= 'f') |
232 | return 10 + c - 'a'; |
232 | return 10 + c - 'a'; |
233 | else if (c >= 'A' && c <= 'F') |
233 | else if (c >= 'A' && c <= 'F') |
234 | return 10 + c - 'A'; |
234 | return 10 + c - 'A'; |
235 | else if (c >= '0' && c <= '9') |
235 | else if (c >= '0' && c <= '9') |
236 | return c - '0'; |
236 | return c - '0'; |
237 | else |
237 | else |
238 | return -1; |
238 | return -1; |
239 | } |
239 | } |
240 | |
240 | |
241 | char *convert_query_hexchar(char *txt) |
241 | char *convert_query_hexchar(char *txt) |
242 | { |
242 | { |
243 | int d1, d2; |
243 | int d1, d2, n; |
244 | if (strlen(txt) < 3) { |
244 | n = strlen(txt); |
| |
245 | if (n < 3) { |
245 | *txt = '\0'; |
246 | *txt = '\0'; |
246 | return txt-1; |
247 | return txt-1; |
247 | } |
248 | } |
248 | d1 = hextoint(*(txt+1)); |
249 | d1 = hextoint(*(txt+1)); |
249 | d2 = hextoint(*(txt+2)); |
250 | d2 = hextoint(*(txt+2)); |
250 | if (d1<0 || d2<0) { |
251 | if (d1<0 || d2<0) { |
251 | strcpy(txt, txt+3); |
252 | memmove(txt, txt+3, n-3); |
252 | return txt-1; |
253 | return txt-1; |
253 | } else { |
254 | } else { |
254 | *txt = d1 * 16 + d2; |
255 | *txt = d1 * 16 + d2; |
255 | strcpy(txt+1, txt+3); |
256 | memmove(txt+1, txt+3, n-2); |
256 | return txt; |
257 | return txt; |
257 | } |
258 | } |
258 | } |
259 | } |
259 | |
260 | |
260 | int http_parse_querystring(char *txt, void (*fn)(const char *name, const char *value)) |
261 | int http_parse_querystring(char *txt, void (*fn)(const char *name, const char *value)) |
261 | { |
262 | { |
262 | char *t, *value = NULL, c; |
263 | char *t, *value = NULL, c; |
263 | |
264 | |
264 | if (!txt) |
265 | if (!txt) |
265 | return 0; |
266 | return 0; |
266 | |
267 | |
267 | t = txt = strdup(txt); |
268 | t = txt = strdup(txt); |
|