From a10c169f6dab4f49068eeb34fe12cdff9a5e4cd9 Mon Sep 17 00:00:00 2001 From: Nihilistzsche Date: Fri, 10 Feb 2023 17:15:16 -0800 Subject: [PATCH] Everything efficiency. --- compatibility/crafting-efficiency.lua | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/compatibility/crafting-efficiency.lua b/compatibility/crafting-efficiency.lua index 189987b..d8be6b3 100644 --- a/compatibility/crafting-efficiency.lua +++ b/compatibility/crafting-efficiency.lua @@ -20,14 +20,22 @@ if mods["crafting-efficiency-2"] then for i, recipe in pairs(recipes) do -- add remaining recipes with direct items to find the icons - if data.raw.recipe[recipe] and data.raw.item[recipe] and not eff_data[recipe] and - (data.raw.recipe[recipe].main_product or util.get_result_count(recipe) == 1) then + if data.raw.recipe[recipe] and data.raw.item[recipe] and not eff_data[recipe] then + local research_level = 1 + if not data.raw.recipe[recipe].enabled then + for tech, tbl in pairs(data.raw.technology) do + for _, effect in pairs(tbl.effects or {}) do + if effect.type == "unlock-recipe" and effect.recipe == recipe then + research_level = math.min(#tbl.unit.ingredients, 6) + end + end + end + end eff_data[recipe] = { - name = recipe.." efficiency", max = 15, - icon = data.raw.item[recipe].icon, + icon = data.raw.item[recipe].icon, crafting = { efficiency = 10 }, - research = { level = 6 }, + research = { level = research_level }, } end end