diff options
author | Matthew Wild <mwild1@gmail.com> | 2020-06-15 14:16:10 +0100 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2020-06-15 14:16:10 +0100 |
commit | 63ce191722822d441b3ece1302ca27f45b7f90a5 (patch) | |
tree | 8248a2c1c13b8ceeb67f2d055f8a2ef1c81e200e | |
parent | 9ea29301ad2334abdb9bffa85f12ff631692bdf3 (diff) | |
download | prosody-63ce191722822d441b3ece1302ca27f45b7f90a5.tar.gz prosody-63ce191722822d441b3ece1302ca27f45b7f90a5.zip |
util.gc: New module for configuring the Lua garbage collector
-rw-r--r-- | util/gc.lua | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/util/gc.lua b/util/gc.lua new file mode 100644 index 00000000..e02e85c4 --- /dev/null +++ b/util/gc.lua @@ -0,0 +1,50 @@ +local array = require "util.array"; +local set = require "util.set"; + +local known_options = { + incremental = set.new { "mode", "threshold", "speed", "step_size" }; + generational = set.new { "mode", "minor_threshold", "major_threshold" }; +}; + +if _VERSION ~= "5.4" then + known_options.generational = nil; + known_options.incremental:remove("step_size"); +end + +local function configure(user, defaults) + local mode = user.mode or defaults.mode or "incremental"; + if not known_options[mode] then + return nil, "GC mode not supported on ".._VERSION..": "..mode; + end + + for k, v in pairs(user) do + if not known_options[mode]:contains(k) then + return nil, "Unknown GC parameter: "..k; + elseif k ~= "mode" and type(v) ~= "number" then + return nil, "parameter '"..k.."' should be a number"; + end + end + + if mode == "incremental" then + if _VERSION == "Lua 5.4" then + collectgarbage(mode, + user.threshold or defaults.threshold, + user.speed or defaults.speed, + user.step_size or defaults.step_size + ); + else + collectgarbage("setpause", user.threshold or defaults.threshold); + collectgarbage("setstepmul", user.speed or defaults.speed); + end + elseif mode == "generational" then + collectgarbage(mode, + user.minor_threshold or defaults.minor_threshold, + user.major_threshold or defaults.major_threshold + ); + end + return true; +end + +return { + configure = configure; +}; |