1 -- Minetest: builtin/misc.lua
9 local function update_timers(delay)
12 for index = 1, #timers do
14 local timer = timers[index]
15 timer.time = timer.time - delay
16 if timer.time <= 0 then
17 core.set_last_run_mod(timer.mod_origin)
18 timer.func(unpack(timer.args or {}))
19 table.remove(timers, index)
22 mintime = math.min(mintime, timer.time)
30 local function add_timers()
31 for _, timer in ipairs(timers_to_add) do
32 table.insert(timers, timer)
38 core.register_globalstep(function(dtime)
40 -- abort if no timers are running
47 if delay < mintime then
54 function core.after(time, func, ...)
55 assert(tonumber(time) and type(func) == "function",
56 "Invalid core.after invocation")
63 mod_origin = core.get_last_run_mod(),
67 mintime = math.min(mintime, time)
68 timers_to_add = timers_to_add or {}
69 timers_to_add[#timers_to_add+1] = {
73 mod_origin = core.get_last_run_mod(),
77 function core.check_player_privs(name, privs)
78 local player_privs = core.get_player_privs(name)
79 local missing_privileges = {}
80 for priv, val in pairs(privs) do
82 and not player_privs[priv] then
83 table.insert(missing_privileges, priv)
86 if #missing_privileges > 0 then
87 return false, missing_privileges
92 local player_list = {}
94 core.register_on_joinplayer(function(player)
95 player_list[player:get_player_name()] = player
98 core.register_on_leaveplayer(function(player)
99 player_list[player:get_player_name()] = nil
102 function core.get_connected_players()
103 local temp_table = {}
104 for index, value in pairs(player_list) do
105 if value:is_player_connected() then
106 table.insert(temp_table, value)
112 -- Returns two position vectors representing a box of `radius` in each
113 -- direction centered around the player corresponding to `player_name`
114 function core.get_player_radius_area(player_name, radius)
115 local player = core.get_player_by_name(player_name)
116 if player == nil then
120 local p1 = player:getpos()
124 p1 = vector.subtract(p1, radius)
125 p2 = vector.add(p2, radius)
131 function core.hash_node_position(pos)
132 return (pos.z+32768)*65536*65536 + (pos.y+32768)*65536 + pos.x+32768
135 function core.get_position_from_hash(hash)
137 pos.x = (hash%65536) - 32768
138 hash = math.floor(hash/65536)
139 pos.y = (hash%65536) - 32768
140 hash = math.floor(hash/65536)
141 pos.z = (hash%65536) - 32768
145 function core.get_item_group(name, group)
146 if not core.registered_items[name] or not
147 core.registered_items[name].groups[group] then
150 return core.registered_items[name].groups[group]
153 function core.get_node_group(name, group)
154 core.log("deprecated", "Deprecated usage of get_node_group, use get_item_group instead")
155 return core.get_item_group(name, group)
158 function core.setting_get_pos(name)
159 local value = core.setting_get(name)
163 return core.string_to_pos(value)
166 -- To be overriden by protection mods
167 function core.is_protected(pos, name)
171 function core.record_protection_violation(pos, name)
172 for _, func in pairs(core.registered_on_protection_violation) do
177 local raillike_ids = {}
178 local raillike_cur_id = 0
179 function core.raillike_group(name)
180 local id = raillike_ids[name]
182 raillike_cur_id = raillike_cur_id + 1
183 raillike_ids[name] = raillike_cur_id