akosut 96/08/16 16:15:20
Modified: src mod_browser.c
Log:
Make some changes to mod_browser:
Change BrowserCase to BrowserNoCase
Let per-server entries add, instead of override.
Add the ability to use !option to cancel a previously set option.
Reviewed by: Jim Jagielski
Revision Changes Path
1.2 +24 -5 apache/src/mod_browser.c
Index: mod_browser.c
===================================================================
RCS file: /export/home/cvs/apache/src/mod_browser.c,v
retrieving revision 1.1
retrieving revision 1.2
diff -C3 -r1.1 -r1.2
*** mod_browser.c 1996/08/12 18:59:45 1.1
--- mod_browser.c 1996/08/16 23:15:19 1.2
***************
*** 82,87 ****
--- 82,97 ----
return (void *)new;
}
+ void *merge_browser_config (pool *p, void *basev, void *overridesv)
+ {
+ browser_server_config_rec *a =
+ pcalloc(p, sizeof(browser_server_config_rec));
+ browser_server_config_rec *base = basev, *overrides = overridesv;
+
+ a->browsers = append_arrays(p, base->browsers, overrides->browsers);
+ return a;
+ }
+
char *add_browser(cmd_parms *cmd, void *dummy, char *name, char *feature)
{
browser_server_config_rec *sconf =
***************
*** 97,102 ****
--- 107,113 ----
if (!strcmp(b->name, name)) {
var = getword(cmd->pool, &feature, '=');
if (*feature) table_set(b->features, var, feature);
+ else if (*var == '!') table_set(b->features, var + 1, "!");
else table_set(b->features, var, "1");
return NULL;
}
***************
*** 113,118 ****
--- 124,130 ----
var = getword(cmd->pool, &feature, '=');
if (*feature) table_set(new->features, var, feature);
+ else if (*var == '!') table_set(new->features, var + 1, "!");
else table_set(new->features, var, "1");
return NULL;
***************
*** 121,127 ****
command_rec browser_module_cmds[] = {
{ "BrowserMatch", add_browser, (void*)0,
RSRC_CONF, ITERATE2, "A browser regex and a list of variables." },
! { "BrowserCase", add_browser, (void*)REG_ICASE,
RSRC_CONF, ITERATE2, "a browser regex and a list of variables." },
{ NULL },
};
--- 133,139 ----
command_rec browser_module_cmds[] = {
{ "BrowserMatch", add_browser, (void*)0,
RSRC_CONF, ITERATE2, "A browser regex and a list of variables." },
! { "BrowserNoCase", add_browser, (void*)REG_ICASE,
RSRC_CONF, ITERATE2, "a browser regex and a list of variables." },
{ NULL },
};
***************
*** 132,139 ****
browser_server_config_rec *sconf = get_module_config (s->module_config,
&browser_module);
browser_entry *entries = (browser_entry *)sconf->browsers->elts;
char *ua = table_get(r->headers_in, "User-Agent");
! int i;
if (!ua) return DECLINED;
--- 144,152 ----
browser_server_config_rec *sconf = get_module_config (s->module_config,
&browser_module);
browser_entry *entries = (browser_entry *)sconf->browsers->elts;
+ table_entry *elts;
char *ua = table_get(r->headers_in, "User-Agent");
! int i, j;
if (!ua) return DECLINED;
***************
*** 141,148 ****
browser_entry *b = &entries[i];
if (!regexec(b->preg, ua, 0, NULL, 0)) {
! r->subprocess_env = overlay_tables(r->pool, r->subprocess_env,
! b->features);
}
}
--- 154,167 ----
browser_entry *b = &entries[i];
if (!regexec(b->preg, ua, 0, NULL, 0)) {
! elts = (table_entry *)b->features->elts;
!
! for (j = 0; j < b->features->nelts; ++j) {
! if (!strcmp(elts[j].val, "!"))
! table_unset(r->subprocess_env, elts[j].key);
! else
! table_set(r->subprocess_env, elts[j].key, elts[j].val);
! }
}
}
***************
*** 155,161 ****
NULL, /* dir config creater */
NULL, /* dir merger --- default is to override */
create_browser_config, /* server config */
! NULL, /* merge server configs */
browser_module_cmds, /* command table */
NULL, /* handlers */
NULL, /* filename translation */
--- 174,180 ----
NULL, /* dir config creater */
NULL, /* dir merger --- default is to override */
create_browser_config, /* server config */
! merge_browser_config, /* merge server configs */
browser_module_cmds, /* command table */
NULL, /* handlers */
NULL, /* filename translation */