var = php_strtok_r(res, separator, &strtok_buf);
while (var) {
+ size_t val_len;
+ size_t new_val_len;
+
val = strchr(var, '=');
if (arg == PARSE_COOKIE) {
}
if (val) { /* have a value */
- size_t val_len;
- size_t new_val_len;
*val++ = '\0';
- php_url_decode(var, strlen(var));
- val_len = php_url_decode(val, strlen(val));
- val = estrndup(val, val_len);
- if (sapi_module.input_filter(arg, var, &val, val_len, &new_val_len)) {
- php_register_variable_safe(var, val, new_val_len, &array);
+
+ if (arg == PARSE_COOKIE) {
+ val_len = php_raw_url_decode(val, strlen(val));
+ } else {
+ val_len = php_url_decode(val, strlen(val));
}
- efree(val);
} else {
- size_t val_len;
- size_t new_val_len;
-
- php_url_decode(var, strlen(var));
- val_len = 0;
- val = estrndup("", val_len);
- if (sapi_module.input_filter(arg, var, &val, val_len, &new_val_len)) {
- php_register_variable_safe(var, val, new_val_len, &array);
- }
- efree(val);
+ val = "";
+ val_len = 0;
+ }
+
+ val = estrndup(val, val_len);
+ php_url_decode(var, strlen(var));
+ if (sapi_module.input_filter(arg, var, &val, val_len, &new_val_len)) {
+ php_register_variable_safe(var, val, new_val_len, &array);
}
+ efree(val);
next_cookie:
var = php_strtok_r(NULL, separator, &strtok_buf);
}