| /* Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You under the Apache License, Version 2.0 |
| * (the "License"); you may not use this file except in compliance with |
| * the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| #define APR_WANT_STRFUNC |
| #include "apr_want.h" |
| |
| #include "httpd.h" |
| #include "http_config.h" |
| #include "http_core.h" |
| |
| /* Possibly get rid of the macros we defined in httpd.h */ |
| #if defined(strchr) |
| #undef strchr |
| #endif |
| |
| #if defined (strrchr) |
| #undef strrchr |
| #endif |
| |
| #if defined (strstr) |
| #undef strstr |
| #endif |
| |
| |
| #if defined(ap_strchr) |
| #undef ap_strchr |
| AP_DECLARE(char *) ap_strchr(char *s, int c); |
| #endif |
| |
| AP_DECLARE(char *) ap_strchr(char *s, int c) |
| { |
| return strchr(s,c); |
| } |
| |
| #if defined(ap_strchr_c) |
| #undef ap_strchr_c |
| AP_DECLARE(const char *) ap_strchr_c(const char *s, int c); |
| #endif |
| |
| AP_DECLARE(const char *) ap_strchr_c(const char *s, int c) |
| { |
| return strchr(s,c); |
| } |
| |
| #if defined(ap_strrchr) |
| #undef ap_strrchr |
| AP_DECLARE(char *) ap_strrchr(char *s, int c); |
| #endif |
| |
| AP_DECLARE(char *) ap_strrchr(char *s, int c) |
| { |
| return strrchr(s,c); |
| } |
| |
| #if defined(ap_strrchr_c) |
| #undef ap_strrchr_c |
| AP_DECLARE(const char *) ap_strrchr_c(const char *s, int c); |
| #endif |
| |
| AP_DECLARE(const char *) ap_strrchr_c(const char *s, int c) |
| { |
| return strrchr(s,c); |
| } |
| |
| #if defined(ap_strstr) |
| #undef ap_strstr |
| AP_DECLARE(char *) ap_strstr(char *s, const char *c); |
| #endif |
| |
| AP_DECLARE(char *) ap_strstr(char *s, const char *c) |
| { |
| return strstr(s,c); |
| } |
| |
| #if defined(ap_strstr_c) |
| #undef ap_strstr_c |
| AP_DECLARE(const char *) ap_strstr_c(const char *s, const char *c); |
| #endif |
| |
| AP_DECLARE(const char *) ap_strstr_c(const char *s, const char *c) |
| { |
| return strstr(s,c); |
| } |
| |
| #if defined(ap_get_module_config) |
| #undef ap_get_module_config |
| AP_DECLARE(void *) ap_get_module_config(const ap_conf_vector_t *cv, |
| const module *m); |
| #endif |
| |
| AP_DECLARE(void *) ap_get_module_config(const ap_conf_vector_t *cv, |
| const module *m) |
| { |
| return ((void **)cv)[m->module_index]; |
| } |
| |
| #if defined(ap_get_core_module_config) |
| #undef ap_get_core_module_config |
| AP_DECLARE(void *) ap_get_core_module_config(const ap_conf_vector_t *cv); |
| #endif |
| |
| AP_DECLARE(void *) ap_get_core_module_config(const ap_conf_vector_t *cv) |
| { |
| return ((void **)cv)[AP_CORE_MODULE_INDEX]; |
| } |
| |
| |
| #if defined(ap_get_server_module_loglevel) |
| #undef ap_get_server_module_loglevel |
| AP_DECLARE(int) ap_get_server_module_loglevel(const server_rec *s, int module_index); |
| #endif |
| |
| AP_DECLARE(int) ap_get_server_module_loglevel(const server_rec *s, int module_index) |
| { |
| if (module_index < 0 || s->log.module_levels == NULL || |
| s->log.module_levels[module_index] < 0) |
| { |
| return s->log.level; |
| } |
| |
| return s->log.module_levels[module_index]; |
| } |
| |
| #if defined(ap_get_conn_module_loglevel) |
| #undef ap_get_conn_module_loglevel |
| AP_DECLARE(int) ap_get_conn_module_loglevel(const conn_rec *c, int module_index); |
| #endif |
| |
| AP_DECLARE(int) ap_get_conn_module_loglevel(const conn_rec *c, int module_index) |
| { |
| const struct ap_logconf *l = (c)->log ? (c)->log : &(c)->base_server->log; |
| if (module_index < 0 || l->module_levels == NULL || |
| l->module_levels[module_index] < 0) |
| { |
| return l->level; |
| } |
| |
| return l->module_levels[module_index]; |
| } |
| |
| #if defined(ap_get_conn_server_module_loglevel) |
| #undef ap_get_conn_server_module_loglevel |
| AP_DECLARE(int) ap_get_conn_server_module_loglevel(const conn_rec *c, |
| const server_rec *s, |
| int module_index); |
| #endif |
| |
| AP_DECLARE(int) ap_get_conn_server_module_loglevel(const conn_rec *c, |
| const server_rec *s, |
| int module_index) |
| { |
| const struct ap_logconf *l = (c->log && c->log != &c->base_server->log) ? |
| c->log : &s->log; |
| if (module_index < 0 || l->module_levels == NULL || |
| l->module_levels[module_index] < 0) |
| { |
| return l->level; |
| } |
| |
| return l->module_levels[module_index]; |
| } |
| |
| #if defined(ap_get_request_module_loglevel) |
| #undef ap_get_request_module_loglevel |
| AP_DECLARE(int) ap_get_request_module_loglevel(const request_rec *c, int module_index); |
| #endif |
| |
| AP_DECLARE(int) ap_get_request_module_loglevel(const request_rec *r, int module_index) |
| { |
| const struct ap_logconf *l = r->log ? r->log : |
| r->connection->log ? r->connection->log : |
| &r->server->log; |
| if (module_index < 0 || l->module_levels == NULL || |
| l->module_levels[module_index] < 0) |
| { |
| return l->level; |
| } |
| |
| return l->module_levels[module_index]; |
| } |
| |
| /** |
| * Generic accessors for other modules to set at their own module-specific |
| * data |
| * @param conf_vector The vector in which the modules configuration is stored. |
| * usually r->per_dir_config or s->module_config |
| * @param m The module to set the data for. |
| * @param val The module-specific data to set |
| * @fn void ap_set_module_config(ap_conf_vector_t *cv, const module *m, void *val) |
| */ |
| #if defined(ap_set_module_config) |
| #undef ap_set_module_config |
| AP_DECLARE(void) ap_set_module_config(ap_conf_vector_t *cv, const module *m, |
| void *val); |
| #endif |
| |
| AP_DECLARE(void) ap_set_module_config(ap_conf_vector_t *cv, const module *m, |
| void *val) |
| { |
| ((void **)cv)[m->module_index] = val; |
| } |
| |
| |
| #if defined(ap_set_core_module_config) |
| #undef ap_set_core_module_config |
| AP_DECLARE(void) ap_set_core_module_config(ap_conf_vector_t *cv, void *val); |
| #endif |
| |
| AP_DECLARE(void) ap_set_core_module_config(ap_conf_vector_t *cv, void *val) |
| { |
| ((void **)cv)[AP_CORE_MODULE_INDEX] = val; |
| } |
| |
| #if defined(apr_palloc) |
| #undef apr_palloc |
| #endif |
| AP_DECLARE(void *) ap_palloc_debug(apr_pool_t *p, apr_size_t size) |
| { |
| /* poison uninitialized memory */ |
| return memset(apr_palloc(p, size), 0xEE, size); |
| } |
| |
| #if defined(apr_pcalloc) |
| #undef apr_pcalloc |
| #endif |
| AP_DECLARE(void *) ap_pcalloc_debug(apr_pool_t *p, apr_size_t size) |
| { |
| return memset(apr_palloc(p, size), 0, size); |
| } |