projects
/
m6w6
/
ext-http
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
|
github
raw
|
inline
| side by side
- fix 'a=b ;'
[m6w6/ext-http]
/
http_api.c
diff --git
a/http_api.c
b/http_api.c
index 1d3f657dd9b5f5ada83dd5469bb54150aff2d90f..d85b9230b500fc2d3a6c4faeaf98d54c8e7dedf3 100644
(file)
--- a/
http_api.c
+++ b/
http_api.c
@@
-101,7
+101,7
@@
PHP_HTTP_API STATUS _http_parse_cookie(const char *list, HashTable *items TSRMLS
c = s = estrdup(list);
for(;;) {
c = s = estrdup(list);
for(;;) {
-#if
0
+#if
char *tk = NULL, *tv = NULL;
if (key) {
char *tk = NULL, *tv = NULL;
if (key) {
@@
-137,21
+137,20
@@
PHP_HTTP_API STATUS _http_parse_cookie(const char *list, HashTable *items TSRMLS
switch (st)
{
case ST_QUOTE:
switch (st)
{
case ST_QUOTE:
- switch (*c)
- {
- case '"':
- if (*(c-1) != '\\') {
- st = ST_ADD;
- } else {
- memmove(c-1, c, strlen(c)+1);
- }
- break;
-
- default:
- if (!val) {
- val = c;
- }
- break;
+ if (*c == '"') {
+ if (*(c-1) != '\\') {
+ st = ST_ADD;
+ } else {
+ memmove(c-1, c, strlen(c)+1);
+ }
+ } else {
+ if (!val) {
+ val = c;
+ }
+ if (!*c) {
+ --val;
+ st = ST_ADD;
+ }
}
break;
}
break;
@@
-167,8
+166,11
@@
PHP_HTTP_API STATUS _http_parse_cookie(const char *list, HashTable *items TSRMLS
case ' ':
break;
case ' ':
break;
- case '\0':
case ';':
case ';':
+ goto add;
+ break;
+
+ case '\0':
st = ST_ADD;
break;
st = ST_ADD;
break;
@@
-190,6
+192,7
@@
PHP_HTTP_API STATUS _http_parse_cookie(const char *list, HashTable *items TSRMLS
case '.':
case '_':
case '$':
case '.':
case '_':
case '$':
+ case '@':
if (!key) {
key = c;
}
if (!key) {
key = c;
}
@@
-212,8
+215,10
@@
PHP_HTTP_API STATUS _http_parse_cookie(const char *list, HashTable *items TSRMLS
break;
case '\0':
break;
case '\0':
- keylen = c - key;
- st = ST_ADD;
+ if (key) {
+ keylen = c - key;
+ st = ST_ADD;
+ }
break;
}
break;
break;
}
break;
@@
-232,6
+237,7
@@
PHP_HTTP_API STATUS _http_parse_cookie(const char *list, HashTable *items TSRMLS
add:
if (val) {
vallen = c - val - (*c?1:0);
add:
if (val) {
vallen = c - val - (*c?1:0);
+ while (val[vallen-1] == ' ') --vallen;
} else {
val = "";
vallen = 0;
} else {
val = "";
vallen = 0;
@@
-264,6
+270,7
@@
PHP_HTTP_API STATUS _http_parse_cookie(const char *list, HashTable *items TSRMLS
return SUCCESS;
failure:
return SUCCESS;
failure:
+ http_error_ex(HE_WARNING, HTTP_E_INVALID_PARAM, "Unexpected character (%c) at pos %tu of %zu", *c, c-s, strlen(s));
efree(s);
return FAILURE;
}
efree(s);
return FAILURE;
}