mirror of
https://github.com/minetest-mods/craftguide.git
synced 2025-10-24 11:15:24 +02:00
Compare commits
3 Commits
1.14.1
...
be4aebdacd
Author | SHA1 | Date | |
---|---|---|---|
|
be4aebdacd | ||
|
e4e93077c7 | ||
|
2b8dbcea49 |
50
init.lua
50
init.lua
@@ -734,21 +734,17 @@ end
|
|||||||
local function groups_to_items(groups, get_all)
|
local function groups_to_items(groups, get_all)
|
||||||
if not get_all and #groups == 1 then
|
if not get_all and #groups == 1 then
|
||||||
local group = groups[1]
|
local group = groups[1]
|
||||||
local def_gr = "default:" .. group
|
local stereotype = craftguide.group_stereotypes[group]
|
||||||
local stereotypes = craftguide.group_stereotypes
|
local def = reg_items[stereotype]
|
||||||
local stereotype = stereotypes and stereotypes[group]
|
|
||||||
stereotype = reg_items[stereotype] and stereotype
|
|
||||||
|
|
||||||
if stereotype then
|
if def and show_item(def) then
|
||||||
return stereotype
|
return stereotype
|
||||||
elseif reg_items[def_gr] then
|
|
||||||
return def_gr
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local names = {}
|
local names = {}
|
||||||
for name, def in pairs(reg_items) do
|
for name, def in pairs(reg_items) do
|
||||||
if item_has_groups(def.groups, groups) then
|
if show_item(def) and item_has_groups(def.groups, groups) then
|
||||||
if get_all then
|
if get_all then
|
||||||
names[#names + 1] = name
|
names[#names + 1] = name
|
||||||
else
|
else
|
||||||
@@ -1466,9 +1462,39 @@ core.register_craft = function(def)
|
|||||||
local name = output[i]
|
local name = output[i]
|
||||||
|
|
||||||
if def.type == "fuel" then
|
if def.type == "fuel" then
|
||||||
def.replacements = def.replacements
|
|
||||||
def.items = {def.recipe}
|
def.items = {def.recipe}
|
||||||
fuel_cache[name] = def
|
fuel_cache[name] = def
|
||||||
|
|
||||||
|
elseif def.type == "cooking" then
|
||||||
|
def.items = {def.recipe}
|
||||||
|
|
||||||
|
elseif def.type == "shapeless" then
|
||||||
|
def.items, def.width = {}, 0
|
||||||
|
for j = 1, #def.recipe do
|
||||||
|
def.items[#def.items + 1] = def.recipe[j]
|
||||||
|
end
|
||||||
|
else
|
||||||
|
def.items, def.width = {}, #def.recipe[1]
|
||||||
|
local c = 0
|
||||||
|
|
||||||
|
for j = 1, #def.recipe do
|
||||||
|
if def.recipe[j] then
|
||||||
|
for h = 1, def.width do
|
||||||
|
c = c + 1
|
||||||
|
local it = def.recipe[j][h]
|
||||||
|
|
||||||
|
if it and it ~= "" then
|
||||||
|
def.items[c] = it
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if def.type ~= "fuel" then
|
||||||
|
def.recipe = nil
|
||||||
|
recipes_cache[name] = recipes_cache[name] or {}
|
||||||
|
insert(recipes_cache[name], 1, def)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -1530,14 +1556,16 @@ local function get_init_items()
|
|||||||
if name ~= "" and show_item(def) then
|
if name ~= "" and show_item(def) then
|
||||||
cache_drops(name, def.drop)
|
cache_drops(name, def.drop)
|
||||||
|
|
||||||
if not fuel_cache[name] then
|
if not fuel_cache[name] then --[*]
|
||||||
cache_fuel(name)
|
cache_fuel(name)
|
||||||
end
|
end
|
||||||
|
|
||||||
if not recipes_cache[name] then
|
if not recipes_cache[name] then --[*]
|
||||||
cache_recipes(name)
|
cache_recipes(name)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
--[*] `core.register_craft` override may have cached them already
|
||||||
|
|
||||||
_preselect[name] = true
|
_preselect[name] = true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Reference in New Issue
Block a user