util.startup: Close state on exit to ensure GC finalizers are called

Ensures a last round of garbage collection and that finalizers are
called. Fixes things like proper closing of SQLite3 state.

There are more calls to os.exit() but most of them exit with an error or
in a case where a final GC sweep might not matter as much.

It would be nice if this was the default.

Calling util.statup.exit() everywhere may be sensible, but would be more
involved, requiring imports everywhere.
This commit is contained in:
Kim Alvefur 2023-01-22 14:45:47 +01:00
parent 7c302e9c4c
commit 435e008568
2 changed files with 5 additions and 5 deletions

View file

@ -663,11 +663,11 @@ local command_runner = async.runner(function ()
local ok, ret = modulemanager.call_module_method(module, "command", arg); local ok, ret = modulemanager.call_module_method(module, "command", arg);
if ok then if ok then
if type(ret) == "number" then if type(ret) == "number" then
os.exit(ret); os.exit(ret, true);
elseif type(ret) == "string" then elseif type(ret) == "string" then
show_message(ret); show_message(ret);
end end
os.exit(0); -- :) os.exit(0, true); -- :)
else else
show_message("Failed to execute command: "..error_messages[ret]); show_message("Failed to execute command: "..error_messages[ret]);
os.exit(1); -- :( os.exit(1); -- :(
@ -745,10 +745,10 @@ local command_runner = async.runner(function ()
end end
os.exit(0); os.exit(0, true);
end end
os.exit(commands[command](arg)); os.exit(commands[command](arg), true);
end, watchers); end, watchers);
command_runner:run(true); command_runner:run(true);

View file

@ -648,7 +648,7 @@ function startup.shutdown()
end end
function startup.exit() function startup.exit()
os.exit(prosody.shutdown_code); os.exit(prosody.shutdown_code, true);
end end
-- prosodyctl only -- prosodyctl only