diff options
author | Matthew Wild <mwild1@gmail.com> | 2015-12-03 14:54:29 +0000 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2015-12-03 14:54:29 +0000 |
commit | 14f6ec5e010ad22137736a0aee9a935a6f437788 (patch) | |
tree | 2aa3853cf54535eb4ee9660c7739ccfe7455149c | |
parent | fcb1c816a1e438767815d0829208d3c0df868743 (diff) | |
download | prosody-14f6ec5e010ad22137736a0aee9a935a6f437788.tar.gz prosody-14f6ec5e010ad22137736a0aee9a935a6f437788.zip |
net.http.server: Use new util.cache to remember wildcard event handlers
-rw-r--r-- | net/http/server.lua | 10 |
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; |