summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrian Pane <brianp@apache.org>2001-11-24 11:13:29 +0100
committerBrian Pane <brianp@apache.org>2001-11-24 11:13:29 +0100
commit5998b7f194f5c4a2dc6ca081d0a967a05794614d (patch)
tree30ac0d82c920b293b0add231cf43df058e65256c
parentoptimized away the sprintf calls in ap_make_etag() (diff)
downloadapache2-5998b7f194f5c4a2dc6ca081d0a967a05794614d.tar.xz
apache2-5998b7f194f5c4a2dc6ca081d0a967a05794614d.zip
optimization: short-circuit out of the mod_actions handler if there are no actions defined in the config
git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@92162 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--modules/mappers/mod_actions.c16
1 files changed, 14 insertions, 2 deletions
diff --git a/modules/mappers/mod_actions.c b/modules/mappers/mod_actions.c
index 2eb411be34..ee176b6349 100644
--- a/modules/mappers/mod_actions.c
+++ b/modules/mappers/mod_actions.c
@@ -92,6 +92,9 @@
typedef struct {
apr_table_t *action_types; /* Added with Action... */
const char *scripted[METHODS]; /* Added with Script... */
+ int configured; /* True if Action or Script has been
+ * called at least once
+ */
} action_dir_config;
module actions_module;
@@ -121,6 +124,8 @@ static void *merge_action_dir_configs(apr_pool_t *p, void *basev, void *addv)
new->scripted[i] = add->scripted[i] ? add->scripted[i]
: base->scripted[i];
}
+
+ new->configured = (base->configured || add->configured);
return new;
}
@@ -129,6 +134,7 @@ static const char *add_action(cmd_parms *cmd, void *m_v,
{
action_dir_config *m = (action_dir_config *)m_v;
apr_table_setn(m->action_types, type, script);
+ m->configured = 1;
return NULL;
}
@@ -146,6 +152,7 @@ static const char *set_script(cmd_parms *cmd, void *m_v,
else
m->scripted[methnum] = script;
+ m->configured = 1;
return NULL;
}
@@ -162,11 +169,14 @@ static int action_handler(request_rec *r)
{
action_dir_config *conf = (action_dir_config *)
ap_get_module_config(r->per_dir_config, &actions_module);
- const char *t, *action = r->handler ? r->handler :
- ap_field_noparam(r->pool, r->content_type);
+ const char *t, *action;
const char *script;
int i;
+ if (!conf->configured) {
+ return DECLINED;
+ }
+
/* Note that this handler handles _all_ types, so handler is unchecked */
/* Set allowed stuff */
@@ -191,6 +201,8 @@ static int action_handler(request_rec *r)
return DECLINED;
/* Second, check for actions (which override the method scripts) */
+ action = r->handler ? r->handler :
+ ap_field_noparam(r->pool, r->content_type);
if ((t = apr_table_get(conf->action_types,
action ? action : ap_default_type(r)))) {
script = t;