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);
if ok then
if type(ret) == "number" then
os.exit(ret);
os.exit(ret, true);
elseif type(ret) == "string" then
show_message(ret);
end
os.exit(0); -- :)
os.exit(0, true); -- :)
else
show_message("Failed to execute command: "..error_messages[ret]);
os.exit(1); -- :(
@ -745,10 +745,10 @@ local command_runner = async.runner(function ()
end
os.exit(0);
os.exit(0, true);
end
os.exit(commands[command](arg));
os.exit(commands[command](arg), true);
end, watchers);
command_runner:run(true);

View file

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