From a8caed8195013354eee73910f8dd8e048ac32f26 Mon Sep 17 00:00:00 2001 From: Vanessa Ezekowitz Date: Tue, 20 Jun 2017 05:46:30 -0400 Subject: separate the make-colored-itemstack code into its own function --- init.lua | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/init.lua b/init.lua index 85f5380..315f5fb 100644 --- a/init.lua +++ b/init.lua @@ -154,6 +154,16 @@ end function unifieddyes.after_dig_node(foo) end +-- This helper function mostly by juhdanad, creates a colored itemstack + +function unifieddyes.make_colored_itemstack(itemstack, palette, color) + local paletteidx = unifieddyes.getpaletteidx(color, palette) + local stack = ItemStack(itemstack) + stack:get_meta():set_int("palette_index", paletteidx) + stack:get_meta():set_string("dye", color) + return stack:to_string() +end + -- this helper function registers all of the recipes needed to create colored -- blocks with any of the dyes supported by that block's palette. @@ -179,7 +189,6 @@ function unifieddyes.register_color_craft(craft) for _,val in ipairs(vals_table) do local color = "dye:"..val..hue[1]..sat - local paletteidx = unifieddyes.getpaletteidx(color, craft.palette) local newrecipe = table.copy(craft.recipe) for k, item in ipairs(newrecipe) do @@ -187,10 +196,8 @@ function unifieddyes.register_color_craft(craft) if item == "NEUTRAL_NODE" then newrecipe[k] = craft.neutral_node end end - local stack = ItemStack(craft.output) - stack:get_meta():set_int("palette_index", paletteidx) - stack:get_meta():set_string("dye", color) - local colorized_itemstack = stack:to_string() + local colorized_itemstack = + unifieddyes.make_colored_itemstack(craft.output, craft.palette, color) minetest.register_craft({ output = colorized_itemstack, -- cgit v1.2.3