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 */
  
  
  

Reply via email to