summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTim <t4im@users.noreply.github.com>2015-01-25 20:05:10 +0100
committerTim <t4im@users.noreply.github.com>2015-01-25 20:05:10 +0100
commit5b026d2cc7c17de260e0c143565988483e3c309f (patch)
tree78c04c20f7ca435f4fdd7ba255a6526983f6cda7
parentcdd3eb209b653defe148fd9fad6129b5e940fdd7 (diff)
improve tp_tube configuration handling to decrease disk i/o, handle empty strings and form escapes
-rw-r--r--teleport_tube.lua48
1 files changed, 35 insertions, 13 deletions
diff --git a/teleport_tube.lua b/teleport_tube.lua
index 44a7fce..2f391f7 100644
--- a/teleport_tube.lua
+++ b/teleport_tube.lua
@@ -40,7 +40,7 @@ local function set_tube(pos, channel, can_receive)
end
-- we haven't found any tp tube to update, so lets add it
- table.insert(tp_tube_db,{x=pos.x,y=pos.y,z=pos.z,channel=channel,cr=cr})
+ table.insert(tp_tube_db,{x=pos.x,y=pos.y,z=pos.z,channel=channel,cr=can_receive})
save_tube_db()
end
@@ -48,7 +48,8 @@ local function remove_tube(pos)
local tubes = tp_tube_db or read_tube_db()
local newtbl = {}
for _, val in ipairs(tubes) do
- if val.x ~= pos.x or val.y ~= pos.y or val.z ~= pos.z then
+ if val.channel ~= "" -- remove also any empty channels when we stumble over them
+ and (val.x ~= pos.x or val.y ~= pos.y or val.z ~= pos.z) then
table.insert(newtbl, val)
end
end
@@ -122,6 +123,7 @@ pipeworks.register_tube("pipeworks:teleport_tube","Teleporting Pneumatic Tube Se
velocity.z = 0
local meta = minetest.get_meta(pos)
local channel = meta:get_string("channel")
+ if channel == "" then return {} end
local target = get_receivers(pos, channel)
if target[1] == nil then return {} end
local d = math.random(1,#target)
@@ -133,17 +135,20 @@ pipeworks.register_tube("pipeworks:teleport_tube","Teleporting Pneumatic Tube Se
},
on_construct = function(pos)
local meta = minetest.get_meta(pos)
- meta:set_string("channel","")
- meta:set_int("can_receive",1)
- set_tube(pos, "", 1)
+ meta:set_int("can_receive", 1)
set_teleport_tube_formspec(meta, 1)
end,
on_receive_fields = function(pos,formname,fields,sender)
+ if not fields.channel then
+ return -- ignore escaping or clientside manipulation of the form
+ end
+
local meta = minetest.get_meta(pos)
local can_receive = meta:get_int("can_receive")
- if fields.channel then
- -- check for private channels
+ -- check for private channels each time before actually changing anything
+ -- to not even allow switching between can_receive states of private channels
+ if fields.channel ~= "" then
local sender_name = sender:get_player_name()
local name, mode = fields.channel:match("^([^:;]+)([:;])")
if name and mode and name ~= sender_name then
@@ -158,22 +163,39 @@ pipeworks.register_tube("pipeworks:teleport_tube","Teleporting Pneumatic Tube Se
return
end
end
- -- save channel if we set one
- meta:set_string("channel", fields.channel)
end
- -- make sure we have a channel, either the newly set one or the one from metadata
- local channel = fields.channel or meta:get_string("channel")
+ local dirty = false
+
+ -- test if a can_receive button was pressed
if fields.cr0 and can_receive ~= 0 then
can_receive = 0
meta:set_int("can_receive", can_receive)
+ dirty = true
elseif fields.cr1 and can_receive ~= 1 then
can_receive = 1
meta:set_int("can_receive", can_receive)
+ dirty = true
+ end
+
+ -- was the channel changed?
+ local channel = meta:get_string("channel")
+ if fields.channel ~= channel then
+ channel = fields.channel
+ meta:set_string("channel", channel)
+ dirty = true
end
- set_tube(pos, fields.channel, can_receive)
- set_teleport_tube_formspec(meta, can_receive)
+ -- save if we changed something, handle the empty channel while we're at it
+ if dirty then
+ if channel ~= "" then
+ set_tube(pos, channel, can_receive)
+ else
+ -- remove empty channel tubes, to not have to search through them
+ remove_tube(pos)
+ end
+ set_teleport_tube_formspec(meta, can_receive)
+ end
end,
on_destruct = function(pos)
remove_tube(pos)