Software /
code /
prosody-modules
Changeset
3031:040eaa3844f4
mod_pastebin: Check line length via preconstructed pattern instead of gsub
Optimization on the theory that this check scales with the configuration
option instead of with the size of the user-supplied message
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Sun, 20 May 2018 17:55:53 +0200 |
parents | 3030:4a7f08fe793c |
children | 3032:0f2dd6397569 |
files | mod_pastebin/mod_pastebin.lua |
diffstat | 1 files changed, 3 insertions(+), 2 deletions(-) [+] |
line wrap: on
line diff
--- a/mod_pastebin/mod_pastebin.lua Sun May 20 17:54:47 2018 +0200 +++ b/mod_pastebin/mod_pastebin.lua Sun May 20 17:55:53 2018 +0200 @@ -89,6 +89,8 @@ end end +local line_count_pattern = string.rep("[^\n]\n", line_threshold):sub(1, -2); + function check_message(data) local origin, stanza = data.origin, data.stanza; @@ -109,8 +111,7 @@ if ( #body > length_threshold and utf8_length(body) > length_threshold ) or (trigger_string and body:find(trigger_string, 1, true) == 1) or - (select(2, body:gsub("\n", "%0")) >= line_threshold) - then + body:find(line_count_pattern) then if trigger_string and body:sub(1, #trigger_string) == trigger_string then body = body:sub(#trigger_string+1); end