aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorMatthew Wild <mwild1@gmail.com>2015-12-03 14:54:29 +0000
committerMatthew Wild <mwild1@gmail.com>2015-12-03 14:54:29 +0000
commit12f9aac248d944f00645fc438f95e53dbee21128 (patch)
tree2aa3853cf54535eb4ee9660c7739ccfe7455149c /net
parentfb55a7df98190568bc93ef889967148ecc2b5ec4 (diff)
downloadprosody-12f9aac248d944f00645fc438f95e53dbee21128.tar.gz
prosody-12f9aac248d944f00645fc438f95e53dbee21128.zip
net.http.server: Use new util.cache to remember wildcard event handlers
Diffstat (limited to 'net')
-rw-r--r--net/http/server.lua10
1 files changed, 5 insertions, 5 deletions
diff --git a/net/http/server.lua b/net/http/server.lua
index ffcceabe..acfb8a1d 100644
--- a/net/http/server.lua
+++ b/net/http/server.lua
@@ -27,7 +27,10 @@ local function is_wildcard_match(wildcard_event, event)
return wildcard_event:sub(1, -2) == event:sub(1, #wildcard_event-1);
end
-local recent_wildcard_events, max_cached_wildcard_events = {}, 10000;
+local _handlers = events._handlers;
+local recent_wildcard_events = cache.new(10000, function (key, value)
+ rawset(_handlers, key, nil);
+end);
local event_map = events._event_map;
setmetatable(events._handlers, {
@@ -62,10 +65,7 @@ setmetatable(events._handlers, {
end
rawset(handlers, curr_event, handlers_array);
if not event_map[curr_event] then -- Only wildcard handlers match, if any
- table.insert(recent_wildcard_events, curr_event);
- if #recent_wildcard_events > max_cached_wildcard_events then
- rawset(handlers, table.remove(recent_wildcard_events, 1), nil);
- end
+ recent_wildcard_events:set(curr_event, true);
end
return handlers_array;
end;