mirror of
https://github.com/minetest-mods/craftguide.git
synced 2025-01-27 11:50:16 +01:00
Fix aliased items once and for all(?)
This commit is contained in:
parent
b09870a5b2
commit
937f5f0918
70
init.lua
70
init.lua
@ -51,15 +51,16 @@ local S = CORE_VERSION >= 500 and core.get_translator("craftguide") or
|
|||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
|
||||||
local maxn, sort, concat, copy, insert =
|
local maxn, sort, concat, copy, insert, remove =
|
||||||
table.maxn, table.sort, table.concat, table.copy, table.insert
|
table.maxn, table.sort, table.concat, table.copy,
|
||||||
|
table.insert, table.remove
|
||||||
|
|
||||||
local fmt, find, gmatch, match, sub, split, upper, lower =
|
local fmt, find, gmatch, match, sub, split, upper, lower =
|
||||||
string.format, string.find, string.gmatch, string.match,
|
string.format, string.find, string.gmatch, string.match,
|
||||||
string.sub, string.split, string.upper, string.lower
|
string.sub, string.split, string.upper, string.lower
|
||||||
|
|
||||||
local min, max, floor, ceil = math.min, math.max, math.floor, math.ceil
|
local min, max, floor, ceil = math.min, math.max, math.floor, math.ceil
|
||||||
local pairs, next = pairs, next
|
local pairs, next, type = pairs, next, type
|
||||||
local vec_add, vec_mul = vector.add, vector.multiply
|
local vec_add, vec_mul = vector.add, vector.multiply
|
||||||
|
|
||||||
local ROWS = sfinv_only and 9 or 11
|
local ROWS = sfinv_only and 9 or 11
|
||||||
@ -105,7 +106,7 @@ craftguide.group_stereotypes = {
|
|||||||
mesecon_conductor_craftable = "mesecons:wire_00000000_off",
|
mesecon_conductor_craftable = "mesecons:wire_00000000_off",
|
||||||
}
|
}
|
||||||
|
|
||||||
local function table_diff(t1, t2)
|
local function array_diff(t1, t2)
|
||||||
local hash = {}
|
local hash = {}
|
||||||
|
|
||||||
for i = 1, #t1 do
|
for i = 1, #t1 do
|
||||||
@ -131,6 +132,60 @@ local function table_diff(t1, t2)
|
|||||||
return diff
|
return diff
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function table_eq(T1, T2)
|
||||||
|
local avoid_loops = {}
|
||||||
|
|
||||||
|
local function recurse(t1, t2)
|
||||||
|
if type(t1) ~= type(t2) then return end
|
||||||
|
if type(t1) ~= "table" then
|
||||||
|
return t1 == t2
|
||||||
|
end
|
||||||
|
|
||||||
|
if avoid_loops[t1] then return
|
||||||
|
avoid_loops[t1] == t2
|
||||||
|
end
|
||||||
|
|
||||||
|
avoid_loops[t1] = t2
|
||||||
|
local t2keys = {}
|
||||||
|
local t2tablekeys = {}
|
||||||
|
|
||||||
|
for k in pairs(t2) do
|
||||||
|
if type(k) == "table" then
|
||||||
|
insert(t2tablekeys, k)
|
||||||
|
end
|
||||||
|
|
||||||
|
t2keys[k] = true
|
||||||
|
end
|
||||||
|
|
||||||
|
for k1, v1 in pairs(t1) do
|
||||||
|
local v2 = t2[k1]
|
||||||
|
if type(k1) == "table" then
|
||||||
|
local ok
|
||||||
|
for i = 1, #t2tablekeys do
|
||||||
|
local tk = t2tablekeys[i]
|
||||||
|
if table_eq(k1, tk) and recurse(v1, t2[tk]) then
|
||||||
|
remove(t2tablekeys, i)
|
||||||
|
t2keys[tk] = nil
|
||||||
|
ok = true
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if not ok then return end
|
||||||
|
else
|
||||||
|
if v2 == nil then return end
|
||||||
|
t2keys[k1] = nil
|
||||||
|
if not recurse(v1, v2) then return end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if next(t2keys) then return end
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
return recurse(T1, T2)
|
||||||
|
end
|
||||||
|
|
||||||
local function table_merge(t1, t2, hash)
|
local function table_merge(t1, t2, hash)
|
||||||
t1 = t1 or {}
|
t1 = t1 or {}
|
||||||
t2 = t2 or {}
|
t2 = t2 or {}
|
||||||
@ -1017,9 +1072,10 @@ local function get_init_items()
|
|||||||
|
|
||||||
for j = 1, #recipes_cache[newname] do
|
for j = 1, #recipes_cache[newname] do
|
||||||
local rcp_new = recipes_cache[newname][j]
|
local rcp_new = recipes_cache[newname][j]
|
||||||
local diff = table_diff(rcp_old, rcp_new)
|
rcp_new.type = nil
|
||||||
|
rcp_new.method = nil
|
||||||
|
|
||||||
if #diff == 0 then
|
if table_eq(rcp_old, rcp_new) then
|
||||||
is_similar = true
|
is_similar = true
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
@ -1407,7 +1463,7 @@ if progressive_mode then
|
|||||||
local data = pdata[name]
|
local data = pdata[name]
|
||||||
|
|
||||||
local inv_items = get_inv_items(player)
|
local inv_items = get_inv_items(player)
|
||||||
local diff = table_diff(inv_items, data.inv_items)
|
local diff = array_diff(inv_items, data.inv_items)
|
||||||
|
|
||||||
if #diff > 0 then
|
if #diff > 0 then
|
||||||
data.inv_items = table_merge(diff, data.inv_items)
|
data.inv_items = table_merge(diff, data.inv_items)
|
||||||
|
Loading…
Reference in New Issue
Block a user