2019-02-20 12:43:29 +02:00
|
|
|
local Token = {}
|
|
|
|
|
|
|
|
local tokens = {}
|
|
|
|
|
2021-01-12 22:52:45 +02:00
|
|
|
local counter = 200
|
2023-09-20 21:37:45 +02:00
|
|
|
local alternative_counter = 20000
|
2019-02-20 12:43:29 +02:00
|
|
|
|
|
|
|
--- Assigns a unquie id for the given var.
|
|
|
|
-- This function cannot be called after on_init() or on_load() has run as that is a desync risk.
|
|
|
|
-- Typically this is used to register functions, so the id can be stored in the global table
|
|
|
|
-- instead of the function. This is becasue closures cannot be safely stored in the global table.
|
|
|
|
-- @param var<any>
|
2023-09-20 21:37:45 +02:00
|
|
|
-- @param sarg<boolean>
|
2019-02-20 12:43:29 +02:00
|
|
|
-- @return number the unique token for the variable.
|
2023-09-20 21:37:45 +02:00
|
|
|
function Token.register(var, sarg)
|
2019-02-20 12:43:29 +02:00
|
|
|
if _LIFECYCLE == 8 then
|
|
|
|
error('Calling Token.register after on_init() or on_load() has run is a desync risk.', 2)
|
|
|
|
end
|
|
|
|
|
2023-09-20 21:37:45 +02:00
|
|
|
if sarg then
|
|
|
|
alternative_counter = alternative_counter + 1
|
|
|
|
tokens[alternative_counter] = var
|
|
|
|
return alternative_counter
|
|
|
|
end
|
|
|
|
|
2019-02-20 12:43:29 +02:00
|
|
|
counter = counter + 1
|
|
|
|
|
|
|
|
tokens[counter] = var
|
|
|
|
|
|
|
|
return counter
|
|
|
|
end
|
|
|
|
|
|
|
|
function Token.get(token_id)
|
|
|
|
return tokens[token_id]
|
|
|
|
end
|
|
|
|
|
2019-08-14 15:19:18 +02:00
|
|
|
local uid_counter = 100
|
2019-02-20 12:43:29 +02:00
|
|
|
|
2022-07-10 19:41:21 +02:00
|
|
|
---@return integer
|
2019-02-20 12:43:29 +02:00
|
|
|
function Token.uid()
|
|
|
|
uid_counter = uid_counter + 1
|
|
|
|
|
|
|
|
return uid_counter
|
|
|
|
end
|
|
|
|
|
|
|
|
return Token
|