view src/luan/modules/Thread.luan @ 1372:431d5bec3ca4

add Thread.new_synchronizer
author Franklin Schmidt <fschmidt@gmail.com>
date Mon, 01 Jul 2019 15:37:51 -0600
parents ae2321a09723
children 72b699bad1a4
line wrap: on
line source

require "java"
local ThreadLuan = require "java:luan.modules.ThreadLuan"
local ReentrantLock = require "java:java.util.concurrent.locks.ReentrantLock"
local Luan = require "luan:Luan.luan"
local error = Luan.error
local set_metatable = Luan.set_metatable or error()
local try = Luan.try or error()
local Time = require "luan:Time.luan"
local Logging = require "luan:logging/Logging.luan"
local logger = Logging.logger "Thread"


local Thread = {}

Thread.sleep = ThreadLuan.sleep

local function safe(fn)
	return function()
		try {
			fn
			catch = function(e)
				logger.error(e)
			end
		}
	end
end

function Thread.fork(fn)
	fn = safe(fn)
	ThreadLuan.fork(fn)
end

function Thread.schedule(fn,options)
	fn = safe(fn)
	options = options or {}
	ThreadLuan.schedule(fn,options)
end


local forever = Time.period{years=100}

function Thread.global_callable(name,fns,timeout)
	timeout = timeout or forever
	local callable = ThreadLuan.globalCallable(name,fns,timeout)
	local mt = {}
	function mt.__index(_,key)
		return function(...)
			return callable.call(key,...)
		end
	end
	local tbl = {}
	set_metatable(tbl,mt)
	return tbl
end

Thread.remove_global_callable = ThreadLuan.removeGlobalCallable

function Thread.global_map(name,timeout)
	timeout = timeout or forever

	local map = {}
	local fns = {}

	function fns.get(key)
		return map[key]
	end

	function fns.put(key,value)
		map[key] = value
	end

	local callable = ThreadLuan.globalCallable(name,fns,timeout)
	local mt = {}
	function mt.__index(_,key)
		return callable.call("get",key)
	end
	function mt.__new_index(_,key,value)
		return callable.call("put",key,value)
	end
	local tbl = {}
	set_metatable(tbl,mt)
	return tbl
end


local backup_lock = ThreadLuan.backupLock.readLock()
local run_in_lock = ThreadLuan.runInLock

function Thread.run_for_backup(fn)
	return run_in_lock(backup_lock,fn)
end


function Thread.new_synchronizer()
	local lock = ReentrantLock.new()
	return function(fn)
		return function(...)
			return run_in_lock(lock,fn,...)
		end
	end
end


return Thread