mirror of
https://github.com/minetest-mods/teleport-request.git
synced 2025-01-08 14:07:28 +01:00
short a bit the code
fix readme newline
This commit is contained in:
parent
6349d9b02e
commit
b5f6fa8419
64
init.lua
64
init.lua
@ -14,18 +14,17 @@ local tpr_list = {}
|
|||||||
local tphr_list = {}
|
local tphr_list = {}
|
||||||
|
|
||||||
--Teleport Request System
|
--Teleport Request System
|
||||||
local function tpr_send(name, param)
|
local function tpr_send(sender, receiver)
|
||||||
|
|
||||||
local sender = name
|
|
||||||
local receiver = param
|
|
||||||
|
|
||||||
if receiver == "" then
|
if receiver == "" then
|
||||||
minetest.chat_send_player(sender, "Usage: /tpr <Player name>")
|
minetest.chat_send_player(sender, "Usage: /tpr <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.get_player_by_name(receiver) then
|
if not minetest.get_player_by_name(receiver) then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
minetest.chat_send_player(receiver, sender ..' is requesting to teleport to you. /tpy to accept.')
|
minetest.chat_send_player(receiver, sender ..' is requesting to teleport to you. /tpy to accept.')
|
||||||
minetest.chat_send_player(sender, 'Teleport request sent! It will time out in '.. timeout_delay ..' seconds.')
|
minetest.chat_send_player(sender, 'Teleport request sent! It will time out in '.. timeout_delay ..' seconds.')
|
||||||
|
|
||||||
@ -33,25 +32,23 @@ local function tpr_send(name, param)
|
|||||||
tpr_list[receiver] = sender
|
tpr_list[receiver] = sender
|
||||||
--Teleport timeout delay
|
--Teleport timeout delay
|
||||||
minetest.after(timeout_delay, function(name)
|
minetest.after(timeout_delay, function(name)
|
||||||
if tpr_list[name] ~= nil then
|
if tpr_list[name] then
|
||||||
tpr_list[name] = nil
|
tpr_list[name] = nil
|
||||||
end
|
end
|
||||||
end, name)
|
end, sender)
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local function tphr_send(name, param)
|
local function tphr_send(sender, receiver)
|
||||||
|
|
||||||
local sender = name
|
|
||||||
local receiver = param
|
|
||||||
|
|
||||||
if receiver == "" then
|
if receiver == "" then
|
||||||
minetest.chat_send_player(sender, "Usage: /tphr <Player name>")
|
minetest.chat_send_player(sender, "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.get_player_by_name(receiver) then
|
if not minetest.get_player_by_name(receiver) then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
minetest.chat_send_player(receiver, sender ..' is requesting that you teleport to them. /tpy to accept; /tpn to deny')
|
minetest.chat_send_player(receiver, sender ..' is requesting that you teleport to them. /tpy to accept; /tpn to deny')
|
||||||
minetest.chat_send_player(sender, 'Teleport request sent! It will time out in '.. timeout_delay ..' seconds.')
|
minetest.chat_send_player(sender, 'Teleport request sent! It will time out in '.. timeout_delay ..' seconds.')
|
||||||
|
|
||||||
@ -59,19 +56,18 @@ local function tphr_send(name, param)
|
|||||||
tphr_list[receiver] = sender
|
tphr_list[receiver] = sender
|
||||||
--Teleport timeout delay
|
--Teleport timeout delay
|
||||||
minetest.after(timeout_delay, function(name)
|
minetest.after(timeout_delay, function(name)
|
||||||
if tphr_list[name] ~= nil then
|
if tphr_list[name] then
|
||||||
tphr_list[name] = nil
|
tphr_list[name] = nil
|
||||||
end
|
end
|
||||||
end, name)
|
end, sender)
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local function tpr_deny(name, param)
|
local function tpr_deny(name)
|
||||||
if tpr_list[name] ~= nil then
|
if tpr_list[name] then
|
||||||
minetest.chat_send_player(tpr_list[name], 'Teleport request denied.')
|
minetest.chat_send_player(tpr_list[name], 'Teleport request denied.')
|
||||||
tpr_list[name] = nil
|
tpr_list[name] = nil
|
||||||
end
|
end
|
||||||
if tphr_list[name] ~= nil then
|
if tphr_list[name] then
|
||||||
minetest.chat_send_player(tphr_list[name], 'Teleport request denied.')
|
minetest.chat_send_player(tphr_list[name], 'Teleport request denied.')
|
||||||
tphr_list[name] = nil
|
tphr_list[name] = nil
|
||||||
end
|
end
|
||||||
@ -85,10 +81,9 @@ local function find_free_position_near(pos)
|
|||||||
{x=0,y=0,z=1},
|
{x=0,y=0,z=1},
|
||||||
{x=0,y=0,z=-1},
|
{x=0,y=0,z=-1},
|
||||||
}
|
}
|
||||||
for _, d in ipairs(tries) do
|
for _,d in pairs(tries) do
|
||||||
local p = {x = pos.x+d.x, y = pos.y+d.y, z = pos.z+d.z}
|
local p = vector.add(pos, d)
|
||||||
local n = minetest.get_node(p)
|
if not minetest.registered_nodes[minetest.get_node(p).name].walkable then
|
||||||
if not minetest.registered_nodes[n.name].walkable then
|
|
||||||
return p, true
|
return p, true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -100,15 +95,13 @@ end
|
|||||||
local function tpr_accept(name, param)
|
local function tpr_accept(name, param)
|
||||||
|
|
||||||
--Check to prevent constant teleporting.
|
--Check to prevent constant teleporting.
|
||||||
if tpr_list[name] == nil and tphr_list[name] == nil then
|
if not tpr_list[name]
|
||||||
|
and not tphr_list[name] 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
|
||||||
end
|
end
|
||||||
|
|
||||||
local chatmsg
|
local chatmsg, source, target, name2
|
||||||
local source = nil
|
|
||||||
local target = nil
|
|
||||||
local name2
|
|
||||||
|
|
||||||
if tpr_list[name] then
|
if tpr_list[name] then
|
||||||
name2 = tpr_list[name]
|
name2 = tpr_list[name]
|
||||||
@ -127,16 +120,15 @@ local function tpr_accept(name, param)
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- Could happen if either player disconnects (or timeout); if so just abort
|
-- Could happen if either player disconnects (or timeout); if so just abort
|
||||||
if source == nil or target == nil then
|
if not source
|
||||||
|
or not target then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.chat_send_player(name2, "Request Accepted!")
|
minetest.chat_send_player(name2, "Request Accepted!")
|
||||||
minetest.chat_send_player(name, chatmsg)
|
minetest.chat_send_player(name, chatmsg)
|
||||||
|
|
||||||
local p = source:getpos()
|
target:setpos(find_free_position_near(source:getpos()))
|
||||||
local p = find_free_position_near(p)
|
|
||||||
target:setpos(p)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
--Initalize Permissions.
|
--Initalize Permissions.
|
||||||
@ -155,7 +147,6 @@ minetest.register_chatcommand("tpr", {
|
|||||||
params = "<playername> | leave playername empty to see help message",
|
params = "<playername> | leave playername empty to see help message",
|
||||||
privs = {interact=true},
|
privs = {interact=true},
|
||||||
func = tpr_send
|
func = tpr_send
|
||||||
|
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_chatcommand("tphr", {
|
minetest.register_chatcommand("tphr", {
|
||||||
@ -163,7 +154,6 @@ minetest.register_chatcommand("tphr", {
|
|||||||
params = "<playername> | leave playername empty to see help message",
|
params = "<playername> | leave playername empty to see help message",
|
||||||
privs = {interact=true},
|
privs = {interact=true},
|
||||||
func = tphr_send
|
func = tphr_send
|
||||||
|
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_chatcommand("tpy", {
|
minetest.register_chatcommand("tpy", {
|
||||||
@ -176,4 +166,4 @@ minetest.register_chatcommand("tpn", {
|
|||||||
func = tpr_deny
|
func = tpr_deny
|
||||||
})
|
})
|
||||||
|
|
||||||
print ("[Teleport Request] Teleport Request v" .. version .. " Loaded.")
|
minetest.log("info", "[Teleport Request] Teleport Request v" .. version .. " Loaded.")
|
||||||
|
Loading…
Reference in New Issue
Block a user