mirror of
https://git.minetest.land/VoxeLibre/VoxeLibre.git
synced 2025-01-23 07:28:10 +01:00
Move table.* functions to separate file in mcl_utils, add table.find() and table.intersect()
This commit is contained in:
parent
9b958bed62
commit
d5edaaa688
2 changed files with 68 additions and 46 deletions
|
@ -3,52 +3,7 @@ mcl_util = {}
|
||||||
local modname = minetest.get_current_modname()
|
local modname = minetest.get_current_modname()
|
||||||
local modpath = minetest.get_modpath(modname)
|
local modpath = minetest.get_modpath(modname)
|
||||||
dofile(modpath.."/roman_numerals.lua")
|
dofile(modpath.."/roman_numerals.lua")
|
||||||
|
dofile(modpath.."/table.lua")
|
||||||
-- Updates all values in t using values from to*.
|
|
||||||
function table.update(t, ...)
|
|
||||||
for _, to in ipairs {...} do
|
|
||||||
for k, v in pairs(to) do
|
|
||||||
t[k] = v
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return t
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Updates nil values in t using values from to*.
|
|
||||||
function table.update_nil(t, ...)
|
|
||||||
for _, to in ipairs {...} do
|
|
||||||
for k, v in pairs(to) do
|
|
||||||
if t[k] == nil then
|
|
||||||
t[k] = v
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return t
|
|
||||||
end
|
|
||||||
|
|
||||||
---Works the same as `pairs`, but order returned by keys
|
|
||||||
---
|
|
||||||
---Taken from https://www.lua.org/pil/19.3.html
|
|
||||||
---@generic T: table, K, V, C
|
|
||||||
---@param t T
|
|
||||||
---@param f? fun(a: C, b: C):boolean
|
|
||||||
---@return fun():K, V
|
|
||||||
function table.pairs_by_keys(t, f)
|
|
||||||
local a = {}
|
|
||||||
for n in pairs(t) do table.insert(a, n) end
|
|
||||||
table.sort(a, f)
|
|
||||||
|
|
||||||
local i = 0 -- iterator variable
|
|
||||||
local function iter() -- iterator function
|
|
||||||
i = i + 1
|
|
||||||
if a[i] == nil then
|
|
||||||
return nil
|
|
||||||
else
|
|
||||||
return a[i], t[a[i]]
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return iter
|
|
||||||
end
|
|
||||||
|
|
||||||
local LOGGING_ON = minetest.settings:get_bool("mcl_logging_default", false)
|
local LOGGING_ON = minetest.settings:get_bool("mcl_logging_default", false)
|
||||||
local LOG_MODULE = "[MCL2]"
|
local LOG_MODULE = "[MCL2]"
|
||||||
|
|
67
mods/CORE/mcl_util/table.lua
Normal file
67
mods/CORE/mcl_util/table.lua
Normal file
|
@ -0,0 +1,67 @@
|
||||||
|
-- Updates all values in t using values from to*.
|
||||||
|
function table.update(t, ...)
|
||||||
|
for _, to in ipairs {...} do
|
||||||
|
for k, v in pairs(to) do
|
||||||
|
t[k] = v
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return t
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Updates nil values in t using values from to*.
|
||||||
|
function table.update_nil(t, ...)
|
||||||
|
for _, to in ipairs {...} do
|
||||||
|
for k, v in pairs(to) do
|
||||||
|
if t[k] == nil then
|
||||||
|
t[k] = v
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return t
|
||||||
|
end
|
||||||
|
|
||||||
|
---Works the same as `pairs`, but order returned by keys
|
||||||
|
---
|
||||||
|
---Taken from https://www.lua.org/pil/19.3.html
|
||||||
|
---@generic T: table, K, V, C
|
||||||
|
---@param t T
|
||||||
|
---@param f? fun(a: C, b: C):boolean
|
||||||
|
---@return fun():K, V
|
||||||
|
function table.pairs_by_keys(t, f)
|
||||||
|
local a = {}
|
||||||
|
for n in pairs(t) do table.insert(a, n) end
|
||||||
|
table.sort(a, f)
|
||||||
|
|
||||||
|
local i = 0 -- iterator variable
|
||||||
|
local function iter() -- iterator function
|
||||||
|
i = i + 1
|
||||||
|
if a[i] == nil then
|
||||||
|
return nil
|
||||||
|
else
|
||||||
|
return a[i], t[a[i]]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return iter
|
||||||
|
end
|
||||||
|
|
||||||
|
function table.find(t, item)
|
||||||
|
for k,v in pairs(t) do
|
||||||
|
if v == item then return k end
|
||||||
|
end
|
||||||
|
return nil
|
||||||
|
end
|
||||||
|
|
||||||
|
function table.intersect(a, b)
|
||||||
|
local values_map = {}
|
||||||
|
|
||||||
|
for _,v in pairs(a) do values_map[v] = 1 end
|
||||||
|
for _,v in pairs(b) do values_map[v] = (values_map[v] or 0) + 1 end
|
||||||
|
|
||||||
|
-- Get all the values that are in both tables
|
||||||
|
local result = {}
|
||||||
|
for v,count in pairs(values_map) do
|
||||||
|
if count == 2 then table.insert(result, v) end
|
||||||
|
end
|
||||||
|
return result
|
||||||
|
end
|
||||||
|
|
Loading…
Reference in a new issue