summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVanessaE <vanessaezekowitz@gmail.com>2013-01-20 17:35:13 -0800
committerVanessaE <vanessaezekowitz@gmail.com>2013-01-20 17:35:13 -0800
commita69d9d2e01e7e59c9b9a719f547097720dac0f8a (patch)
tree0efe09b0bf1d51f766a6739c7474bbe4609ecefb
parenta2fc5547001399fdfd2f6a2c2746c01b0f97244f (diff)
parent7b793fe5bd42c8f600d649489931ed6efa3a519d (diff)
Merge pull request #12 from Novatux/master
Sand tubes, which take nearby items.
-rw-r--r--autocrafter.lua2
-rw-r--r--crafts.lua9
-rw-r--r--deployer.lua158
-rw-r--r--init.lua2
-rw-r--r--item_transport.lua4
-rw-r--r--node_breaker.lua100
-rw-r--r--textures/pipeworks_accelerator_tube_end.pngbin0 -> 2836 bytes
-rw-r--r--textures/pipeworks_accelerator_tube_inv.pngbin0 -> 1295 bytes
-rw-r--r--textures/pipeworks_accelerator_tube_noctr.pngbin0 -> 2182 bytes
-rw-r--r--textures/pipeworks_accelerator_tube_plain.pngbin0 -> 2742 bytes
-rw-r--r--textures/pipeworks_accelerator_tube_short.pngbin0 -> 1378 bytes
-rw-r--r--textures/pipeworks_black.png (renamed from textures/black.png)bin150 -> 150 bytes
-rw-r--r--textures/pipeworks_blue.png (renamed from textures/blue.png)bin160 -> 160 bytes
-rw-r--r--textures/pipeworks_deployer_back.pngbin0 -> 757 bytes
-rw-r--r--textures/pipeworks_deployer_bottom.pngbin0 -> 835 bytes
-rw-r--r--textures/pipeworks_deployer_front_off.pngbin0 -> 800 bytes
-rw-r--r--textures/pipeworks_deployer_front_on.pngbin0 -> 719 bytes
-rw-r--r--textures/pipeworks_deployer_side.pngbin0 -> 908 bytes
-rw-r--r--textures/pipeworks_deployer_side1.pngbin0 -> 908 bytes
-rw-r--r--textures/pipeworks_deployer_side2.pngbin0 -> 910 bytes
-rw-r--r--textures/pipeworks_deployer_top.pngbin0 -> 842 bytes
-rw-r--r--textures/pipeworks_filter_input.png (renamed from textures/filter_input.png)bin12686 -> 12686 bytes
-rw-r--r--textures/pipeworks_filter_output.png (renamed from textures/filter_output.png)bin13205 -> 13205 bytes
-rw-r--r--textures/pipeworks_filter_side.png (renamed from textures/filter_side.png)bin13194 -> 13194 bytes
-rw-r--r--textures/pipeworks_filter_top.png (renamed from textures/filter_top.png)bin13137 -> 13137 bytes
-rw-r--r--textures/pipeworks_green.png (renamed from textures/green.png)bin160 -> 160 bytes
-rw-r--r--textures/pipeworks_nodebreaker_back.pngbin0 -> 632 bytes
-rw-r--r--textures/pipeworks_nodebreaker_bottom_off.pngbin0 -> 556 bytes
-rw-r--r--textures/pipeworks_nodebreaker_bottom_on.pngbin0 -> 549 bytes
-rw-r--r--textures/pipeworks_nodebreaker_front_off.pngbin0 -> 653 bytes
-rw-r--r--textures/pipeworks_nodebreaker_front_on.pngbin0 -> 659 bytes
-rw-r--r--textures/pipeworks_nodebreaker_side1_off.pngbin0 -> 616 bytes
-rw-r--r--textures/pipeworks_nodebreaker_side1_on.pngbin0 -> 610 bytes
-rw-r--r--textures/pipeworks_nodebreaker_side2_off.pngbin0 -> 606 bytes
-rw-r--r--textures/pipeworks_nodebreaker_side2_on.pngbin0 -> 598 bytes
-rw-r--r--textures/pipeworks_nodebreaker_top_off.pngbin0 -> 556 bytes
-rw-r--r--textures/pipeworks_nodebreaker_top_on.pngbin0 -> 558 bytes
-rw-r--r--textures/pipeworks_red.png (renamed from textures/red.png)bin160 -> 160 bytes
-rw-r--r--textures/pipeworks_sand_tube_end.pngbin0 -> 2561 bytes
-rw-r--r--textures/pipeworks_sand_tube_inv.pngbin0 -> 1209 bytes
-rw-r--r--textures/pipeworks_sand_tube_noctr.pngbin0 -> 1969 bytes
-rw-r--r--textures/pipeworks_sand_tube_plain.pngbin0 -> 2433 bytes
-rw-r--r--textures/pipeworks_sand_tube_short.pngbin0 -> 1220 bytes
-rw-r--r--textures/pipeworks_white.png (renamed from textures/white.png)bin160 -> 160 bytes
-rw-r--r--textures/pipeworks_yellow.png (renamed from textures/yellow.png)bin160 -> 160 bytes
-rw-r--r--tubes.lua69
46 files changed, 327 insertions, 17 deletions
diff --git a/autocrafter.lua b/autocrafter.lua
index 9469b7d..ba62c79 100644
--- a/autocrafter.lua
+++ b/autocrafter.lua
@@ -57,7 +57,7 @@ minetest.register_node("pipeworks:autocrafter",{
meta:set_string("formspec",
"size[8,11]"..
"list[current_name;recipe;0,0;3,3;]"..
- "list[current_name;src;0,3;8,3;]"..
+ "list[current_name;src;0,3.5;8,3;]"..
"list[current_name;dst;4,0;4,3;]"..
"list[current_player;main;0,7;8,4;]")
meta:set_string("infotext", "Autocrafter")
diff --git a/crafts.lua b/crafts.lua
index 9d33b4f..e5adc4e 100644
--- a/crafts.lua
+++ b/crafts.lua
@@ -137,6 +137,15 @@ if io.open(minetest.get_modpath("pipeworks").."/../technic/init.lua", "r") == ni
{ "homedecor:plastic_sheeting", "homedecor:plastic_sheeting", "homedecor:plastic_sheeting" }
},
})
+
+ minetest.register_craft( {
+ output = "pipeworks:sand_tube_000000 2",
+ recipe = {
+ { "homedecor:plastic_sheeting", "homedecor:plastic_sheeting", "homedecor:plastic_sheeting" },
+ { "default:sand", "default:sand", "default:sand" },
+ { "homedecor:plastic_sheeting", "homedecor:plastic_sheeting", "homedecor:plastic_sheeting" }
+ },
+ })
minetest.register_craft( {
output = "pipeworks:filter 2",
diff --git a/deployer.lua b/deployer.lua
new file mode 100644
index 0000000..a57a895
--- /dev/null
+++ b/deployer.lua
@@ -0,0 +1,158 @@
+minetest.register_craft({
+ output = 'pipeworks:deployer_off 1',
+ recipe = {
+ {'default:wood', 'default:chest','default:wood'},
+ {'default:stone', 'mesecons:piston','default:stone'},
+ {'default:stone', 'mesecons:mesecon','default:stone'},
+
+ }
+})
+
+deployer_on = function(pos, node)
+ local pos1={}
+ pos1.x=pos.x
+ pos1.y=pos.y
+ pos1.z=pos.z
+ local pos2={}
+ pos2.x=pos.x
+ pos2.y=pos.y
+ pos2.z=pos.z
+ if node.param2==3 then
+ pos1.x=pos1.x+1
+ pos2.x=pos2.x+2
+ end
+ if node.param2==2 then
+ pos1.z=pos1.z+1
+ pos2.z=pos2.z+2
+ end
+ if node.param2==1 then
+ pos1.x=pos1.x-1
+ pos2.x=pos2.x-2
+ end
+ if node.param2==0 then
+ pos1.z=pos1.z-1
+ pos2.z=pos2.z-2
+ end
+
+ if node.name == "pipeworks:deployer_off" then
+ hacky_swap_node(pos,"pipeworks:deployer_on")
+ nodeupdate(pos)
+ local meta = minetest.env:get_meta(pos);
+
+ local inv = meta:get_inventory()
+ local invlist=inv:get_list("main")
+ for i,stack in ipairs(invlist) do
+
+ if stack:get_name() ~=nil and stack:get_name() ~="" and minetest.env:get_node(pos1).name == "air" then
+ local placer={}
+ function placer:get_player_name() return "deployer" end
+ function placer:getpos() return pos end
+ local stack2=minetest.item_place(stack,placer,{type="node", under=pos1, above=pos2})
+ invlist[i]=stack2
+ inv:set_list("main",invlist)
+ return
+ end
+ end
+ end
+end
+
+deployer_off = function(pos, node)
+ if node.name == "pipeworks:deployer_on" then
+ hacky_swap_node(pos,"pipeworks:deployer_off")
+ nodeupdate(pos)
+ end
+end
+
+minetest.register_node("pipeworks:deployer_off", {
+ description = "Deployer",
+ tile_images = {"pipeworks_deployer_top.png","pipeworks_deployer_bottom.png","pipeworks_deployer_side2.png","pipeworks_deployer_side1.png",
+ "pipeworks_deployer_back.png","pipeworks_deployer_front_off.png"},
+ mesecons = {effector={action_on=deployer_on,action_off=deployer_off}},
+ tube={insert_object=function(pos,node,stack,direction)
+ local meta=minetest.env:get_meta(pos)
+ local inv=meta:get_inventory()
+ return inv:add_item("main",stack)
+ end,
+ can_insert=function(pos,node,stack,direction)
+ local meta=minetest.env:get_meta(pos)
+ local inv=meta:get_inventory()
+ return inv:room_for_item("main",stack)
+ end,
+ input_inventory="main"},
+ is_ground_content = true,
+ paramtype2 = "facedir",
+ groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2, mesecon = 2,tubedevice=1, tubedevice_receiver=1},
+ sounds = default.node_sound_stone_defaults(),
+ on_construct = function(pos)
+ local meta = minetest.env:get_meta(pos)
+ meta:set_string("formspec",
+ "invsize[8,9;]"..
+ "label[0,0;Deployer]"..
+ "list[current_name;main;4,1;3,3;]"..
+ "list[current_player;main;0,5;8,4;]")
+ meta:set_string("infotext", "Deployer")
+ local inv = meta:get_inventory()
+ inv:set_size("main", 3*3)
+ end,
+
+ can_dig = function(pos,player)
+ local meta = minetest.env:get_meta(pos);
+ local inv = meta:get_inventory()
+ return inv:is_empty("main")
+ end,
+
+})
+
+minetest.register_node("pipeworks:deployer_on", {
+ description = "Deployer",
+ tile_images = {"pipeworks_deployer_top.png","pipeworks_deployer_bottom.png","pipeworks_deployer_side2.png","pipeworks_deployer_side1.png",
+ "pipeworks_deployer_back.png","pipeworks_deployer_front_on.png"},
+ mesecons = {effector={action_on=deployer_on,action_off=deployer_off}},
+ tube={insert_object=function(pos,node,stack,direction)
+ local meta=minetest.env:get_meta(pos)
+ local inv=meta:get_inventory()
+ return inv:add_item("main",stack)
+ end,
+ can_insert=function(pos,node,stack,direction)
+ local meta=minetest.env:get_meta(pos)
+ local inv=meta:get_inventory()
+ return inv:room_for_item("main",stack)
+ end,
+ input_inventory="main"},
+ is_ground_content = true,
+ paramtype2 = "facedir",
+ tubelike=1,
+ groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2, mesecon = 2,tubedevice=1, tubedevice_receiver=1,not_in_creative_inventory=1},
+ sounds = default.node_sound_stone_defaults(),
+ on_construct = function(pos)
+ local meta = minetest.env:get_meta(pos)
+ meta:set_string("formspec",
+ "invsize[8,9;]"..
+ "label[0,0;Deployer]"..
+ "list[current_name;main;4,1;3,3;]"..
+ "list[current_player;main;0,5;8,4;]")
+ meta:set_string("infotext", "Deployer")
+ local inv = meta:get_inventory()
+ inv:set_size("main", 3*3)
+ end,
+ can_dig = function(pos,player)
+ local meta = minetest.env:get_meta(pos);
+ local inv = meta:get_inventory()
+ return inv:is_empty("main")
+ end,
+})
+
+function hacky_swap_node(pos,name)
+ local node=minetest.env:get_node(pos)
+ local meta=minetest.env:get_meta(pos)
+ local meta0=meta:to_table()
+ node.name=name
+ minetest.env:add_node(pos, node)
+ local meta=minetest.env:get_meta(pos)
+ meta:from_table(meta0)
+end
+
+
+
+
+
diff --git a/init.lua b/init.lua
index 5b0187c..ce6bc3c 100644
--- a/init.lua
+++ b/init.lua
@@ -329,4 +329,6 @@ dofile(minetest.get_modpath("pipeworks").."/flowing_logic.lua")
dofile(minetest.get_modpath("pipeworks").."/compat.lua")
dofile(minetest.get_modpath("pipeworks").."/item_transport.lua")
dofile(minetest.get_modpath("pipeworks").."/autocrafter.lua")
+dofile(minetest.get_modpath("pipeworks").."/deployer.lua")
+dofile(minetest.get_modpath("pipeworks").."/node_breaker.lua")
print("Pipeworks loaded!")
diff --git a/item_transport.lua b/item_transport.lua
index c1d7315..665516e 100644
--- a/item_transport.lua
+++ b/item_transport.lua
@@ -9,8 +9,8 @@ minetest.register_craftitem("pipeworks:filter", {
minetest.register_node("pipeworks:filter", {
description = "filter",
- tiles = {"filter_top.png", "filter_top.png", "filter_output.png",
- "filter_input.png", "filter_side.png", "filter_top.png"},
+ tiles = {"pipeworks_filter_top.png", "pipeworks_filter_top.png", "pipeworks_filter_output.png",
+ "pipeworks_filter_input.png", "pipeworks_filter_side.png", "pipeworks_filter_top.png"},
paramtype2 = "facedir",
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2,tubedevice=1,mesecon=2},
legacy_facedir_simple = true,
diff --git a/node_breaker.lua b/node_breaker.lua
new file mode 100644
index 0000000..3af1902
--- /dev/null
+++ b/node_breaker.lua
@@ -0,0 +1,100 @@
+minetest.register_craft({
+ output = 'pipeworks:nodebreaker_off 1',
+ recipe = {
+ {'default:wood', 'default:pick_mese','default:wood'},
+ {'default:stone', 'mesecons:piston','default:stone'},
+ {'default:stone', 'mesecons:mesecon','default:stone'},
+
+ }
+})
+
+
+function hacky_swap_node(pos,name)
+ local node=minetest.env:get_node(pos)
+ local meta=minetest.env:get_meta(pos)
+ local meta0=meta:to_table()
+ node.name=name
+ minetest.env:add_node(pos, node)
+ local meta=minetest.env:get_meta(pos)
+ meta:from_table(meta0)
+end
+
+
+node_breaker_on = function(pos, node)
+ if node.name == "pipeworks:nodebreaker_off" then
+ hacky_swap_node(pos,"pipeworks:nodebreaker_on")
+ break_node (pos,node.param2)
+ nodeupdate(pos)
+ end
+end
+
+node_breaker_off = function(pos, node)
+ if node.name == "pipeworks:nodebreaker_on" then
+ hacky_swap_node(pos,"pipeworks:nodebreaker_off")
+ nodeupdate(pos)
+ end
+end
+
+minetest.register_node("pipeworks:nodebreaker_off", {
+ description = "Node Breaker",
+ tile_images = {"pipeworks_nodebreaker_top_off.png","pipeworks_nodebreaker_bottom_off.png","pipeworks_nodebreaker_side2_off.png","pipeworks_nodebreaker_side1_off.png",
+ "pipeworks_nodebreaker_back.png","pipeworks_nodebreaker_front_off.png"},
+ is_ground_content = true,
+ paramtype2 = "facedir",
+ groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2, mesecon = 2,tubedevice=1},
+ mesecons= {effector={action_on=node_breaker_on, action_off=node_breaker_off}},
+ sounds = default.node_sound_stone_defaults(),
+ on_construct = function(pos)
+ local meta = minetest.env:get_meta(pos)
+ end,
+
+})
+
+minetest.register_node("pipeworks:nodebreaker_on", {
+ description = "Node Breaker",
+ tile_images = {"pipeworks_nodebreaker_top_on.png","pipeworks_nodebreaker_bottom_on.png","pipeworks_nodebreaker_side2_on.png","pipeworks_nodebreaker_side1_on.png",
+ "pipeworks_nodebreaker_back.png","pipeworks_nodebreaker_front_on.png"},
+ mesecons= {effector={action_on=node_breaker_on, action_off=node_breaker_off}},
+ is_ground_content = true,
+ paramtype2 = "facedir",
+ groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2, mesecon = 2,tubedevice=1,not_in_creative_inventory=1},
+ sounds = default.node_sound_stone_defaults(),
+})
+
+function break_node (pos,n_param)
+ local pos1={}
+ local pos2={}
+ pos1.x=pos.x
+ pos1.y=pos.y
+ pos1.z=pos.z
+ pos2.x=pos.x
+ pos2.y=pos.y
+ pos2.z=pos.z
+
+ --param2 3=x+ 1=x- 2=z+ 0=z-
+ local x_velocity=0
+ local z_velocity=0
+
+ if n_param==3 then pos2.x=pos2.x+1 pos1.x=pos1.x-1 x_velocity=-1 end
+ if n_param==2 then pos2.z=pos2.z+1 pos1.z=pos1.z-1 z_velocity=-1 end
+ if n_param==1 then pos2.x=pos2.x-1 pos1.x=pos1.x+1 x_velocity=1 end
+ if n_param==0 then pos2.z=pos2.z-1 pos1.x=pos1.z+1 z_velocity=1 end
+
+ local node=minetest.env:get_node(pos2)
+ if node.name == "air" then return nil end
+ if node.name == "default:lava_source" then return nil end
+ if node.name == "default:lava_flowing" then return nil end
+ if node.name == "default:water_source" then minetest.env:remove_node(pos2) return nil end
+ if node.name == "default:water_flowing" then minetest.env:remove_node(pos2) return nil end
+ if node.name == "ignore" then minetest.env:remove_node(pos2) return nil end
+ local drops = minetest.get_node_drops(node.name, "default:pick_mese")
+ local _, dropped_item
+ for _, dropped_item in ipairs(drops) do
+ local item1=tube_item({x=pos.x,y=pos.y,z=pos.z},dropped_item)
+ item1:get_luaentity().start_pos = {x=pos.x,y=pos.y,z=pos.z}
+ item1:setvelocity({x=x_velocity, y=0, z=z_velocity})
+ item1:setacceleration({x=0, y=0, z=0})
+ end
+ minetest.env:remove_node(pos2)
+end
+
diff --git a/textures/pipeworks_accelerator_tube_end.png b/textures/pipeworks_accelerator_tube_end.png
new file mode 100644
index 0000000..38e1848
--- /dev/null
+++ b/textures/pipeworks_accelerator_tube_end.png
Binary files differ
diff --git a/textures/pipeworks_accelerator_tube_inv.png b/textures/pipeworks_accelerator_tube_inv.png
new file mode 100644
index 0000000..d9f34a9
--- /dev/null
+++ b/textures/pipeworks_accelerator_tube_inv.png
Binary files differ
diff --git a/textures/pipeworks_accelerator_tube_noctr.png b/textures/pipeworks_accelerator_tube_noctr.png
new file mode 100644
index 0000000..f09c85c
--- /dev/null
+++ b/textures/pipeworks_accelerator_tube_noctr.png
Binary files differ
diff --git a/textures/pipeworks_accelerator_tube_plain.png b/textures/pipeworks_accelerator_tube_plain.png
new file mode 100644
index 0000000..29218ba
--- /dev/null
+++ b/textures/pipeworks_accelerator_tube_plain.png
Binary files differ
diff --git a/textures/pipeworks_accelerator_tube_short.png b/textures/pipeworks_accelerator_tube_short.png
new file mode 100644
index 0000000..4e37b66
--- /dev/null
+++ b/textures/pipeworks_accelerator_tube_short.png
Binary files differ
diff --git a/textures/black.png b/textures/pipeworks_black.png
index 9e58d8c..9e58d8c 100644
--- a/textures/black.png
+++ b/textures/pipeworks_black.png
Binary files differ
diff --git a/textures/blue.png b/textures/pipeworks_blue.png
index aa346d4..aa346d4 100644
--- a/textures/blue.png
+++ b/textures/pipeworks_blue.png
Binary files differ
diff --git a/textures/pipeworks_deployer_back.png b/textures/pipeworks_deployer_back.png
new file mode 100644
index 0000000..12e5a31
--- /dev/null
+++ b/textures/pipeworks_deployer_back.png
Binary files differ
diff --git a/textures/pipeworks_deployer_bottom.png b/textures/pipeworks_deployer_bottom.png
new file mode 100644
index 0000000..febbe18
--- /dev/null
+++ b/textures/pipeworks_deployer_bottom.png
Binary files differ
diff --git a/textures/pipeworks_deployer_front_off.png b/textures/pipeworks_deployer_front_off.png
new file mode 100644
index 0000000..9593112
--- /dev/null
+++ b/textures/pipeworks_deployer_front_off.png
Binary files differ
diff --git a/textures/pipeworks_deployer_front_on.png b/textures/pipeworks_deployer_front_on.png
new file mode 100644
index 0000000..f78de4c
--- /dev/null
+++ b/textures/pipeworks_deployer_front_on.png
Binary files differ
diff --git a/textures/pipeworks_deployer_side.png b/textures/pipeworks_deployer_side.png
new file mode 100644
index 0000000..73af8f8
--- /dev/null
+++ b/textures/pipeworks_deployer_side.png
Binary files differ
diff --git a/textures/pipeworks_deployer_side1.png b/textures/pipeworks_deployer_side1.png
new file mode 100644
index 0000000..8ef28d3
--- /dev/null
+++ b/textures/pipeworks_deployer_side1.png
Binary files differ
diff --git a/textures/pipeworks_deployer_side2.png b/textures/pipeworks_deployer_side2.png
new file mode 100644
index 0000000..ccb2cb9
--- /dev/null
+++ b/textures/pipeworks_deployer_side2.png
Binary files differ
diff --git a/textures/pipeworks_deployer_top.png b/textures/pipeworks_deployer_top.png
new file mode 100644
index 0000000..262c9f6
--- /dev/null
+++ b/textures/pipeworks_deployer_top.png
Binary files differ
diff --git a/textures/filter_input.png b/textures/pipeworks_filter_input.png
index ce532cb..ce532cb 100644
--- a/textures/filter_input.png
+++ b/textures/pipeworks_filter_input.png
Binary files differ
diff --git a/textures/filter_output.png b/textures/pipeworks_filter_output.png
index 4b29690..4b29690 100644
--- a/textures/filter_output.png
+++ b/textures/pipeworks_filter_output.png
Binary files differ
diff --git a/textures/filter_side.png b/textures/pipeworks_filter_side.png
index 00fa44d..00fa44d 100644
--- a/textures/filter_side.png
+++ b/textures/pipeworks_filter_side.png
Binary files differ
diff --git a/textures/filter_top.png b/textures/pipeworks_filter_top.png
index dca538e..dca538e 100644
--- a/textures/filter_top.png
+++ b/textures/pipeworks_filter_top.png
Binary files differ
diff --git a/textures/green.png b/textures/pipeworks_green.png
index 452aff0..452aff0 100644
--- a/textures/green.png
+++ b/textures/pipeworks_green.png
Binary files differ
diff --git a/textures/pipeworks_nodebreaker_back.png b/textures/pipeworks_nodebreaker_back.png
new file mode 100644
index 0000000..0af7422
--- /dev/null
+++ b/textures/pipeworks_nodebreaker_back.png
Binary files differ
diff --git a/textures/pipeworks_nodebreaker_bottom_off.png b/textures/pipeworks_nodebreaker_bottom_off.png
new file mode 100644
index 0000000..0f456eb
--- /dev/null
+++ b/textures/pipeworks_nodebreaker_bottom_off.png
Binary files differ
diff --git a/textures/pipeworks_nodebreaker_bottom_on.png b/textures/pipeworks_nodebreaker_bottom_on.png
new file mode 100644
index 0000000..6c4811a
--- /dev/null
+++ b/textures/pipeworks_nodebreaker_bottom_on.png
Binary files differ
diff --git a/textures/pipeworks_nodebreaker_front_off.png b/textures/pipeworks_nodebreaker_front_off.png
new file mode 100644
index 0000000..488fd0a
--- /dev/null
+++ b/textures/pipeworks_nodebreaker_front_off.png
Binary files differ
diff --git a/textures/pipeworks_nodebreaker_front_on.png b/textures/pipeworks_nodebreaker_front_on.png
new file mode 100644
index 0000000..4904e8b
--- /dev/null
+++ b/textures/pipeworks_nodebreaker_front_on.png
Binary files differ
diff --git a/textures/pipeworks_nodebreaker_side1_off.png b/textures/pipeworks_nodebreaker_side1_off.png
new file mode 100644
index 0000000..857face
--- /dev/null
+++ b/textures/pipeworks_nodebreaker_side1_off.png
Binary files differ
diff --git a/textures/pipeworks_nodebreaker_side1_on.png b/textures/pipeworks_nodebreaker_side1_on.png
new file mode 100644
index 0000000..c756f09
--- /dev/null
+++ b/textures/pipeworks_nodebreaker_side1_on.png
Binary files differ
diff --git a/textures/pipeworks_nodebreaker_side2_off.png b/textures/pipeworks_nodebreaker_side2_off.png
new file mode 100644
index 0000000..4c62f98
--- /dev/null
+++ b/textures/pipeworks_nodebreaker_side2_off.png
Binary files differ
diff --git a/textures/pipeworks_nodebreaker_side2_on.png b/textures/pipeworks_nodebreaker_side2_on.png
new file mode 100644
index 0000000..b9e4823
--- /dev/null
+++ b/textures/pipeworks_nodebreaker_side2_on.png
Binary files differ
diff --git a/textures/pipeworks_nodebreaker_top_off.png b/textures/pipeworks_nodebreaker_top_off.png
new file mode 100644
index 0000000..9139afe
--- /dev/null
+++ b/textures/pipeworks_nodebreaker_top_off.png
Binary files differ
diff --git a/textures/pipeworks_nodebreaker_top_on.png b/textures/pipeworks_nodebreaker_top_on.png
new file mode 100644
index 0000000..4b0a661
--- /dev/null
+++ b/textures/pipeworks_nodebreaker_top_on.png
Binary files differ
diff --git a/textures/red.png b/textures/pipeworks_red.png
index 1275e5d..1275e5d 100644
--- a/textures/red.png
+++ b/textures/pipeworks_red.png
Binary files differ
diff --git a/textures/pipeworks_sand_tube_end.png b/textures/pipeworks_sand_tube_end.png
new file mode 100644
index 0000000..a7816a4
--- /dev/null
+++ b/textures/pipeworks_sand_tube_end.png
Binary files differ
diff --git a/textures/pipeworks_sand_tube_inv.png b/textures/pipeworks_sand_tube_inv.png
new file mode 100644
index 0000000..d3a4b6a
--- /dev/null
+++ b/textures/pipeworks_sand_tube_inv.png
Binary files differ
diff --git a/textures/pipeworks_sand_tube_noctr.png b/textures/pipeworks_sand_tube_noctr.png
new file mode 100644
index 0000000..ddad54a
--- /dev/null
+++ b/textures/pipeworks_sand_tube_noctr.png
Binary files differ
diff --git a/textures/pipeworks_sand_tube_plain.png b/textures/pipeworks_sand_tube_plain.png
new file mode 100644
index 0000000..3d3b03e
--- /dev/null
+++ b/textures/pipeworks_sand_tube_plain.png
Binary files differ
diff --git a/textures/pipeworks_sand_tube_short.png b/textures/pipeworks_sand_tube_short.png
new file mode 100644
index 0000000..5fa36ac
--- /dev/null
+++ b/textures/pipeworks_sand_tube_short.png
Binary files differ
diff --git a/textures/white.png b/textures/pipeworks_white.png
index 8b83403..8b83403 100644
--- a/textures/white.png
+++ b/textures/pipeworks_white.png
Binary files differ
diff --git a/textures/yellow.png b/textures/pipeworks_yellow.png
index e6672bd..e6672bd 100644
--- a/textures/yellow.png
+++ b/textures/pipeworks_yellow.png
Binary files differ
diff --git a/tubes.lua b/tubes.lua
index 0061f5a..e0169a1 100644
--- a/tubes.lua
+++ b/tubes.lua
@@ -315,12 +315,12 @@ register_tube("pipeworks:mese_tube","Mese pneumatic tube segment",mese_plain_tex
"list[current_name;line4;1,3;6,1;]"..
"list[current_name;line5;1,4;6,1;]"..
"list[current_name;line6;1,5;6,1;]"..
- "image[0,0;1,1;white.png]"..
- "image[0,1;1,1;black.png]"..
- "image[0,2;1,1;green.png]"..
- "image[0,3;1,1;yellow.png]"..
- "image[0,4;1,1;blue.png]"..
- "image[0,5;1,1;red.png]"..
+ "image[0,0;1,1;pipeworks_white.png]"..
+ "image[0,1;1,1;pipeworks_black.png]"..
+ "image[0,2;1,1;pipeworks_green.png]"..
+ "image[0,3;1,1;pipeworks_yellow.png]"..
+ "image[0,4;1,1;pipeworks_blue.png]"..
+ "image[0,5;1,1;pipeworks_red.png]"..
"button[7,0;1,1;button1;On]"..
"button[7,1;1,1;button2;On]"..
"button[7,2;1,1;button3;On]"..
@@ -344,12 +344,12 @@ register_tube("pipeworks:mese_tube","Mese pneumatic tube segment",mese_plain_tex
"list[current_name;line4;1,3;6,1;]"..
"list[current_name;line5;1,4;6,1;]"..
"list[current_name;line6;1,5;6,1;]"..
- "image[0,0;1,1;white.png]"..
- "image[0,1;1,1;black.png]"..
- "image[0,2;1,1;green.png]"..
- "image[0,3;1,1;yellow.png]"..
- "image[0,4;1,1;blue.png]"..
- "image[0,5;1,1;red.png]"
+ "image[0,0;1,1;pipeworks_white.png]"..
+ "image[0,1;1,1;pipeworks_black.png]"..
+ "image[0,2;1,1;pipeworks_green.png]"..
+ "image[0,3;1,1;pipeworks_yellow.png]"..
+ "image[0,4;1,1;pipeworks_blue.png]"..
+ "image[0,5;1,1;pipeworks_red.png]"
for i=1,6 do
local st=meta:get_int("l"..tostring(i).."s")
if st==0 then
@@ -416,12 +416,53 @@ register_tube("pipeworks:detector_tube_off","Detector tube segment",detector_pla
mesecons={receptor={state="off",
rules=mesecons_rules}}})
-register_tube("pipeworks:accelerator_tube","Accelerator pneumatic tube segment",plain_textures,noctr_textures,end_textures,
- short_texture,inv_texture,
+accelerator_noctr_textures={"pipeworks_accelerator_tube_noctr.png","pipeworks_accelerator_tube_noctr.png","pipeworks_accelerator_tube_noctr.png",
+ "pipeworks_accelerator_tube_noctr.png","pipeworks_accelerator_tube_noctr.png","pipeworks_accelerator_tube_noctr.png"}
+accelerator_plain_textures={"pipeworks_accelerator_tube_plain.png","pipeworks_accelerator_tube_plain.png","pipeworks_accelerator_tube_plain.png",
+ "pipeworks_accelerator_tube_plain.png","pipeworks_accelerator_tube_plain.png","pipeworks_accelerator_tube_plain.png"}
+accelerator_end_textures={"pipeworks_accelerator_tube_end.png","pipeworks_accelerator_tube_end.png","pipeworks_accelerator_tube_end.png",
+ "pipeworks_accelerator_tube_end.png","pipeworks_accelerator_tube_end.png","pipeworks_accelerator_tube_end.png"}
+accelerator_short_texture="pipeworks_accelerator_tube_short.png"
+accelerator_inv_texture="pipeworks_accelerator_tube_inv.png"
+
+register_tube("pipeworks:accelerator_tube","Accelerator pneumatic tube segment",accelerator_plain_textures,
+ accelerator_noctr_textures,accelerator_end_textures,accelerator_short_texture,accelerator_inv_texture,
{tube={can_go=function(pos,node,velocity,stack)
velocity.speed=velocity.speed+1
return notvel(meseadjlist,velocity)
end}})
+sand_noctr_textures={"pipeworks_sand_tube_noctr.png","pipeworks_sand_tube_noctr.png","pipeworks_sand_tube_noctr.png",
+ "pipeworks_sand_tube_noctr.png","pipeworks_sand_tube_noctr.png","pipeworks_sand_tube_noctr.png"}
+sand_plain_textures={"pipeworks_sand_tube_plain.png","pipeworks_sand_tube_plain.png","pipeworks_sand_tube_plain.png",
+ "pipeworks_sand_tube_plain.png","pipeworks_sand_tube_plain.png","pipeworks_sand_tube_plain.png"}
+sand_end_textures={"pipeworks_sand_tube_end.png","pipeworks_sand_tube_end.png","pipeworks_sand_tube_end.png",
+ "pipeworks_sand_tube_end.png","pipeworks_sand_tube_end.png","pipeworks_sand_tube_end.png"}
+sand_short_texture="pipeworks_sand_tube_short.png"
+sand_inv_texture="pipeworks_sand_tube_inv.png"
+
+register_tube("pipeworks:sand_tube","Sand pneumatic tube segment",sand_plain_textures,sand_noctr_textures,sand_end_textures,
+ sand_short_texture,sand_inv_texture,
+ {groups={sand_tube=1},
+ tube={can_go=function(pos,node,velocity,stack)
+ return meseadjlist
+ end}})
+
+minetest.register_abm({nodenames={"group:sand_tube"},interval=1,chance=1,
+ action=function(pos, node, active_object_count, active_object_count_wider)
+ for _,object in ipairs(minetest.env:get_objects_inside_radius(pos, 2)) do
+ if not object:is_player() and object:get_luaentity() and object:get_luaentity().name == "__builtin:item" then
+ if object:get_luaentity().itemstring ~= "" then
+ local titem=tube_item(pos,object:get_luaentity().itemstring)
+ titem:get_luaentity().start_pos = {x=pos.x,y=pos.y-1,z=pos.z}
+ titem:setvelocity({x=0,y=1,z=0})
+ titem:setacceleration({x=0, y=0, z=0})
+ end
+ object:get_luaentity().itemstring = ""
+ object:remove()
+ end
+ end
+ end})
+
modpath=minetest.get_modpath("pipeworks")
dofile(modpath.."/teleport_tube.lua") \ No newline at end of file