Restricted scope of variables

This commit is contained in:
Craig Robbins 2014-07-30 12:30:37 +10:00
parent 2ae3d6932f
commit 05018b636a

@ -1,14 +1,16 @@
--Configuration values: --Configuration values:
--Use these to customize this mod --Use these to customize this mod
timeout_delay = 60 local timeout_delay = 60
--DO NOT CHANGE: --DO NOT CHANGE:
value_carryover = nil local value_carryover = nil
value_carryover2 = nil local value_carryover2 = nil
local version = "0.1a"
print ("[Teleport Request] Teleport Request v0.1a Loaded.") local tpr_list = {}
local tphr_list = {}
--Teleport Request System --Teleport Request System
@ -42,20 +44,17 @@ end
local function tphr_send(name, param) local function tphr_send(name, param)
--Register variables local sender2 = name
local receiver2 = param
local value_carryover2 = param
sender2 = name
receiver2 = param
value_carryover2 = param
--Check for empty parameter --Check for empty parameter
if receiver2 == "" then if receiver2 == "" then
minetest.chat_send_player(sender2, "Usage: /tphr <Player name>") minetest.chat_send_player(sender2, "Usage: /tphr <Player name>")
return return
end end
--If paremeter is valid, Send teleport message and set the table. --If paremeter is valid, Send teleport message and set the table.
if minetest.env:get_player_by_name(receiver2) then if minetest.env:get_player_by_name(receiver2) then
minetest.chat_send_player(receiver2, sender2 ..' is requesting that you teleport to them. /tpy to accept.') minetest.chat_send_player(receiver2, sender2 ..' is requesting that you teleport to them. /tpy to accept.')
minetest.chat_send_player(sender2, 'Teleport request sent! It will time out in '.. timeout_delay ..' seconds.') minetest.chat_send_player(sender2, 'Teleport request sent! It will time out in '.. timeout_delay ..' seconds.')
@ -72,23 +71,15 @@ end
--Reset after configured delay. --Reset after configured delay.
function reset_request(name) function reset_request(name)
--A check to prevent crashing
if tpr_list[value_carryover] ~= nil then if tpr_list[value_carryover] ~= nil then
tpr_list[value_carryover] = nil tpr_list[value_carryover] = nil
end end
end end
function reset_request2(name) function reset_request2(name)
--A check to prevent crashing
if tphr_list[value_carryover2] ~= nil then if tphr_list[value_carryover2] ~= nil then
tphr_list[value_carryover2] = nil tphr_list[value_carryover2] = nil
end end
end end
function tpr_deny(name) function tpr_deny(name)
@ -103,19 +94,14 @@ function tpr_deny(name)
minetest.chat_send_player(sender2, 'Teleport request denied :C') minetest.chat_send_player(sender2, 'Teleport request denied :C')
end end
end end
--Teleport Accept Systems --Teleport Accept Systems
local function tpr_accept(name, param) local function tpr_accept(name, param)
--Register name variables. local receiver = name
receiver = name
sender = tpr_list[name]
receiver = name
sender2 = tphr_list[name]
--Check to prevent constant teleporting. --Check to prevent constant teleporting.
if tpr_list[name] == nil and tphr_list[name] == nil then if tpr_list[name] == nil and tphr_list[name] == nil then
minetest.chat_send_player(name, "Usage: /tpy allows you to accept teleport requests sent to you by other players") minetest.chat_send_player(name, "Usage: /tpy allows you to accept teleport requests sent to you by other players")
return return
@ -125,6 +111,7 @@ local function tpr_accept(name, param)
--Check to ensure name is valid, then send appropriate chat messages --Check to ensure name is valid, then send appropriate chat messages
if tpr_list[name] then if tpr_list[name] then
local sender = tpr_list[name]
minetest.chat_send_player(tpr_list[receiver], "Request Accepted!") minetest.chat_send_player(tpr_list[receiver], "Request Accepted!")
minetest.chat_send_player(receiver, sender..' is teleporting to you.') minetest.chat_send_player(receiver, sender..' is teleporting to you.')
@ -171,8 +158,9 @@ local function tpr_accept(name, param)
--Teleport Here accepting system --Teleport Here accepting system
if tphr_list[name] then if tphr_list[name] then
local sender = tphr_list[name]
minetest.chat_send_player(tphr_list[receiver], "Request Accepted!") minetest.chat_send_player(tphr_list[receiver], "Request Accepted!")
minetest.chat_send_player(receiver, 'you are teleporting to '..sender2..'.') minetest.chat_send_player(receiver, 'you are teleporting to '..sender..'.')
--Code here copied from Celeron-55's /teleport command. Thanks Celeron! --Code here copied from Celeron-55's /teleport command. Thanks Celeron!
@ -195,7 +183,7 @@ local function tpr_accept(name, param)
--Get names from variables and set position. Then actually teleport the player. --Get names from variables and set position. Then actually teleport the player.
local requester = minetest.env:get_player_by_name(sender2) local requester = minetest.env:get_player_by_name(sender)
local accepter = minetest.env:get_player_by_name(name) local accepter = minetest.env:get_player_by_name(name)
-- Could happen if either player disconnects; if so just abort -- Could happen if either player disconnects; if so just abort
@ -209,18 +197,12 @@ local function tpr_accept(name, param)
accepter:setpos(p) accepter:setpos(p)
-- Set name values to nil to prevent re-teleporting on the same request. -- Set name values to nil to prevent re-teleporting on the same request.
tphr_list[name] = nil tphr_list[name] = nil
return return
end end
end end
--Initalize Table.
tpr_list = {}
tphr_list = {}
--Initalize Permissions. --Initalize Permissions.
minetest.register_privilege("tpr_admin", { minetest.register_privilege("tpr_admin", {
@ -255,3 +237,5 @@ minetest.register_chatcommand("tpn", {
description = "Deny teleport requests from another player", description = "Deny teleport requests from another player",
func = tpr_deny func = tpr_deny
}) })
print ("[Teleport Request] Teleport Request v" .. version .. " Loaded.")