mirror of
https://github.com/PHIDIAS0303/ExpCluster.git
synced 2025-12-29 12:16:37 +09:00
Added Async
This commit is contained in:
71
expcore/async.lua
Normal file
71
expcore/async.lua
Normal file
@@ -0,0 +1,71 @@
|
||||
--[[-- Core Module - Async
|
||||
- An extention of task and token to allow a single require to register and run async functions.
|
||||
@core Async
|
||||
@alias Async
|
||||
|
||||
@usage
|
||||
-- To use Async you must register the allowed functions when the files are loaded, often this will just be giving access to
|
||||
-- some functions within a module if you expect that some parts may be blocked by in game permissions or a custom system you have made
|
||||
-- you may also want to register functions that you want to have a delayed call, such as waiting 2 seconds before printing a message
|
||||
|
||||
-- This player.admin is called (command or gui element event) by a player who isnt admin then it will error
|
||||
-- here we register the function to promote the player so that it will run async
|
||||
local promote_player =
|
||||
Async.register(function(player)
|
||||
player.admin = true
|
||||
end)
|
||||
|
||||
-- This will allow us to bypass this by running one tick later outside of any player scope
|
||||
Async(promote_player,game.player)
|
||||
|
||||
-- Here we make an sync function that we want to have a delay, note the delay is not defined here
|
||||
local print_message =
|
||||
Async.register(function(player,message)
|
||||
player.print(message)
|
||||
end)
|
||||
|
||||
-- We can then call the async function with a delay using the wait function
|
||||
Async.wait(60,print_message,game.player,'One second has passed!')
|
||||
|
||||
]]
|
||||
local Task = require 'utils.task' --- @dep utils.task
|
||||
local Token = require 'utils.token' --- @dep utils.token
|
||||
|
||||
local Async = {}
|
||||
|
||||
local internal_run =
|
||||
Token.register(function(params)
|
||||
local func = Token.get(params.token)
|
||||
func(unpack(params.params))
|
||||
end)
|
||||
|
||||
--- Register a new async function, must called when the file is loaded
|
||||
-- @tparam function callback the function that will become an async function
|
||||
Async.register = Token.register
|
||||
|
||||
--- Runs the async function linked to this token, you may supply any number of params as needed
|
||||
-- @tparam string token the token of the async function you want to run
|
||||
-- @tparam[opt] any ... the other params that you want to pass to your function
|
||||
function Async.run(token,...)
|
||||
Task.queue_task(internal_run, {
|
||||
token = token,
|
||||
params = {...}
|
||||
})
|
||||
end
|
||||
|
||||
--- Runs the async function linked to this token after the given number of ticks, you may supply any number of params as needed
|
||||
-- @tparam number ticks the number of ticks that you want the function to run after
|
||||
-- @tparam string token the token of the async function you want to run
|
||||
-- @tparam[opt] any ... the other params that you want to pass to your function
|
||||
function Async.wait(ticks,token,...)
|
||||
Task.set_timeout_in_ticks(ticks, internal_run, {
|
||||
token = token,
|
||||
params = {...}
|
||||
})
|
||||
end
|
||||
|
||||
return setmetatable(Async,{
|
||||
__call = function(self,...)
|
||||
self.run(...)
|
||||
end
|
||||
})
|
||||
Reference in New Issue
Block a user