From a3edf1047aae66c17e09d01b9233f68321c27247 Mon Sep 17 00:00:00 2001 From: Vanessa Dannenberg Date: Tue, 28 May 2019 07:13:12 -0400 Subject: update homedecor and digistuff --- digistuff/button.lua | 67 +++++++++++++++++++++++++++++++++------------------- 1 file changed, 43 insertions(+), 24 deletions(-) (limited to 'digistuff/button.lua') diff --git a/digistuff/button.lua b/digistuff/button.lua index 76022f6..dc2cf3b 100644 --- a/digistuff/button.lua +++ b/digistuff/button.lua @@ -1,9 +1,22 @@ digistuff.button_turnoff = function (pos) local node = minetest.get_node(pos) - if node.name=="digistuff:button_on" then --has not been dug - minetest.swap_node(pos, {name = "digistuff:button_off", param2=node.param2}) - if minetest.get_modpath("mesecons") then minetest.sound_play("mesecons_button_pop", {pos=pos}) end - end + minetest.swap_node(pos, {name = "digistuff:button_off", param2=node.param2}) + if minetest.get_modpath("mesecons") then minetest.sound_play("mesecons_button_pop", {pos=pos}) end +end + +digistuff.button_get_rules = function(node) + local rules = { + {x = 1,y = 0,z = 0}, + {x = -1,y = 0,z = 0}, + {x = 0,y = 1,z = 0}, + {x = 0,y = -1,z = 0}, + {x = 0,y = 0,z = 1}, + {x = 0,y = 0,z = -1}, + {x = 0,y = 0,z = 2}, + } + local dir = minetest.facedir_to_dir(node.param2) + rules = digistuff.rotate_rules(rules,dir) + return rules end minetest.register_node("digistuff:button", { @@ -34,23 +47,28 @@ minetest.register_node("digistuff:button", { }, digiline = { - receptor = {} + receptor = {}, + wire = { + rules = digistuff.button_get_rules, + }, }, - groups = {dig_immediate=2}, + groups = {dig_immediate = 2,digiline_receiver = 1,}, description = "Digilines Button", on_construct = function(pos) local meta = minetest.get_meta(pos) meta:set_string("formspec","size[8,4;]field[1,1;6,2;channel;Channel;${channel}]field[1,2;6,2;msg;Message;${msg}]button_exit[2.25,3;3,1;submit;Save]") end, + after_place_node = digistuff.place_receiver, + after_destruct = digistuff.remove_receiver, on_receive_fields = function(pos, formname, fields, sender) local meta = minetest.get_meta(pos) - if fields.channel and fields.msg and fields.channel ~= "" and fields.msg ~= "" then + if fields.channel and fields.channel ~= "" then meta:set_string("channel",fields.channel) meta:set_string("msg",fields.msg) meta:set_string("formspec","") minetest.swap_node(pos, {name = "digistuff:button_off", param2=minetest.get_node(pos).param2}) else - minetest.chat_send_player(sender:get_player_name(),"Channel and message must both be set!") + minetest.chat_send_player(sender:get_player_name(),"Please set a channel!") end end, sounds = default and default.node_sound_stone_defaults(), @@ -84,17 +102,21 @@ minetest.register_node("digistuff:button_off", { }, digiline = { - receptor = {} + receptor = {}, + wire = { + rules = digistuff.button_get_rules, + }, }, - groups = {dig_immediate=2, not_in_creative_inventory=1}, + groups = {dig_immediate = 2,not_in_creative_inventory = 1,digiline_receiver = 1,}, drop = "digistuff:button", + after_destruct = digistuff.remove_receiver, description = "Digilines Button (off state - you hacker you!)", on_rightclick = function (pos, node, clicker) local meta = minetest.get_meta(pos) - digiline:receptor_send(pos, digiline.rules.default, meta:get_string("channel"), meta:get_string("msg")) + digiline:receptor_send(pos, digistuff.button_get_rules(node), meta:get_string("channel"), meta:get_string("msg")) minetest.swap_node(pos, {name = "digistuff:button_on", param2=node.param2}) if minetest.get_modpath("mesecons") then minetest.sound_play("mesecons_button_push", {pos=pos}) end - minetest.after(0.5, digistuff.button_turnoff, pos) + minetest.get_node_timer(pos):start(0.25) end, sounds = default and default.node_sound_stone_defaults(), }) @@ -128,28 +150,25 @@ minetest.register_node("digistuff:button_on", { }, digiline = { - receptor = {} + receptor = {}, + wire = { + rules = digistuff.button_get_rules, + }, }, - groups = {dig_immediate=2, not_in_creative_inventory=1}, + on_timer = digistuff.button_turnoff, + groups = {dig_immediate = 2,not_in_creative_inventory = 1,digiline_receiver = 1,}, drop = 'digistuff:button', + after_destruct = digistuff.remove_receiver, on_rightclick = function (pos, node, clicker) local meta = minetest.get_meta(pos) - digiline:receptor_send(pos, digiline.rules.default, meta:get_string("channel"), meta:get_string("msg")) + digiline:receptor_send(pos, digistuff.button_get_rules(node), meta:get_string("channel"), meta:get_string("msg")) if minetest.get_modpath("mesecons") then minetest.sound_play("mesecons_button_push", {pos=pos}) end + minetest.get_node_timer(pos):start(0.25) end, description = "Digilines Button (on state - you hacker you!)", sounds = default and default.node_sound_stone_defaults(), }) -minetest.register_craft({ - output = "digistuff:digimese", - recipe = { - {"digilines:wire_std_00000000","digilines:wire_std_00000000","digilines:wire_std_00000000"}, - {"digilines:wire_std_00000000","default:mese","digilines:wire_std_00000000"}, - {"digilines:wire_std_00000000","digilines:wire_std_00000000","digilines:wire_std_00000000"} - } -}) - minetest.register_craft({ output = "digistuff:button", recipe = { -- cgit v1.2.3