File

teal-src/util/poll.d.tl @ 12553:cc0ec0277813 0.12

util.startup: Fix async waiting for last shutdown steps Observed problem: When shutting down prosody would immediately exit after waiting for s2s connections to close, skipping the last cleanup events and reporting the exit reason and code. This happens because prosody.main_thread is in a waiting state and queuing startup.shutdown is dispatched trough the main loop via nexttick, but since the main loop was no longer running at that point it proceeded to the end of the prosody script and exited there.
author Kim Alvefur <zash@zash.se>
date Tue, 14 Jun 2022 16:28:49 +0200
parent 12316:6bb2f660f689
line wrap: on
line source

local record state
	enum waiterr
		"timeout"
		"signal"
	end
	add : function (state, integer, boolean, boolean) : boolean
	add : function (state, integer, boolean, boolean) : nil, string, integer
	set : function (state, integer, boolean, boolean) : boolean
	set : function (state, integer, boolean, boolean) : nil, string, integer
	del : function (state, integer) : boolean
	del : function (state, integer) : nil, string, integer
	wait : function (state, integer) : integer, boolean, boolean
	wait : function (state, integer) : nil, string, integer
	wait : function (state, integer) : nil, waiterr
	getfd : function (state) : integer
end

local record lib
	new : function () : state
	EEXIST : integer
	EMFILE : integer
	ENOENT : integer
	enum api_backend
		"epoll"
		"poll"
		"select"
	end
	api : api_backend
end

return lib