Fix handling of uri-specific parameters
We need to (re)apply uri-specific parameters for each new uri even if the parameter has already been set to get the correct value. Thanks to Julien STEINHAUSER <julien.steinhauser@orange.fr> for the report!
This commit is contained in:
parent
a1328457cf
commit
2223417c91
26
surf.c
26
surf.c
|
@ -643,7 +643,7 @@ cookiepolicy_set(const WebKitCookieAcceptPolicy p)
|
|||
void
|
||||
seturiparameters(Client *c, const char *uri)
|
||||
{
|
||||
Parameter *newconfig = NULL;
|
||||
Parameter *config, *newconfig = NULL;
|
||||
int i;
|
||||
|
||||
for (i = 0; i < LENGTH(uriparams); ++i) {
|
||||
|
@ -656,16 +656,26 @@ seturiparameters(Client *c, const char *uri)
|
|||
|
||||
if (!newconfig)
|
||||
newconfig = defconfig;
|
||||
if (newconfig == curconfig)
|
||||
return;
|
||||
|
||||
for (i = 0; i < ParameterLast; ++i) {
|
||||
if (defconfig[i].force)
|
||||
switch(i) {
|
||||
case Certificate:
|
||||
case CookiePolicies:
|
||||
case Style:
|
||||
config = defconfig[i].force ? defconfig :
|
||||
newconfig[i].force ? newconfig :
|
||||
defconfig;
|
||||
break;
|
||||
default:
|
||||
if (newconfig == curconfig || defconfig[i].force)
|
||||
continue;
|
||||
if (newconfig[i].force)
|
||||
setparameter(c, 0, i, &newconfig[i].val);
|
||||
else if (curconfig[i].force)
|
||||
setparameter(c, 0, i, &defconfig[i].val);
|
||||
config = newconfig[i].force ? newconfig :
|
||||
curconfig[i].force ? defconfig :
|
||||
NULL;
|
||||
}
|
||||
|
||||
if (config)
|
||||
setparameter(c, 0, i, &config[i].val);
|
||||
}
|
||||
|
||||
curconfig = newconfig;
|
||||
|
|
Loading…
Reference in New Issue