forked from mtcontrib/pipeworks
Fix indentation and coding style
This commit is contained in:
parent
95aac90b67
commit
27f3a8ab31
369
tubes.lua
369
tubes.lua
@ -1,6 +1,6 @@
|
|||||||
-- This file supplies the various kinds of pneumatic tubes
|
-- This file supplies the various kinds of pneumatic tubes
|
||||||
|
|
||||||
pipeworks.tubenodes={}
|
pipeworks.tubenodes = {}
|
||||||
|
|
||||||
minetest.register_alias("pipeworks:tube", "pipeworks:tube_000000")
|
minetest.register_alias("pipeworks:tube", "pipeworks:tube_000000")
|
||||||
|
|
||||||
@ -215,51 +215,49 @@ end
|
|||||||
|
|
||||||
-- now let's actually call that function to get the real work done!
|
-- now let's actually call that function to get the real work done!
|
||||||
|
|
||||||
local noctr_textures={"pipeworks_tube_noctr.png","pipeworks_tube_noctr.png","pipeworks_tube_noctr.png",
|
local noctr_textures = {"pipeworks_tube_noctr.png","pipeworks_tube_noctr.png","pipeworks_tube_noctr.png",
|
||||||
"pipeworks_tube_noctr.png","pipeworks_tube_noctr.png","pipeworks_tube_noctr.png"}
|
"pipeworks_tube_noctr.png","pipeworks_tube_noctr.png","pipeworks_tube_noctr.png"}
|
||||||
local plain_textures={"pipeworks_tube_plain.png","pipeworks_tube_plain.png","pipeworks_tube_plain.png",
|
local plain_textures = {"pipeworks_tube_plain.png","pipeworks_tube_plain.png","pipeworks_tube_plain.png",
|
||||||
"pipeworks_tube_plain.png","pipeworks_tube_plain.png","pipeworks_tube_plain.png"}
|
"pipeworks_tube_plain.png","pipeworks_tube_plain.png","pipeworks_tube_plain.png"}
|
||||||
local end_textures={"pipeworks_tube_end.png","pipeworks_tube_end.png","pipeworks_tube_end.png",
|
local end_textures = {"pipeworks_tube_end.png","pipeworks_tube_end.png","pipeworks_tube_end.png",
|
||||||
"pipeworks_tube_end.png","pipeworks_tube_end.png","pipeworks_tube_end.png"}
|
"pipeworks_tube_end.png","pipeworks_tube_end.png","pipeworks_tube_end.png"}
|
||||||
local short_texture="pipeworks_tube_short.png"
|
local short_texture = "pipeworks_tube_short.png"
|
||||||
local inv_texture="pipeworks_tube_inv.png"
|
local inv_texture = "pipeworks_tube_inv.png"
|
||||||
|
|
||||||
pipeworks.register_tube("pipeworks:tube","Pneumatic tube segment",plain_textures,noctr_textures,end_textures,short_texture,inv_texture)
|
pipeworks.register_tube("pipeworks:tube", "Pneumatic tube segment", plain_textures, noctr_textures, end_textures, short_texture, inv_texture)
|
||||||
|
|
||||||
|
|
||||||
local mese_noctr_textures={"pipeworks_mese_tube_noctr_1.png","pipeworks_mese_tube_noctr_2.png","pipeworks_mese_tube_noctr_3.png",
|
|
||||||
"pipeworks_mese_tube_noctr_4.png","pipeworks_mese_tube_noctr_5.png","pipeworks_mese_tube_noctr_6.png"}
|
|
||||||
local mese_plain_textures={"pipeworks_mese_tube_plain_1.png","pipeworks_mese_tube_plain_2.png","pipeworks_mese_tube_plain_3.png",
|
|
||||||
"pipeworks_mese_tube_plain_4.png","pipeworks_mese_tube_plain_5.png","pipeworks_mese_tube_plain_6.png"}
|
|
||||||
local mese_end_textures={"pipeworks_mese_tube_end.png","pipeworks_mese_tube_end.png","pipeworks_mese_tube_end.png",
|
|
||||||
"pipeworks_mese_tube_end.png","pipeworks_mese_tube_end.png","pipeworks_mese_tube_end.png"}
|
|
||||||
local mese_short_texture="pipeworks_mese_tube_short.png"
|
|
||||||
local mese_inv_texture="pipeworks_mese_tube_inv.png"
|
|
||||||
|
|
||||||
if pipeworks.enable_mese_tube then
|
if pipeworks.enable_mese_tube then
|
||||||
pipeworks.register_tube("pipeworks:mese_tube","Mese pneumatic tube segment",mese_plain_textures,mese_noctr_textures,
|
local mese_noctr_textures = {"pipeworks_mese_tube_noctr_1.png","pipeworks_mese_tube_noctr_2.png","pipeworks_mese_tube_noctr_3.png",
|
||||||
mese_end_textures,mese_short_texture,mese_inv_texture,
|
"pipeworks_mese_tube_noctr_4.png","pipeworks_mese_tube_noctr_5.png","pipeworks_mese_tube_noctr_6.png"}
|
||||||
{tube={can_go=function(pos,node,velocity,stack)
|
local mese_plain_textures = {"pipeworks_mese_tube_plain_1.png","pipeworks_mese_tube_plain_2.png","pipeworks_mese_tube_plain_3.png",
|
||||||
tbl={}
|
"pipeworks_mese_tube_plain_4.png","pipeworks_mese_tube_plain_5.png","pipeworks_mese_tube_plain_6.png"}
|
||||||
local meta=minetest.get_meta(pos)
|
local mese_end_textures = {"pipeworks_mese_tube_end.png","pipeworks_mese_tube_end.png","pipeworks_mese_tube_end.png",
|
||||||
local inv=meta:get_inventory()
|
"pipeworks_mese_tube_end.png","pipeworks_mese_tube_end.png","pipeworks_mese_tube_end.png"}
|
||||||
local found=false
|
local mese_short_texture = "pipeworks_mese_tube_short.png"
|
||||||
local name=stack:get_name()
|
local mese_inv_texture = "pipeworks_mese_tube_inv.png"
|
||||||
for i,vect in ipairs(pipeworks.meseadjlist) do
|
pipeworks.register_tube("pipeworks:mese_tube", "Mese pneumatic tube segment", mese_plain_textures, mese_noctr_textures,
|
||||||
if meta:get_int("l"..tostring(i).."s")==1 then
|
mese_end_textures, mese_short_texture, mese_inv_texture,
|
||||||
for _,st in ipairs(inv:get_list("line"..tostring(i))) do
|
{tube = {can_go = function(pos, node, velocity, stack)
|
||||||
if st:get_name()==name then
|
local tbl = {}
|
||||||
found=true
|
local meta = minetest.get_meta(pos)
|
||||||
table.insert(tbl,vect)
|
local inv = meta:get_inventory()
|
||||||
|
local found = false
|
||||||
|
local name = stack:get_name()
|
||||||
|
for i, vect in ipairs(pipeworks.meseadjlist) do
|
||||||
|
if meta:get_int("l"..tostring(i).."s") == 1 then
|
||||||
|
for _, st in ipairs(inv:get_list("line"..tostring(i))) do
|
||||||
|
if st:get_name() == name then
|
||||||
|
found = true
|
||||||
|
table.insert(tbl, vect)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if found==false then
|
if found == false then
|
||||||
for i,vect in ipairs(pipeworks.meseadjlist) do
|
for i, vect in ipairs(pipeworks.meseadjlist) do
|
||||||
if meta:get_int("l"..tostring(i).."s")==1 then
|
if meta:get_int("l"..tostring(i).."s") == 1 then
|
||||||
if inv:is_empty("line"..tostring(i)) then
|
if inv:is_empty("line"..tostring(i)) then
|
||||||
table.insert(tbl,vect)
|
table.insert(tbl, vect)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -269,8 +267,8 @@ if pipeworks.enable_mese_tube then
|
|||||||
on_construct = function(pos)
|
on_construct = function(pos)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local inv = meta:get_inventory()
|
local inv = meta:get_inventory()
|
||||||
for i=1,6 do
|
for i = 1, 6 do
|
||||||
meta:set_int("l"..tostring(i).."s",1)
|
meta:set_int("l"..tostring(i).."s", 1)
|
||||||
inv:set_size("line"..tostring(i), 6*1)
|
inv:set_size("line"..tostring(i), 6*1)
|
||||||
end
|
end
|
||||||
meta:set_string("formspec",
|
meta:set_string("formspec",
|
||||||
@ -296,15 +294,16 @@ if pipeworks.enable_mese_tube then
|
|||||||
"list[current_player;main;0,7;8,4;]")
|
"list[current_player;main;0,7;8,4;]")
|
||||||
meta:set_string("infotext", "Mese pneumatic tube")
|
meta:set_string("infotext", "Mese pneumatic tube")
|
||||||
end,
|
end,
|
||||||
on_receive_fields=function(pos,formname,fields,sender)
|
on_receive_fields = function(pos, formname, fields, sender)
|
||||||
local meta=minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local i
|
local i
|
||||||
for key,_ in pairs(fields) do i=key end
|
if fields.quit then return end
|
||||||
if i==nil then return end
|
for key, _ in pairs(fields) do i = key end
|
||||||
i=string.sub(i,-1)
|
if i == nil then return end
|
||||||
newstate=1-meta:get_int("l"..i.."s")
|
i = string.sub(i,-1)
|
||||||
|
newstate = 1 - meta:get_int("l"..i.."s")
|
||||||
meta:set_int("l"..i.."s",newstate)
|
meta:set_int("l"..i.."s",newstate)
|
||||||
local frm="size[8,11]"..
|
local frm = "size[8,11]"..
|
||||||
"list[current_name;line1;1,0;6,1;]"..
|
"list[current_name;line1;1,0;6,1;]"..
|
||||||
"list[current_name;line2;1,1;6,1;]"..
|
"list[current_name;line2;1,1;6,1;]"..
|
||||||
"list[current_name;line3;1,2;6,1;]"..
|
"list[current_name;line3;1,2;6,1;]"..
|
||||||
@ -317,19 +316,19 @@ if pipeworks.enable_mese_tube then
|
|||||||
"image[0,3;1,1;pipeworks_yellow.png]"..
|
"image[0,3;1,1;pipeworks_yellow.png]"..
|
||||||
"image[0,4;1,1;pipeworks_blue.png]"..
|
"image[0,4;1,1;pipeworks_blue.png]"..
|
||||||
"image[0,5;1,1;pipeworks_red.png]"
|
"image[0,5;1,1;pipeworks_red.png]"
|
||||||
for i=1,6 do
|
for i = 1, 6 do
|
||||||
local st=meta:get_int("l"..tostring(i).."s")
|
local st = meta:get_int("l"..tostring(i).."s")
|
||||||
if st==0 then
|
if st == 0 then
|
||||||
frm=frm.."button[7,"..tostring(i-1)..";1,1;button"..tostring(i)..";Off]"
|
frm = frm.."button[7,"..tostring(i-1)..";1,1;button"..tostring(i)..";Off]"
|
||||||
else
|
else
|
||||||
frm=frm.."button[7,"..tostring(i-1)..";1,1;button"..tostring(i)..";On]"
|
frm = frm.."button[7,"..tostring(i-1)..";1,1;button"..tostring(i)..";On]"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
frm=frm.."list[current_player;main;0,7;8,4;]"
|
frm = frm.."list[current_player;main;0,7;8,4;]"
|
||||||
meta:set_string("formspec",frm)
|
meta:set_string("formspec", frm)
|
||||||
end,
|
end,
|
||||||
can_dig = function(pos,player)
|
can_dig = function(pos, player)
|
||||||
local meta = minetest.get_meta(pos);
|
local meta = minetest.get_meta(pos)
|
||||||
local inv = meta:get_inventory()
|
local inv = meta:get_inventory()
|
||||||
return (inv:is_empty("line1") and inv:is_empty("line2") and inv:is_empty("line3") and
|
return (inv:is_empty("line1") and inv:is_empty("line2") and inv:is_empty("line3") and
|
||||||
inv:is_empty("line4") and inv:is_empty("line5") and inv:is_empty("line6"))
|
inv:is_empty("line4") and inv:is_empty("line5") and inv:is_empty("line6"))
|
||||||
@ -338,32 +337,30 @@ if pipeworks.enable_mese_tube then
|
|||||||
end
|
end
|
||||||
|
|
||||||
if pipeworks.enable_detector_tube then
|
if pipeworks.enable_detector_tube then
|
||||||
|
local detector_plain_textures = {"pipeworks_detector_tube_plain.png", "pipeworks_detector_tube_plain.png", "pipeworks_detector_tube_plain.png",
|
||||||
local detector_plain_textures={"pipeworks_detector_tube_plain.png","pipeworks_detector_tube_plain.png","pipeworks_detector_tube_plain.png",
|
"pipeworks_detector_tube_plain.png", "pipeworks_detector_tube_plain.png", "pipeworks_detector_tube_plain.png"}
|
||||||
"pipeworks_detector_tube_plain.png","pipeworks_detector_tube_plain.png","pipeworks_detector_tube_plain.png"}
|
local detector_inv_texture = "pipeworks_detector_tube_inv.png"
|
||||||
local detector_inv_texture="pipeworks_detector_tube_inv.png"
|
pipeworks.register_tube("pipeworks:detector_tube_on", "Detector tube segment on (you hacker you)", detector_plain_textures, noctr_textures,
|
||||||
|
end_textures, short_texture, detector_inv_texture,
|
||||||
pipeworks.register_tube("pipeworks:detector_tube_on","Detector tube segment on (you hacker you)",detector_plain_textures,noctr_textures,
|
{tube = {can_go = function(pos, node, velocity, stack)
|
||||||
end_textures,short_texture,detector_inv_texture,
|
|
||||||
{tube={can_go=function(pos,node,velocity,stack)
|
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local name = minetest.get_node(pos).name
|
local name = minetest.get_node(pos).name
|
||||||
local nitems=meta:get_int("nitems")+1
|
local nitems = meta:get_int("nitems")+1
|
||||||
meta:set_int("nitems", nitems)
|
meta:set_int("nitems", nitems)
|
||||||
minetest.after(0.1,minetest.registered_nodes[name].item_exit,pos)
|
minetest.after(0.1, minetest.registered_nodes[name].item_exit, pos)
|
||||||
return pipeworks.notvel(pipeworks.meseadjlist,velocity)
|
return pipeworks.notvel(pipeworks.meseadjlist,velocity)
|
||||||
end},
|
end},
|
||||||
groups={mesecon=2,not_in_creative_inventory=1},
|
groups = {mesecon = 2, not_in_creative_inventory = 1},
|
||||||
drop="pipeworks:detector_tube_off_000000",
|
drop = "pipeworks:detector_tube_off_1",
|
||||||
mesecons={receptor={state="on",
|
mesecons = {receptor = {state = "on",
|
||||||
rules=pipeworks.mesecons_rules}},
|
rules = pipeworks.mesecons_rules}},
|
||||||
item_exit = function(pos)
|
item_exit = function(pos)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local nitems=meta:get_int("nitems")-1
|
local nitems = meta:get_int("nitems")-1
|
||||||
local name = minetest.get_node(pos).name
|
local name = minetest.get_node(pos).name
|
||||||
if nitems==0 then
|
if nitems == 0 then
|
||||||
minetest.set_node(pos,{name=string.gsub(name,"on","off")})
|
minetest.set_node(pos,{name = string.gsub(name, "on", "off")})
|
||||||
mesecon:receptor_off(pos,pipeworks.mesecons_rules)
|
mesecon:receptor_off(pos, pipeworks.mesecons_rules)
|
||||||
else
|
else
|
||||||
meta:set_int("nitems", nitems)
|
meta:set_int("nitems", nitems)
|
||||||
end
|
end
|
||||||
@ -372,109 +369,111 @@ if pipeworks.enable_detector_tube then
|
|||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
meta:set_int("nitems", 1)
|
meta:set_int("nitems", 1)
|
||||||
local name = minetest.get_node(pos).name
|
local name = minetest.get_node(pos).name
|
||||||
minetest.after(0.1,minetest.registered_nodes[name].item_exit,pos)
|
minetest.after(0.1, minetest.registered_nodes[name].item_exit,pos)
|
||||||
end})
|
end})
|
||||||
|
pipeworks.register_tube("pipeworks:detector_tube_off", "Detector tube segment", detector_plain_textures, noctr_textures,
|
||||||
pipeworks.register_tube("pipeworks:detector_tube_off","Detector tube segment",detector_plain_textures,noctr_textures,
|
end_textures, short_texture, detector_inv_texture,
|
||||||
end_textures,short_texture,detector_inv_texture,
|
{tube = {can_go = function(pos, node, velocity, stack)
|
||||||
{tube={can_go=function(pos,node,velocity,stack)
|
|
||||||
local name = minetest.get_node(pos).name
|
local name = minetest.get_node(pos).name
|
||||||
minetest.set_node(pos,{name=string.gsub(name,"off","on")})
|
minetest.set_node(pos,{name = string.gsub(name, "off", "on")})
|
||||||
mesecon:receptor_on(pos,pipeworks.mesecons_rules)
|
mesecon:receptor_on(pos, pipeworks.mesecons_rules)
|
||||||
return pipeworks.notvel(pipeworks.meseadjlist,velocity)
|
return pipeworks.notvel(pipeworks.meseadjlist, velocity)
|
||||||
end},
|
end},
|
||||||
groups={mesecon=2},
|
groups = {mesecon = 2},
|
||||||
mesecons={receptor={state="off",
|
mesecons = {receptor = {state = "off",
|
||||||
rules=pipeworks.mesecons_rules}}
|
rules = pipeworks.mesecons_rules}}
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
local conductor_plain_textures={"pipeworks_conductor_tube_plain.png","pipeworks_conductor_tube_plain.png","pipeworks_conductor_tube_plain.png",
|
|
||||||
"pipeworks_conductor_tube_plain.png","pipeworks_conductor_tube_plain.png","pipeworks_conductor_tube_plain.png"}
|
|
||||||
local conductor_noctr_textures={"pipeworks_conductor_tube_noctr.png","pipeworks_conductor_tube_noctr.png","pipeworks_conductor_tube_noctr.png",
|
|
||||||
"pipeworks_conductor_tube_noctr.png","pipeworks_conductor_tube_noctr.png","pipeworks_conductor_tube_noctr.png"}
|
|
||||||
local conductor_end_textures={"pipeworks_conductor_tube_end.png","pipeworks_conductor_tube_end.png","pipeworks_conductor_tube_end.png",
|
|
||||||
"pipeworks_conductor_tube_end.png","pipeworks_conductor_tube_end.png","pipeworks_conductor_tube_end.png"}
|
|
||||||
local conductor_short_texture="pipeworks_conductor_tube_short.png"
|
|
||||||
local conductor_inv_texture="pipeworks_conductor_tube_inv.png"
|
|
||||||
|
|
||||||
local conductor_on_plain_textures={"pipeworks_conductor_tube_on_plain.png","pipeworks_conductor_tube_on_plain.png","pipeworks_conductor_tube_on_plain.png",
|
|
||||||
"pipeworks_conductor_tube_on_plain.png","pipeworks_conductor_tube_on_plain.png","pipeworks_conductor_tube_on_plain.png"}
|
|
||||||
local conductor_on_noctr_textures={"pipeworks_conductor_tube_on_noctr.png","pipeworks_conductor_tube_on_noctr.png","pipeworks_conductor_tube_on_noctr.png",
|
|
||||||
"pipeworks_conductor_tube_on_noctr.png","pipeworks_conductor_tube_on_noctr.png","pipeworks_conductor_tube_on_noctr.png"}
|
|
||||||
local conductor_on_end_textures={"pipeworks_conductor_tube_on_end.png","pipeworks_conductor_tube_on_end.png","pipeworks_conductor_tube_on_end.png",
|
|
||||||
"pipeworks_conductor_tube_on_end.png","pipeworks_conductor_tube_on_end.png","pipeworks_conductor_tube_on_end.png"}
|
|
||||||
|
|
||||||
if pipeworks.enable_conductor_tube then
|
if pipeworks.enable_conductor_tube then
|
||||||
pipeworks.register_tube("pipeworks:conductor_tube_off","Conductor tube segment",conductor_plain_textures,conductor_noctr_textures,
|
local conductor_plain_textures = {"pipeworks_conductor_tube_plain.png", "pipeworks_conductor_tube_plain.png", "pipeworks_conductor_tube_plain.png",
|
||||||
conductor_end_textures,conductor_short_texture,conductor_inv_texture,
|
"pipeworks_conductor_tube_plain.png", "pipeworks_conductor_tube_plain.png", "pipeworks_conductor_tube_plain.png"}
|
||||||
{groups={mesecon=2},
|
local conductor_noctr_textures = {"pipeworks_conductor_tube_noctr.png", "pipeworks_conductor_tube_noctr.png", "pipeworks_conductor_tube_noctr.png",
|
||||||
mesecons={conductor={state="off",
|
"pipeworks_conductor_tube_noctr.png", "pipeworks_conductor_tube_noctr.png", "pipeworks_conductor_tube_noctr.png"}
|
||||||
rules=pipeworks.mesecons_rules,
|
local conductor_end_textures = {"pipeworks_conductor_tube_end.png", "pipeworks_conductor_tube_end.png", "pipeworks_conductor_tube_end.png",
|
||||||
onstate="pipeworks:conductor_tube_on_#id"}}
|
"pipeworks_conductor_tube_end.png", "pipeworks_conductor_tube_end.png", "pipeworks_conductor_tube_end.png"}
|
||||||
|
local conductor_short_texture = "pipeworks_conductor_tube_short.png"
|
||||||
|
local conductor_inv_texture = "pipeworks_conductor_tube_inv.png"
|
||||||
|
|
||||||
|
local conductor_on_plain_textures = {"pipeworks_conductor_tube_on_plain.png", "pipeworks_conductor_tube_on_plain.png", "pipeworks_conductor_tube_on_plain.png",
|
||||||
|
"pipeworks_conductor_tube_on_plain.png", "pipeworks_conductor_tube_on_plain.png", "pipeworks_conductor_tube_on_plain.png"}
|
||||||
|
local conductor_on_noctr_textures = {"pipeworks_conductor_tube_on_noctr.png", "pipeworks_conductor_tube_on_noctr.png", "pipeworks_conductor_tube_on_noctr.png",
|
||||||
|
"pipeworks_conductor_tube_on_noctr.png", "pipeworks_conductor_tube_on_noctr.png", "pipeworks_conductor_tube_on_noctr.png"}
|
||||||
|
local conductor_on_end_textures = {"pipeworks_conductor_tube_on_end.png", "pipeworks_conductor_tube_on_end.png", "pipeworks_conductor_tube_on_end.png",
|
||||||
|
"pipeworks_conductor_tube_on_end.png", "pipeworks_conductor_tube_on_end.png", "pipeworks_conductor_tube_on_end.png"}
|
||||||
|
|
||||||
|
pipeworks.register_tube("pipeworks:conductor_tube_off", "Conductor tube segment", conductor_plain_textures, conductor_noctr_textures,
|
||||||
|
conductor_end_textures, conductor_short_texture, conductor_inv_texture,
|
||||||
|
{groups = {mesecon = 2},
|
||||||
|
mesecons = {conductor = {state = "off",
|
||||||
|
rules = pipeworks.mesecons_rules,
|
||||||
|
onstate = "pipeworks:conductor_tube_on_#id"}}
|
||||||
})
|
})
|
||||||
|
|
||||||
pipeworks.register_tube("pipeworks:conductor_tube_on","Conductor tube segment on (you hacker you)",conductor_on_plain_textures,conductor_on_noctr_textures,
|
pipeworks.register_tube("pipeworks:conductor_tube_on", "Conductor tube segment on (you hacker you)", conductor_on_plain_textures, conductor_on_noctr_textures,
|
||||||
conductor_on_end_textures,conductor_short_texture,conductor_inv_texture,
|
conductor_on_end_textures, conductor_short_texture, conductor_inv_texture,
|
||||||
{groups={mesecon=2,not_in_creative_inventory=1},
|
{groups = {mesecon = 2, not_in_creative_inventory = 1},
|
||||||
drop="pipeworks:conductor_tube_off_000000",
|
drop = "pipeworks:conductor_tube_off_1",
|
||||||
mesecons={conductor={state="on",
|
mesecons = {conductor = {state = "on",
|
||||||
rules=pipeworks.mesecons_rules,
|
rules = pipeworks.mesecons_rules,
|
||||||
offstate="pipeworks:conductor_tube_off_#id"}}
|
offstate = "pipeworks:conductor_tube_off_#id"}}
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
local 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"}
|
|
||||||
local 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"}
|
|
||||||
local 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"}
|
|
||||||
local accelerator_short_texture="pipeworks_accelerator_tube_short.png"
|
|
||||||
local accelerator_inv_texture="pipeworks_accelerator_tube_inv.png"
|
|
||||||
|
|
||||||
if pipeworks.enable_accelerator_tube then
|
if pipeworks.enable_accelerator_tube then
|
||||||
pipeworks.register_tube("pipeworks:accelerator_tube","Accelerator pneumatic tube segment",accelerator_plain_textures,
|
local accelerator_noctr_textures = {"pipeworks_accelerator_tube_noctr.png", "pipeworks_accelerator_tube_noctr.png", "pipeworks_accelerator_tube_noctr.png",
|
||||||
accelerator_noctr_textures,accelerator_end_textures,accelerator_short_texture,accelerator_inv_texture,
|
"pipeworks_accelerator_tube_noctr.png", "pipeworks_accelerator_tube_noctr.png", "pipeworks_accelerator_tube_noctr.png"}
|
||||||
{tube={can_go=function(pos,node,velocity,stack)
|
local accelerator_plain_textures = {"pipeworks_accelerator_tube_plain.png" ,"pipeworks_accelerator_tube_plain.png", "pipeworks_accelerator_tube_plain.png",
|
||||||
velocity.speed=velocity.speed+1
|
"pipeworks_accelerator_tube_plain.png", "pipeworks_accelerator_tube_plain.png", "pipeworks_accelerator_tube_plain.png"}
|
||||||
return pipeworks.notvel(pipeworks.meseadjlist,velocity)
|
local 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"}
|
||||||
|
local accelerator_short_texture = "pipeworks_accelerator_tube_short.png"
|
||||||
|
local accelerator_inv_texture = "pipeworks_accelerator_tube_inv.png"
|
||||||
|
|
||||||
|
pipeworks.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 pipeworks.notvel(pipeworks.meseadjlist, velocity)
|
||||||
end}
|
end}
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
if pipeworks.enable_crossing_tube then
|
if pipeworks.enable_crossing_tube then
|
||||||
pipeworks.register_tube("pipeworks:crossing_tube","Crossing tube segment",accelerator_plain_textures,
|
-- FIXME: The textures are not the correct ones
|
||||||
accelerator_noctr_textures,accelerator_end_textures,accelerator_short_texture,accelerator_inv_texture,
|
pipeworks.register_tube("pipeworks:crossing_tube", "Crossing tube segment", accelerator_plain_textures,
|
||||||
{tube={can_go=function(pos,node,velocity,stack)
|
accelerator_noctr_textures, accelerator_end_textures, accelerator_short_texture, accelerator_inv_texture,
|
||||||
|
{tube = {can_go = function(pos, node, velocity, stack)
|
||||||
return {velocity}
|
return {velocity}
|
||||||
end}
|
end}
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
local 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"}
|
|
||||||
local 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"}
|
|
||||||
local 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"}
|
|
||||||
local sand_short_texture="pipeworks_sand_tube_short.png"
|
|
||||||
local sand_inv_texture="pipeworks_sand_tube_inv.png"
|
|
||||||
|
|
||||||
if pipeworks.enable_sand_tube then
|
if pipeworks.enable_sand_tube then
|
||||||
pipeworks.register_tube("pipeworks:sand_tube","Sand pneumatic tube segment",sand_plain_textures,sand_noctr_textures,sand_end_textures,
|
local sand_noctr_textures = {"pipeworks_sand_tube_noctr.png", "pipeworks_sand_tube_noctr.png", "pipeworks_sand_tube_noctr.png",
|
||||||
sand_short_texture,sand_inv_texture,
|
"pipeworks_sand_tube_noctr.png", "pipeworks_sand_tube_noctr.png", "pipeworks_sand_tube_noctr.png"}
|
||||||
{groups={sand_tube=1}})
|
local 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"}
|
||||||
|
local 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"}
|
||||||
|
local sand_short_texture = "pipeworks_sand_tube_short.png"
|
||||||
|
local sand_inv_texture = "pipeworks_sand_tube_inv.png"
|
||||||
|
|
||||||
minetest.register_abm({nodenames={"group:sand_tube"},interval=1,chance=1,
|
pipeworks.register_tube("pipeworks:sand_tube", "Sand pneumatic tube segment", sand_plain_textures, sand_noctr_textures, sand_end_textures,
|
||||||
action=function(pos, node, active_object_count, active_object_count_wider)
|
sand_short_texture, sand_inv_texture,
|
||||||
for _,object in ipairs(minetest.get_objects_inside_radius(pos, 2)) do
|
{groups = {sand_tube = 1}})
|
||||||
|
|
||||||
|
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.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 not object:is_player() and object:get_luaentity() and object:get_luaentity().name == "__builtin:item" then
|
||||||
if object:get_luaentity().itemstring ~= "" then
|
if object:get_luaentity().itemstring ~= "" then
|
||||||
local titem=pipeworks.tube_item(pos,object:get_luaentity().itemstring)
|
local titem = pipeworks.tube_item(pos,object:get_luaentity().itemstring)
|
||||||
titem:get_luaentity().start_pos = {x=pos.x,y=pos.y-1,z=pos.z}
|
titem:get_luaentity().start_pos = {x = pos.x, y = pos.y-1, z = pos.z}
|
||||||
titem:setvelocity({x=0.01,y=1,z=-0.01})
|
titem:setvelocity({x = 0.01, y = 1, z = -0.01})
|
||||||
titem:setacceleration({x=0, y=0, z=0})
|
titem:setacceleration({x = 0, y = 0, z = 0})
|
||||||
end
|
end
|
||||||
object:get_luaentity().itemstring = ""
|
object:get_luaentity().itemstring = ""
|
||||||
object:remove()
|
object:remove()
|
||||||
@ -484,19 +483,19 @@ if pipeworks.enable_sand_tube then
|
|||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
local mese_sand_noctr_textures={"pipeworks_mese_sand_tube_noctr.png","pipeworks_mese_sand_tube_noctr.png","pipeworks_mese_sand_tube_noctr.png",
|
|
||||||
"pipeworks_mese_sand_tube_noctr.png","pipeworks_mese_sand_tube_noctr.png","pipeworks_mese_sand_tube_noctr.png"}
|
|
||||||
local mese_sand_plain_textures={"pipeworks_mese_sand_tube_plain.png","pipeworks_mese_sand_tube_plain.png","pipeworks_mese_sand_tube_plain.png",
|
|
||||||
"pipeworks_mese_sand_tube_plain.png","pipeworks_mese_sand_tube_plain.png","pipeworks_mese_sand_tube_plain.png"}
|
|
||||||
local mese_sand_end_textures={"pipeworks_mese_sand_tube_end.png","pipeworks_mese_sand_tube_end.png","pipeworks_mese_sand_tube_end.png",
|
|
||||||
"pipeworks_mese_sand_tube_end.png","pipeworks_mese_sand_tube_end.png","pipeworks_mese_sand_tube_end.png"}
|
|
||||||
local mese_sand_short_texture="pipeworks_mese_sand_tube_short.png"
|
|
||||||
local mese_sand_inv_texture="pipeworks_mese_sand_tube_inv.png"
|
|
||||||
|
|
||||||
if pipeworks.enable_mese_sand_tube then
|
if pipeworks.enable_mese_sand_tube then
|
||||||
pipeworks.register_tube("pipeworks:mese_sand_tube","Mese sand pneumatic tube segment",mese_sand_plain_textures,mese_sand_noctr_textures,mese_sand_end_textures,
|
local mese_sand_noctr_textures = {"pipeworks_mese_sand_tube_noctr.png", "pipeworks_mese_sand_tube_noctr.png", "pipeworks_mese_sand_tube_noctr.png",
|
||||||
mese_sand_short_texture,mese_sand_inv_texture,
|
"pipeworks_mese_sand_tube_noctr.png", "pipeworks_mese_sand_tube_noctr.png", "pipeworks_mese_sand_tube_noctr.png"}
|
||||||
{groups={mese_sand_tube=1},
|
local mese_sand_plain_textures = {"pipeworks_mese_sand_tube_plain.png", "pipeworks_mese_sand_tube_plain.png", "pipeworks_mese_sand_tube_plain.png",
|
||||||
|
"pipeworks_mese_sand_tube_plain.png", "pipeworks_mese_sand_tube_plain.png", "pipeworks_mese_sand_tube_plain.png"}
|
||||||
|
local mese_sand_end_textures = {"pipeworks_mese_sand_tube_end.png", "pipeworks_mese_sand_tube_end.png", "pipeworks_mese_sand_tube_end.png",
|
||||||
|
"pipeworks_mese_sand_tube_end.png", "pipeworks_mese_sand_tube_end.png", "pipeworks_mese_sand_tube_end.png"}
|
||||||
|
local mese_sand_short_texture = "pipeworks_mese_sand_tube_short.png"
|
||||||
|
local mese_sand_inv_texture = "pipeworks_mese_sand_tube_inv.png"
|
||||||
|
|
||||||
|
pipeworks.register_tube("pipeworks:mese_sand_tube", "Mese sand pneumatic tube segment", mese_sand_plain_textures, mese_sand_noctr_textures,
|
||||||
|
mese_sand_end_textures, mese_sand_short_texture,mese_sand_inv_texture,
|
||||||
|
{groups = {mese_sand_tube = 1},
|
||||||
on_construct = function(pos)
|
on_construct = function(pos)
|
||||||
local meta = minetest.env:get_meta(pos)
|
local meta = minetest.env:get_meta(pos)
|
||||||
meta:set_int("dist", 0)
|
meta:set_int("dist", 0)
|
||||||
@ -505,8 +504,8 @@ if pipeworks.enable_mese_sand_tube then
|
|||||||
"field[.5,.5;1.5,1;dist;distance;${dist}]")
|
"field[.5,.5;1.5,1;dist;distance;${dist}]")
|
||||||
meta:set_string("infotext", "Mese sand pneumatic tube")
|
meta:set_string("infotext", "Mese sand pneumatic tube")
|
||||||
end,
|
end,
|
||||||
on_receive_fields=function(pos,formname,fields,sender)
|
on_receive_fields = function(pos,formname,fields,sender)
|
||||||
local meta=minetest.env:get_meta(pos)
|
local meta = minetest.env:get_meta(pos)
|
||||||
local dist
|
local dist
|
||||||
_, dist = pcall(tonumber, fields.dist)
|
_, dist = pcall(tonumber, fields.dist)
|
||||||
if dist and 0 <= dist and dist <= 8 then meta:set_int("dist", dist) end
|
if dist and 0 <= dist and dist <= 8 then meta:set_int("dist", dist) end
|
||||||
@ -527,15 +526,17 @@ if pipeworks.enable_mese_sand_tube then
|
|||||||
return objs
|
return objs
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_abm({nodenames={"group:mese_sand_tube"},interval=1,chance=1,
|
minetest.register_abm({nodenames = {"group:mese_sand_tube"},
|
||||||
action=function(pos, node, active_object_count, active_object_count_wider)
|
interval = 1,
|
||||||
|
chance = 1,
|
||||||
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
for _,object in ipairs(get_objects_with_square_radius(pos, minetest.env:get_meta(pos):get_int("dist"))) do
|
for _,object in ipairs(get_objects_with_square_radius(pos, minetest.env:get_meta(pos):get_int("dist"))) do
|
||||||
if not object:is_player() and object:get_luaentity() and object:get_luaentity().name == "__builtin:item" then
|
if not object:is_player() and object:get_luaentity() and object:get_luaentity().name == "__builtin:item" then
|
||||||
if object:get_luaentity().itemstring ~= "" then
|
if object:get_luaentity().itemstring ~= "" then
|
||||||
local titem=pipeworks.tube_item(pos,object:get_luaentity().itemstring)
|
local titem = pipeworks.tube_item(pos, object:get_luaentity().itemstring)
|
||||||
titem:get_luaentity().start_pos = {x=pos.x,y=pos.y-1,z=pos.z}
|
titem:get_luaentity().start_pos = {x = pos.x, y = pos.y-1, z = pos.z}
|
||||||
titem:setvelocity({x=0.01,y=1,z=-0.01})
|
titem:setvelocity({x = 0.01, y = 1, z = -0.01})
|
||||||
titem:setacceleration({x=0, y=0, z=0})
|
titem:setacceleration({x = 0, y = 0, z = 0})
|
||||||
end
|
end
|
||||||
object:get_luaentity().itemstring = ""
|
object:get_luaentity().itemstring = ""
|
||||||
object:remove()
|
object:remove()
|
||||||
@ -549,17 +550,17 @@ local function facedir_to_right_dir(facedir)
|
|||||||
|
|
||||||
--find the other directions
|
--find the other directions
|
||||||
local backdir = minetest.facedir_to_dir(facedir)
|
local backdir = minetest.facedir_to_dir(facedir)
|
||||||
local topdir = ({[0]={x=0, y=1, z=0},
|
local topdir = ({[0] = {x = 0, y = 1, z = 0},
|
||||||
{x=0, y=0, z=1},
|
{x = 0, y = 0, z = 1},
|
||||||
{x=0, y=0, z=-1},
|
{x = 0, y = 0, z = -1},
|
||||||
{x=1, y=0, z=0},
|
{x = 1, y = 0, z = 0},
|
||||||
{x=-1, y=0, z=0},
|
{x = -1, y = 0, z = 0},
|
||||||
{x=0, y=-1, z=0}})[math.floor(facedir/4)]
|
{x = 0, y = -1, z = 0}})[math.floor(facedir/4)]
|
||||||
|
|
||||||
--return a cross product
|
--return a cross product
|
||||||
return {x=topdir.y*backdir.z - backdir.y*topdir.z,
|
return {x = topdir.y*backdir.z - backdir.y*topdir.z,
|
||||||
y=topdir.z*backdir.x - backdir.z*topdir.x,
|
y = topdir.z*backdir.x - backdir.z*topdir.x,
|
||||||
z=topdir.x*backdir.y - backdir.x*topdir.y}
|
z = topdir.x*backdir.y - backdir.x*topdir.y}
|
||||||
end
|
end
|
||||||
|
|
||||||
if pipeworks.enable_one_way_tube then
|
if pipeworks.enable_one_way_tube then
|
||||||
@ -572,7 +573,7 @@ if pipeworks.enable_one_way_tube then
|
|||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
node_box = {type="fixed",
|
node_box = {type="fixed",
|
||||||
fixed = {{-1/2, -9/64, -9/64, 1/2, 9/64, 9/64}}},
|
fixed = {{-1/2, -9/64, -9/64, 1/2, 9/64, 9/64}}},
|
||||||
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2,tubedevice=1,tubedevice_receiver=1},
|
groups = {snappy = 2, choppy = 2, oddly_breakable_by_hand = 2, tubedevice = 1, tubedevice_receiver = 1},
|
||||||
legacy_facedir_simple = true,
|
legacy_facedir_simple = true,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
after_place_node = function(pos)
|
after_place_node = function(pos)
|
||||||
@ -581,18 +582,18 @@ if pipeworks.enable_one_way_tube then
|
|||||||
after_dig_node = function(pos)
|
after_dig_node = function(pos)
|
||||||
pipeworks.scan_for_tube_objects(pos)
|
pipeworks.scan_for_tube_objects(pos)
|
||||||
end,
|
end,
|
||||||
tube={connect_sides={left=1, right=1},
|
tube = {connect_sides = {left = 1, right = 1},
|
||||||
can_go=function(pos,node,velocity,stack)
|
can_go = function(pos, node, velocity, stack)
|
||||||
return velocity
|
return velocity
|
||||||
end,
|
end,
|
||||||
insert_object = function(pos,node,stack,direction)
|
insert_object = function(pos, node, stack, direction)
|
||||||
item1=pipeworks.tube_item(pos,stack)
|
item1 = pipeworks.tube_item(pos, stack)
|
||||||
item1:get_luaentity().start_pos = pos
|
item1:get_luaentity().start_pos = pos
|
||||||
item1:setvelocity({x=direction.x*direction.speed, y=direction.y*direction.speed, z=direction.z*direction.speed})
|
item1:setvelocity({x = direction.x*direction.speed, y = direction.y*direction.speed, z = direction.z*direction.speed})
|
||||||
item1:setacceleration({x=0, y=0, z=0})
|
item1:setacceleration({x = 0, y = 0, z = 0})
|
||||||
return ItemStack("")
|
return ItemStack("")
|
||||||
end,
|
end,
|
||||||
can_insert=function(pos,node,stack,direction)
|
can_insert = function(pos, node, stack, direction)
|
||||||
local dir = facedir_to_right_dir(node.param2)
|
local dir = facedir_to_right_dir(node.param2)
|
||||||
if dir.x == direction.x and dir.y == direction.y and dir.z == direction.z then
|
if dir.x == direction.x and dir.y == direction.y and dir.z == direction.z then
|
||||||
return true
|
return true
|
||||||
|
Loading…
Reference in New Issue
Block a user