summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarter Kolwey <cheapiephp@gmail.com>2017-02-26 15:33:14 -0600
committerCarter Kolwey <cheapiephp@gmail.com>2017-02-26 15:35:51 -0600
commit1a15a8b4536e753b3690153c78857e16e5200007 (patch)
treed1969a884da4c748edb81c98d896155ab8898002
parent9ade40ac65681a49732ddf7ceabe62c1eb7a7022 (diff)
Add digilines support to autocrafter
"on" and "off" messages turn it on or off, "single" crafts one item, and sending nested tables in the shape of the crafting grid sets the craft. Example message: { {"default:wood","default:wood","default:wood"}, {"default:wood","","default:wood"}, {"default:wood","default:wood","default:wood"} }
-rw-r--r--autocrafter.lua53
1 files changed, 46 insertions, 7 deletions
diff --git a/autocrafter.lua b/autocrafter.lua
index faf5381..738f3f2 100644
--- a/autocrafter.lua
+++ b/autocrafter.lua
@@ -102,6 +102,7 @@ local function after_recipe_change(pos, inventory)
minetest.get_node_timer(pos):stop()
autocrafterCache[minetest.hash_node_position(pos)] = nil
meta:set_string("infotext", "unconfigured Autocrafter")
+ inventory:set_stack("output", 1, "")
return
end
local recipe_changed = false
@@ -171,26 +172,29 @@ end
local function update_meta(meta, enabled)
local state = enabled and "on" or "off"
meta:set_int("enabled", enabled and 1 or 0)
- meta:set_string("formspec",
- "size[8,11]"..
+ local fs = "size[8,12]"..
"list[context;recipe;0,0;3,3;]"..
"image[3,1;1,1;gui_hb_bg.png^[colorize:#141318:255]"..
"list[context;output;3,1;1,1;]"..
"image_button[3,2;1,1;pipeworks_button_" .. state .. ".png;" .. state .. ";;;false;pipeworks_button_interm.png]" ..
- "list[context;src;0,3.5;8,3;]"..
+ "list[context;src;0,4.5;8,3;]"..
"list[context;dst;4,0;4,3;]"..
default.gui_bg..
default.gui_bg_img..
default.gui_slots..
- default.get_hotbar_bg(0,7) ..
- "list[current_player;main;0,7;8,4;]" ..
+ default.get_hotbar_bg(0,8) ..
+ "list[current_player;main;0,8;8,4;]" ..
"listring[current_player;main]"..
"listring[context;src]" ..
"listring[context;dst]" ..
"listring[current_player;main]"..
"listring[context;recipe]" ..
"listring[context;output]"
- )
+ if minetest.get_modpath("digilines") then
+ fs = fs.."field[1,3.5;4,1;channel;Channel;${channel}]"
+ fs = fs.."button_exit[5,3.2;2,1;save;Save]"
+ end
+ meta:set_string("formspec",fs)
-- toggling the button doesn't quite call for running a recipe change check
-- so instead we run a minimal version for infotext setting only
@@ -282,6 +286,8 @@ minetest.register_node("pipeworks:autocrafter", {
if update_meta(meta, true) then
start_crafter(pos)
end
+ elseif fields.save then
+ meta:set_string("channel",fields.channel)
end
end,
can_dig = function(pos, player)
@@ -362,7 +368,40 @@ minetest.register_node("pipeworks:autocrafter", {
after_inventory_change(pos)
return count
end,
- on_timer = run_autocrafter
+ on_timer = run_autocrafter,
+ digiline = {
+ receptor = {},
+ effector = {
+ action = function(pos,node,channel,msg)
+ local meta = minetest.get_meta(pos)
+ if channel ~= meta:get_string("channel") then return end
+ if type(msg) == "table" then
+ if #msg < 3 then return end
+ local inv = meta:get_inventory()
+ for y=0,2,1 do
+ for x=1,3,1 do
+ local slot = y*3+x
+ if minetest.registered_items[msg[y+1][x]] then
+ inv:set_stack("recipe",slot,ItemStack(msg[y+1][x]))
+ else
+ inv:set_stack("recipe",slot,ItemStack(""))
+ end
+ end
+ end
+ after_recipe_change(pos,inv)
+ elseif msg == "off" then
+ update_meta(meta, false)
+ minetest.get_node_timer(pos):stop()
+ elseif msg == "on" then
+ if update_meta(meta, true) then
+ start_crafter(pos)
+ end
+ elseif msg == "single" then
+ run_autocrafter(pos,1)
+ end
+ end,
+ },
+ },
})
minetest.register_craft( {