summaryrefslogtreecommitdiff
path: root/digistuff
diff options
context:
space:
mode:
Diffstat (limited to 'digistuff')
-rw-r--r--digistuff/README14
-rw-r--r--digistuff/button.lua67
-rw-r--r--digistuff/conductors.lua455
-rw-r--r--digistuff/depends.txt1
-rw-r--r--digistuff/init.lua3
-rw-r--r--digistuff/internal.lua44
-rw-r--r--digistuff/textures/digistuff_digiline_full.pngbin0 -> 1927 bytes
-rw-r--r--digistuff/textures/digistuff_insulated_edge.pngbin0 -> 1210 bytes
-rw-r--r--digistuff/textures/digistuff_insulated_full.pngbin0 -> 1185 bytes
9 files changed, 551 insertions, 33 deletions
diff --git a/digistuff/README b/digistuff/README
index 8247ce7..0212160 100644
--- a/digistuff/README
+++ b/digistuff/README
@@ -23,6 +23,12 @@ How to use digimese:
It conducts digilines signals (like digilines) in all directions (like mese). That's about it, really.
+How to use vertical/insulated digilines:
+These work exactly like the mesecons equivalents, that is:
+Vertical digilines will automatically connect to other vertical digilines directly above or below them, and form "plates" on each end of the stack. Signals can only be conducted into or out of the stack at these "plates".
+Insulated digilines conduct like regular digilines, but only into/out of the ends of the "wire".
+
+
How to use the digilines player detector:
Set a channel and radius (radius must be a number >0 and <10 - anything invalid will be ignored and "6" used instead).
Every second while a player is within the radius, a table listing the players in range will be sent via digilines on the chosen channel.
@@ -39,3 +45,11 @@ Send a digilines signal with the URL you want to download. The HTTPRequestResult
How to use the camera:
Set the channel, distance, and radius. The camera will search for a node "distance" meters away and up to 10m down.
Every second while a player is within "radius" meters of that point, a table listing the players in range will be sent via digilines on the chosen channel.
+
+
+How to use the dimmable lights:
+After setting the channel, send a number from 0 to 14 to set the light level.
+
+How to use the junction box:
+These are just plain digilines conductors (like digimese) but can skip over one node to another junction box or certain other nodes.
+As in, [digiline][junction box][dirt][junction box][digiline] will work to transmit signals "through" the dirt.
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,29 +150,26 @@ 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 = {
{"mesecons_button:button_off"},
diff --git a/digistuff/conductors.lua b/digistuff/conductors.lua
index 77229e2..dfc8793 100644
--- a/digistuff/conductors.lua
+++ b/digistuff/conductors.lua
@@ -1,3 +1,59 @@
+digistuff.remove_receiver = function(pos,node)
+ local dir = minetest.facedir_to_dir(node.param2)
+ local rpos = vector.add(pos,vector.multiply(dir,2))
+ local rnode = minetest.get_node(rpos)
+ if rnode.name == "digistuff:receiver" then
+ rnode.name = "digilines:wire_std_00000000"
+ minetest.remove_node(rpos)
+ minetest.place_node(rpos,rnode)
+ end
+end
+
+digistuff.place_receiver = function(pos)
+ local node = minetest.get_node(pos)
+ local dir = minetest.facedir_to_dir(node.param2)
+ if dir.y == 0 then
+ local nodebehind = minetest.get_node(vector.add(pos,dir))
+ if nodebehind.name == "digistuff:digimese" then return end
+ local rpos = vector.add(pos,vector.multiply(dir,2))
+ local rnode = minetest.get_node(rpos)
+ if string.find(rnode.name,"^digilines:wire_std_") then
+ minetest.remove_node(rpos)
+ local newrnode = {pos = rpos,name = "digistuff:receiver",param2 = node.param2,}
+ minetest.set_node(rpos,newrnode)
+ digilines.update_autoconnect(rpos)
+ end
+ end
+end
+
+local old_update_autoconnect = digilines.update_autoconnect
+
+digilines.update_autoconnect = function(pos,secondcall)
+ if not secondcall then
+ local node = minetest.get_node(pos)
+ if string.find(node.name,"^digilines:wire_std_") then
+ local checkdirs = {
+ {x = 1,y = 0,z = 0},
+ {x = -1,y = 0,z = 0},
+ {x = 0,y = 0,z = 1},
+ {x = 0,y = 0,z = -1},
+ }
+ local found = false
+ for _,i in ipairs(checkdirs) do
+ if not found then
+ local checkpos = vector.add(pos,vector.multiply(i,2))
+ local group = minetest.get_item_group(minetest.get_node(checkpos).name,"digiline_receiver")
+ if group and group > 0 then
+ digistuff.place_receiver(checkpos)
+ if minetest.get_node(pos).name == "digistuff:receiver" then found = true end
+ end
+ end
+ end
+ end
+ end
+ old_update_autoconnect(pos,secondcall)
+end
+
minetest.register_node("digistuff:digimese", {
description = "Digimese",
tiles = {"digistuff_digimese.png"},
@@ -22,14 +78,14 @@ minetest.register_node("digistuff:junctionbox", {
paramtype2 = "facedir",
groups = {cracky = 3},
is_ground_content = false,
- paramtype = "light",
- drawtype = "nodebox",
- node_box = {
- type = "fixed",
- fixed = {
- {-0.1,-0.15,0.35,0.1,0.15,0.5},
- }
- },
+ paramtype = "light",
+ drawtype = "nodebox",
+ node_box = {
+ type = "fixed",
+ fixed = {
+ {-0.1,-0.15,0.35,0.1,0.15,0.5},
+ }
+ },
sounds = default and default.node_sound_stone_defaults(),
digiline = {
receptor = {},
@@ -52,6 +108,330 @@ minetest.register_node("digistuff:junctionbox", {
},
})
+digistuff.receiver_get_rules = function(node)
+ local rules = {
+ {x = 0,y = 0,z = -2},
+ {x = 0,y = 0,z = 1},
+ }
+ return digistuff.rotate_rules(rules,minetest.facedir_to_dir(node.param2))
+end
+
+minetest.register_node("digistuff:receiver", {
+ description = "Digilines Receiver (you hacker you!)",
+ tiles = {"digistuff_digiline_full.png"},
+ paramtype = "light",
+ groups = {dig_immediate = 3,not_in_creative_inventory = 1,},
+ drop = "digilines:wire_std_00000000",
+ is_ground_content = false,
+ paramtype = "light",
+ paramtype2 = "facedir",
+ drawtype = "nodebox",
+ node_box = {
+ type = "fixed",
+ fixed = {
+ {-0.05,-0.05,-1.49,0.05,0.05,-0.5},
+ {-0.2,-0.2,-0.5,0.2,0.2,-0.4},
+ {-0.0625,-0.5,-0.5,0.0625,-0.2,-0.4},
+ {-0.0625,-0.5,-0.4,0.0625,-0.4375,0.5},
+ },
+ },
+ digiline = {
+ receptor = {},
+ wire = {
+ rules = digistuff.receiver_get_rules,
+ },
+ },
+})
+
+digistuff.vertical_autoconnect = function(pos)
+ local node = minetest.get_node(pos)
+ if minetest.get_item_group(node.name,"vertical_digiline") == 0 then return end
+ local uppos = vector.add(pos,vector.new(0,1,0))
+ local dnpos = vector.add(pos,vector.new(0,-1,0))
+ local upnode = minetest.get_node(uppos)
+ local dnnode = minetest.get_node(dnpos)
+ local shouldbe = "digistuff:vertical_bottom"
+ if minetest.get_item_group(dnnode.name,"vertical_digiline") > 0 then
+ if minetest.get_item_group(upnode.name,"vertical_digiline") > 0 then
+ shouldbe = "digistuff:vertical_middle"
+ else
+ shouldbe = "digistuff:vertical_top"
+ end
+ end
+ if shouldbe ~= node.name or upnode.name == "digistuff:vertical_bottom" or dnnode.name == "digistuff:vertical_top" then
+ node.name = shouldbe
+ minetest.set_node(pos,node)
+ digilines.update_autoconnect(pos)
+ digistuff.vertical_autoconnect(uppos)
+ digistuff.vertical_autoconnect(dnpos)
+ end
+end
+
+digistuff.vertical_remove = function(pos)
+ local uppos = vector.add(pos,vector.new(0,1,0))
+ local dnpos = vector.add(pos,vector.new(0,-1,0))
+ digistuff.vertical_autoconnect(uppos)
+ digistuff.vertical_autoconnect(dnpos)
+end
+
+minetest.register_node("digistuff:vertical_bottom", {
+ description = "Vertical Digiline",
+ tiles = {"digistuff_digiline_full.png"},
+ paramtype = "light",
+ groups = {dig_immediate = 3,vertical_digiline = 1,},
+ is_ground_content = false,
+ paramtype = "light",
+ drawtype = "nodebox",
+ node_box = {
+ type = "fixed",
+ fixed = {
+ {-0.5,-0.5,-0.5,0.5,-0.4375,0.5},
+ {-0.05,-0.4375,-0.05,0.05,0.5,0.05},
+ },
+ },
+ after_place_node = digistuff.vertical_autoconnect,
+ after_destruct = digistuff.vertical_remove,
+ digiline = {
+ receptor = {},
+ wire = {
+ rules = {
+ {x = 1,y = 0,z = 0},
+ {x = -1,y = 0,z = 0},
+ {x = 0,y = 0,z = 1},
+ {x = 0,y = 0,z = -1},
+ {x = 0,y = 1,z = 0},
+ {x = 0,y = 2,z = 0},
+ },
+ },
+ },
+})
+
+minetest.register_node("digistuff:vertical_middle", {
+ description = "Vertical Digiline (middle - you hacker you!)",
+ tiles = {"digistuff_digiline_full.png"},
+ paramtype = "light",
+ groups = {dig_immediate = 3,not_in_creative_inventory = 1,vertical_digiline = 1,},
+ drop = "digistuff:vertical_bottom",
+ is_ground_content = false,
+ paramtype = "light",
+ drawtype = "nodebox",
+ node_box = {
+ type = "fixed",
+ fixed = {
+ {-0.05,-0.5,-0.05,0.05,0.5,0.05},
+ },
+ },
+ after_place_node = digistuff.vertical_autoconnect,
+ after_destruct = digistuff.vertical_remove,
+ digiline = {
+ receptor = {},
+ wire = {
+ rules = {
+ {x = 0,y = 1,z = 0},
+ {x = 0,y = -1,z = 0},
+ },
+ },
+ },
+})
+
+minetest.register_node("digistuff:vertical_top", {
+ description = "Vertical Digiline (top - you hacker you!)",
+ tiles = {"digistuff_digiline_full.png"},
+ paramtype = "light",
+ groups = {dig_immediate = 3,not_in_creative_inventory = 1,vertical_digiline = 1,},
+ drop = "digistuff:vertical_bottom",
+ is_ground_content = false,
+ paramtype = "light",
+ drawtype = "nodebox",
+ node_box = {
+ type = "fixed",
+ fixed = {
+ {-0.5,-0.5,-0.5,0.5,-0.4375,0.5},
+ },
+ },
+ after_place_node = digistuff.vertical_autoconnect,
+ after_destruct = digistuff.vertical_remove,
+ digiline = {
+ receptor = {},
+ wire = {
+ rules = {
+ {x = 1,y = 0,z = 0},
+ {x = -1,y = 0,z = 0},
+ {x = 0,y = 0,z = 1},
+ {x = 0,y = 0,z = -1},
+ {x = 0,y = -1,z = 0},
+ },
+ },
+ },
+})
+
+minetest.register_node("digistuff:insulated_straight", {
+ description = "Insulated Digiline (straight)",
+ tiles = {
+ "digistuff_insulated_full.png",
+ "digistuff_insulated_full.png",
+ "digistuff_insulated_edge.png",
+ "digistuff_insulated_edge.png",
+ "digistuff_insulated_full.png",
+ "digistuff_insulated_full.png",
+ },
+ paramtype = "light",
+ paramtype2 = "facedir",
+ on_rotate = minetest.get_modpath("screwdriver") and screwdriver.rotate_simple,
+ groups = {dig_immediate = 3,},
+ is_ground_content = false,
+ paramtype = "light",
+ drawtype = "nodebox",
+ node_box = {
+ type = "fixed",
+ fixed = {
+ {-0.5,-0.5,-0.1,0.5,-0.4,0.1},
+ },
+ },
+ after_place_node = digilines.update_autoconnect,
+ after_destruct = digilines.update_autoconnect,
+ digiline = {
+ receptor = {},
+ wire = {
+ rules = function(node)
+ local rules = {
+ {x = 1,y = 0,z = 0},
+ {x = -1,y = 0,z = 0},
+ }
+ return digistuff.rotate_rules(rules,minetest.facedir_to_dir(node.param2))
+ end,
+ },
+ },
+})
+
+minetest.register_node("digistuff:insulated_tjunction", {
+ description = "Insulated Digiline (T junction)",
+ tiles = {
+ "digistuff_insulated_full.png",
+ "digistuff_insulated_full.png",
+ "digistuff_insulated_edge.png",
+ "digistuff_insulated_edge.png",
+ "digistuff_insulated_full.png",
+ "digistuff_insulated_edge.png",
+ },
+ paramtype = "light",
+ paramtype2 = "facedir",
+ on_rotate = minetest.get_modpath("screwdriver") and screwdriver.rotate_simple,
+ groups = {dig_immediate = 3,},
+ is_ground_content = false,
+ paramtype = "light",
+ drawtype = "nodebox",
+ node_box = {
+ type = "fixed",
+ fixed = {
+ {-0.5,-0.5,-0.1,0.5,-0.4,0.1},
+ {-0.1,-0.5,-0.5,0.1,-0.4,-0.1},
+ },
+ },
+ after_place_node = digilines.update_autoconnect,
+ after_destruct = digilines.update_autoconnect,
+ digiline = {
+ receptor = {},
+ wire = {
+ rules = function(node)
+ local rules = {
+ {x = 1,y = 0,z = 0},
+ {x = -1,y = 0,z = 0},
+ {x = 0,y = 0,z = -1},
+ }
+ return digistuff.rotate_rules(rules,minetest.facedir_to_dir(node.param2))
+ end,
+ },
+ },
+})
+
+minetest.register_node("digistuff:insulated_corner", {
+ description = "Insulated Digiline (corner)",
+ tiles = {
+ "digistuff_insulated_full.png",
+ "digistuff_insulated_full.png",
+ "digistuff_insulated_full.png",
+ "digistuff_insulated_edge.png",
+ "digistuff_insulated_full.png",
+ "digistuff_insulated_edge.png",
+ },
+ paramtype = "light",
+ paramtype2 = "facedir",
+ on_rotate = minetest.get_modpath("screwdriver") and screwdriver.rotate_simple,
+ groups = {dig_immediate = 3,},
+ is_ground_content = false,
+ paramtype = "light",
+ drawtype = "nodebox",
+ node_box = {
+ type = "fixed",
+ fixed = {
+ {-0.1,-0.5,-0.5,0.1,-0.4,0.1},
+ {-0.5,-0.5,-0.1,0.1,-0.4,0.1},
+ },
+ },
+ after_place_node = digilines.update_autoconnect,
+ after_destruct = digilines.update_autoconnect,
+ digiline = {
+ receptor = {},
+ wire = {
+ rules = function(node)
+ local rules = {
+ {x = -1,y = 0,z = 0},
+ {x = 0,y = 0,z = -1},
+ }
+ return digistuff.rotate_rules(rules,minetest.facedir_to_dir(node.param2))
+ end,
+ },
+ },
+})
+
+minetest.register_node("digistuff:insulated_fourway", {
+ description = "Insulated Digiline (four-way junction)",
+ tiles = {
+ "digistuff_insulated_full.png",
+ "digistuff_insulated_full.png",
+ "digistuff_insulated_edge.png",
+ "digistuff_insulated_edge.png",
+ "digistuff_insulated_edge.png",
+ "digistuff_insulated_edge.png",
+ },
+ paramtype = "light",
+ groups = {dig_immediate = 3,},
+ is_ground_content = false,
+ paramtype = "light",
+ drawtype = "nodebox",
+ node_box = {
+ type = "fixed",
+ fixed = {
+ {-0.5,-0.5,-0.1,0.5,-0.4,0.1},
+ {-0.1,-0.5,-0.5,0.1,-0.4,-0.1},
+ {-0.1,-0.5,0.1,0.1,-0.4,0.5},
+ },
+ },
+ after_place_node = digilines.update_autoconnect,
+ after_destruct = digilines.update_autoconnect,
+ digiline = {
+ receptor = {},
+ wire = {
+ rules = {
+ {x = 1,y = 0,z = 0},
+ {x = -1,y = 0,z = 0},
+ {x = 0,y = 0,z = -1},
+ {x = 0,y = 0,z = 1},
+ },
+ },
+ },
+})
+
+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:junctionbox",
recipe = {
@@ -60,3 +440,62 @@ minetest.register_craft({
{"homedecor:plastic_sheeting","digilines:wire_std_00000000","homedecor:plastic_sheeting",},
}
})
+
+if minetest.get_modpath("mesecons_materials") then
+ minetest.register_craft({
+ output = "digistuff:insulated_straight 3",
+ recipe = {
+ {"mesecons_materials:fiber","mesecons_materials:fiber","mesecons_materials:fiber",},
+ {"digilines:wire_std_00000000","digilines:wire_std_00000000","digilines:wire_std_00000000",},
+ {"mesecons_materials:fiber","mesecons_materials:fiber","mesecons_materials:fiber",},
+ }
+ })
+end
+
+minetest.register_craft({
+ output = "digistuff:vertical_bottom 3",
+ recipe = {
+ {"digilines:wire_std_00000000",},
+ {"digilines:wire_std_00000000",},
+ {"digilines:wire_std_00000000",},
+ }
+})
+
+minetest.register_craft({
+ output = "digistuff:insulated_corner 3",
+ recipe = {
+ {"digistuff:insulated_straight","digistuff:insulated_straight",},
+ {"","digistuff:insulated_straight",},
+ }
+})
+
+minetest.register_craft({
+ output = "digistuff:insulated_tjunction 4",
+ recipe = {
+ {"digistuff:insulated_straight","digistuff:insulated_straight","digistuff:insulated_straight",},
+ {"","digistuff:insulated_straight","",},
+ }
+})
+
+minetest.register_craft({
+ output = "digistuff:insulated_fourway 5",
+ recipe = {
+ {"","digistuff:insulated_straight","",},
+ {"digistuff:insulated_straight","digistuff:insulated_straight","digistuff:insulated_straight",},
+ {"","digistuff:insulated_straight","",},
+ }
+})
+
+for _,item in ipairs({"digistuff:insulated_corner","digistuff:insulated_tjunction","digistuff:insulated_fourway",}) do
+ minetest.register_craft({
+ output = "digistuff:insulated_straight",
+ type = "shapeless",
+ recipe = {item},
+ })
+end
+
+minetest.register_craft({
+ output = "digilines:wire_std_00000000",
+ type = "shapeless",
+ recipe = {"digistuff:vertical_bottom"},
+})
diff --git a/digistuff/depends.txt b/digistuff/depends.txt
index cfb8465..a3bfdda 100644
--- a/digistuff/depends.txt
+++ b/digistuff/depends.txt
@@ -2,3 +2,4 @@ default?
digilines
mesecons?
mesecons_mvps?
+screwdriver?
diff --git a/digistuff/init.lua b/digistuff/init.lua
index 1deefe1..dcf5e29 100644
--- a/digistuff/init.lua
+++ b/digistuff/init.lua
@@ -1,6 +1,8 @@
digistuff = {}
local components = {
+ "internal",
+ "conductors",
"touchscreen",
"light",
"noteblock",
@@ -9,7 +11,6 @@ local components = {
"panel",
"piezo",
"detector",
- "conductors",
"piston",
}
for _,name in ipairs(components) do
diff --git a/digistuff/internal.lua b/digistuff/internal.lua
new file mode 100644
index 0000000..494a206
--- /dev/null
+++ b/digistuff/internal.lua
@@ -0,0 +1,44 @@
+digistuff.rotate_rules = function(rulesin,dir)
+ local rules = {}
+ for k,v in ipairs(rulesin) do rules[k] = v end
+ if dir.z > 0 then
+ return rules
+ elseif dir.z < 0 then
+ for _,i in ipairs(rules) do
+ i.x = -i.x
+ i.z = -i.z
+ end
+ return rules
+ elseif dir.x > 0 then
+ for _,i in ipairs(rules) do
+ local z = i.x
+ i.x = i.z
+ i.z = -z
+ end
+ return rules
+ elseif dir.x < 0 then
+ for _,i in ipairs(rules) do
+ local z = i.x
+ i.x = -i.z
+ i.z = z
+ end
+ return rules
+ elseif dir.y > 0 then
+ for _,i in ipairs(rules) do
+ local z = i.y
+ i.y = i.z
+ i.z = z
+ end
+ return rules
+ elseif dir.y < 0 then
+ for _,i in ipairs(rules) do
+ local z = i.y
+ i.y = -i.z
+ i.z = -z
+ end
+ return rules
+ else
+ minetest.log("warning",string.format("digistuff.rotate_rules() called with invalid direction %s,%s,%s",dir.x,dir.y,dir.z))
+ return {}
+ end
+end
diff --git a/digistuff/textures/digistuff_digiline_full.png b/digistuff/textures/digistuff_digiline_full.png
new file mode 100644
index 0000000..cf5ce21
--- /dev/null
+++ b/digistuff/textures/digistuff_digiline_full.png
Binary files differ
diff --git a/digistuff/textures/digistuff_insulated_edge.png b/digistuff/textures/digistuff_insulated_edge.png
new file mode 100644
index 0000000..e1d77a6
--- /dev/null
+++ b/digistuff/textures/digistuff_insulated_edge.png
Binary files differ
diff --git a/digistuff/textures/digistuff_insulated_full.png b/digistuff/textures/digistuff_insulated_full.png
new file mode 100644
index 0000000..69cef5f
--- /dev/null
+++ b/digistuff/textures/digistuff_insulated_full.png
Binary files differ