summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVanessaE <vanessaezekowitz@gmail.com>2013-06-05 07:38:47 -0700
committerVanessaE <vanessaezekowitz@gmail.com>2013-06-05 07:38:47 -0700
commit8c034ff6ef3a9f71d9777667197c255bde7e7055 (patch)
tree5dc2d9a7015b628e1c3441156128c561801d0eab
parent3796ddd3d8916ed47996846b2b30ad0ae460f9cc (diff)
parentc9a8224bb5f27bb308d2fb9e3480e82f39f80943 (diff)
Merge pull request #37 from Novatux/teleport
Add an no-receive option to teleport tubes.
-rw-r--r--teleport_tube.lua35
1 files changed, 27 insertions, 8 deletions
diff --git a/teleport_tube.lua b/teleport_tube.lua
index 76370c2..10541f0 100644
--- a/teleport_tube.lua
+++ b/teleport_tube.lua
@@ -16,14 +16,14 @@ function write_file(tbl)
f:close()
end
-function add_tube_in_file(pos,channel)
+function add_tube_in_file(pos,channel, cr)
tbl=read_file()
for _,val in ipairs(tbl) do
if val.x==pos.x and val.y==pos.y and val.z==pos.z then
return
end
end
- table.insert(tbl,{x=pos.x,y=pos.y,z=pos.z,channel=channel})
+ table.insert(tbl,{x=pos.x,y=pos.y,z=pos.z,channel=channel,cr=cr})
write_file(tbl)
end
@@ -45,11 +45,12 @@ function get_tubes_in_file(pos,channel)
for _,val in ipairs(tbl) do
local node = minetest.env:get_node(val)
local meta = minetest.env:get_meta(val)
- if node.name~="ignore" and val.channel~=meta:get_string("channel") then
+ if node.name~="ignore" and (val.channel~=meta:get_string("channel") or val.cr~=meta:get_int("can_receive")) then
val.channel=meta:get_string("channel")
+ val.cr=meta:get_int("can_receive")
changed=true
end
- if val.channel==channel and (val.x~=pos.x or val.y~=pos.y or val.z~=pos.z) then
+ if val.cr==1 and val.channel==channel and (val.x~=pos.x or val.y~=pos.y or val.z~=pos.z) then
table.insert(newtbl,val)
end
end
@@ -84,15 +85,33 @@ register_tube("pipeworks:teleport_tube","Teleporter pneumatic tube segment",tele
end},
on_construct = function(pos)
local meta = minetest.env:get_meta(pos)
- meta:set_string("channel","0")
- meta:set_string("formspec","size[9,1;]field[0,0.5;9,1;channel;Channel:;${channel}]")
- add_tube_in_file(pos,"0")
+ meta:set_string("channel","")
+ meta:set_int("can_receive",1)
+ meta:set_string("formspec","size[9,1;]"..
+ "field[0,0.5;7,1;channel;Channel:;${channel}]"..
+ "button[8,0;1,1;bt;On]")
+ add_tube_in_file(pos,"")
end,
on_receive_fields = function(pos,formname,fields,sender)
local meta = minetest.env:get_meta(pos)
+ if fields.channel==nil then fields.channel=meta:get_string("channel") end
meta:set_string("channel",fields.channel)
remove_tube_in_file(pos)
- add_tube_in_file(pos,fields.channel)
+ local cr = meta:get_int("can_receive")
+ if fields["bt"] then
+ cr=1-cr
+ meta:set_int("can_receive",cr)
+ if cr==1 then
+ meta:set_string("formspec","size[9,1;]"..
+ "field[0,0.5;7,1;channel;Channel:;${channel}]"..
+ "button[8,0;1,1;bt;On]")
+ else
+ meta:set_string("formspec","size[9,1;]"..
+ "field[0,0.5;7,1;channel;Channel:;${channel}]"..
+ "button[8,0;1,1;bt;Off]")
+ end
+ end
+ add_tube_in_file(pos,fields.channel, cr)
end,
on_destruct = function(pos)
remove_tube_in_file(pos)