Merge pull request #12 from Panquesito7/master

Complete 1 task from TODO list
This commit is contained in:
ChaosWormz 2019-07-29 10:08:56 +03:00 committed by GitHub
commit 202ce65389
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 150 additions and 70 deletions

@ -76,15 +76,16 @@ LGPL-2.1 for code, CC-BY-SA-4.0 for [media](https://github.com/ChaosWormz/telepo
## Contributors:
- [RobbieF](https://minetest.tv) | [GitHub](https://github.com/Cat5TV)
- [DonBatman](https://github.com/donbatman)
- [NathanS21](http://nathansalapat.com/)
- [NathanS21](http://nathansalapat.com/) | [GitHub](https://github.com/NathanSalapat)
- [ChaosWormz](https://github.com/ChaosWormz)
- [Panquesito7](https://github.com/Panquesito7)
- [coil0](https://github.com/coil0)
- Traxie21, the original creator of this mod (however, he/she does not have a GitHub account anymore).
All those who contributed to the original mod (please see `init.lua`).
## Installation
- Unzip the archive, rename the folder to "tpr" (**without the quotes**) and
- Unzip the archive, rename the folder to tpr and
place it in ..minetest/mods/
- GNU/Linux: If you use a system-wide installation place
@ -101,6 +102,5 @@ https://wiki.minetest.net/Installing_Mods
- Add limitations to /tpc which only allow a user to teleport X number of blocks. Prevents users from teleporting to the edge of the world.
- Assess value in changing all tpr-based chat commands to one global command such as /tp to reduce the chance of confusion between tps_admin and the original mod (and also make it so people don't have to remember so many commands).
- Create a better sound effect for teleport and apply it to all teleport methods (not just /tpc)
- Create a new function for the actual set_pos() to remove all the redundant code each time the player is moved and the sound played.
- Rewrite to place all chat commands into one single command much like how /teleport works.
- Make evade respect land: no teleporting inside land, but instead make sure player is standing on surface or in water.

@ -27,13 +27,10 @@ local S, NS = dofile(MP.."/intllib.lua")
timeout_delay = 60
version = "1.5"
map_size = 30912
function can_teleport(to)
return to.x < map_size and to.x > -map_size and to.y < map_size and to.y > -map_size and to.z < map_size and to.z > -map_size
end
-- Enable teleporting immediately to the player with "tp_admin" privilege.
enable_immediate_teleport = true
-- Enable tpp command
enable_tpp_command = false
local chatmsg, source, target, name2, target_coords, pos
-- Set the values of the positions of your places, players will be able to teleport to them (no matter if it is protected, or not).
available_places = {
@ -41,6 +38,9 @@ available_places = {
shop = {x = 0, y = 0, z = 0}, -- Set coordinates of the shop here.
}
-- Enable tpp command
enable_tpp_command = false
-- Register privileges
minetest.register_privilege("tp", {
description = S("Let players teleport to other players (request will be sent)"),

144
init.lua

@ -38,7 +38,40 @@ dofile(MP.."/config.lua")
local tpr_list = {}
local tphr_list = {}
local function find_free_position_near(pos)
local map_size = 30912
local function can_teleport(to)
return to.x < map_size and to.x > -map_size and to.y < map_size and to.y > -map_size and to.z < map_size and to.z > -map_size
end
-- Teleport player to a player (used in "/tpr" and in "/tphr" command).
function tpr_teleport_player()
local target_coords = source:get_pos()
local target_sound = target:get_pos()
target:set_pos(find_free_position_near(target_coords))
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
minetest.sound_play("whoosh", {pos = target_sound, gain = 0.5, max_hear_distance = 10})
--parti2(target_coords)
end
-- TPC & TPJ
function tpc_teleport_player(player)
local pname = minetest.get_player_by_name(player)
minetest.sound_play("whoosh", {pos = pname:get_pos(), gain = 0.5, max_hear_distance = 10})
pname:set_pos(find_free_position_near(target_coords))
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
--parti2(target_coords)
end
-- TPP
function tpp_teleport_player(player)
local pname = minetest.get_player_by_name(player)
minetest.sound_play("whoosh", {pos = pname:get_pos(), gain = 0.5, max_hear_distance = 10})
pname:set_pos(find_free_position_near(pos))
minetest.sound_play("whoosh", {pos = pos, gain = 0.5, max_hear_distance = 10})
--parti2(target_coords)
end
function find_free_position_near(pos)
local tries = {
{x=1,y=0,z=0},
{x=-1,y=0,z=0},
@ -54,7 +87,7 @@ local function find_free_position_near(pos)
return pos, false
end
local function parti(pos)
function parti(pos)
minetest.add_particlespawner(50, 0.4,
{x=pos.x + 0.5, y=pos.y, z=pos.z + 0.5}, {x=pos.x - 0.5, y=pos.y, z=pos.z - 0.5},
{x=0, y=5, z=0}, {x=0, y=0, z=0},
@ -65,7 +98,7 @@ local function parti(pos)
"tps_portal_parti.png")
end
local function parti2(pos)
function parti2(pos)
minetest.add_particlespawner(50, 0.4,
{x=pos.x + 0.5, y=pos.y + 10, z=pos.z + 0.5}, {x=pos.x - 0.5, y=pos.y, z=pos.z - 0.5},
{x=0, y=-5, z=0}, {x=0, y=0, z=0},
@ -80,21 +113,32 @@ end
function clear_tpr_list(name)
if tpr_list[name] then
tpr_list[name] = nil
return
end
end
function clear_tphr_list(name)
if tphr_list[name] then
tphr_list[name] = nil
return
end
end
-- Clear requests when the player leaves
minetest.register_on_leaveplayer(function(name)
if tpr_list[name] then
tpr_list[name] = nil
return
end
if tphr_list[name] then
tphr_list[name] = nil
return
end
end)
function tpr_send(sender, receiver)
if minetest.check_player_privs(sender, {tp_admin = true}) then
-- Write name values to list and clear old values.
tpr_list[receiver] = sender
-- Teleport timeout delay
minetest.after(timeout_delay, clear_tpr_list, receiver)
if minetest.check_player_privs(sender, {tp_admin = true}) and enable_immediate_teleport then
if receiver == "" then
minetest.chat_send_player(sender, S("Usage: /tpr <Player name>"))
return
@ -103,6 +147,7 @@ function tpr_send(sender, receiver)
minetest.chat_send_player(sender, S("There is no player by that name. Keep in mind this is case-sensitive, and the player must be online"))
return
end
tpr_list[receiver] = sender
tpr_accept(receiver)
minetest.chat_send_player(sender, S("You are teleporting to @1.", receiver))
return
@ -122,19 +167,20 @@ function tpr_send(sender, receiver)
minetest.chat_send_player(sender, S("Teleport request sent! It will timeout in @1 seconds", timeout_delay))
-- Write name values to list and clear old values.
if not minetest.check_player_privs(sender, {tp_admin = true}) then
tpr_list[receiver] = sender
-- Teleport timeout delay
minetest.after(timeout_delay, clear_tpr_list, receiver)
minetest.after(timeout_delay, function(name)
if tpr_list[name] then
tpr_list[name] = nil
minetest.chat_send_player(sender, S("Request timed-out."))
minetest.chat_send_player(receiver, S("Request timed-out."))
return
end
end, receiver)
end
function tphr_send(sender, receiver)
if minetest.check_player_privs(sender, {tp_admin = true}) then
-- Write name values to list and clear old values.
tphr_list[receiver] = sender
-- Teleport timeout delay
minetest.after(timeout_delay, clear_tphr_list, receiver)
if minetest.check_player_privs(sender, {tp_admin = true}) and enable_immediate_teleport then
if receiver == "" then
minetest.chat_send_player(sender, S("Usage: /tphr <Player name>"))
return
@ -143,6 +189,7 @@ function tphr_send(sender, receiver)
minetest.chat_send_player(sender, S("There is no player by that name. Keep in mind this is case-sensitive, and the player must be online"))
return
end
tphr_list[receiver] = sender
tpr_accept(receiver)
minetest.chat_send_player(sender, S("@1 is teleporting to you.", receiver))
return
@ -158,14 +205,19 @@ function tphr_send(sender, receiver)
end
minetest.chat_send_player(receiver, S("@1 is requesting that you teleport to them. /tpy to accept; /tpn to deny", sender))
minetest.chat_send_player(sender, S("Teleport request sent! It will timeout in @1 seconds ", timeout_delay))
minetest.chat_send_player(sender, S("Teleport request sent! It will timeout in @1 seconds", timeout_delay))
-- Write name values to list and clear old values.
if not minetest.check_player_privs(sender, {tp_admin = true}) then
tphr_list[receiver] = sender
-- Teleport timeout delay
minetest.after(timeout_delay, clear_tphr_list, receiver)
minetest.after(timeout_delay, function(name)
if tphr_list[name] then
tphr_list[name] = nil
minetest.chat_send_player(sender, S("Request timed-out."))
minetest.chat_send_player(receiver, S("Request timed-out."))
return
end
end, receiver)
end
function tpc_send(player, coordinates)
@ -184,7 +236,7 @@ function tpc_send(player, coordinates)
return nil
end
local target_coords = {x=posx, y=posy, z=posz}
target_coords = {x=posx, y=posy, z=posz}
if can_teleport(target_coords) == false then
minetest.chat_send_player(player, S("You cannot teleport to a location outside the map!"))
@ -195,11 +247,8 @@ function tpc_send(player, coordinates)
-- In future release we'll actually query the player who owns the area, if they're online, and ask for their permission.
-- Admin user (priv "tp_admin") overrides all protection
if minetest.check_player_privs(pname, {tp_admin=true}) then
tpc_teleport_player(player)
minetest.chat_send_player(player, S("Teleporting to: @1, @2, @3", posx, posy, posz))
minetest.sound_play("whoosh", {pos = pname:get_pos(), gain = 0.5, max_hear_distance = 10})
pname:set_pos(find_free_position_near(target_coords))
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
--parti2(target_coords)
else
if minetest.check_player_privs(pname, {tp_tpc = true}) then
local protected = minetest.is_protected(target_coords,pname)
@ -210,11 +259,8 @@ function tpc_send(player, coordinates)
return
end
end
minetest.sound_play("whoosh", {pos = pname:get_pos(), gain = 0.5, max_hear_distance = 10})
tpc_teleport_player(player)
minetest.chat_send_player(player, S("Teleporting to: @1, @2, @3", posx, posy, posz))
pname:set_pos(find_free_position_near(target_coords))
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
--parti2(target_coords)
else
minetest.chat_send_player(player, S("Error: You do not have permission to teleport to coordinates."))
return
@ -224,12 +270,18 @@ end
function tpr_deny(name)
if tpr_list[name] then
minetest.chat_send_player(tpr_list[name], S("Teleport request denied."))
name2 = tpr_list[name]
minetest.chat_send_player(name2, S("Teleport request denied."))
minetest.chat_send_player(name, S("You denied the request @1 sent you.", name2))
tpr_list[name] = nil
end
if tphr_list[name] then
minetest.chat_send_player(tphr_list[name], S("Teleport request denied."))
elseif tphr_list[name] then
name2 = tphr_list[name]
minetest.chat_send_player(name2, S("Teleport request denied."))
minetest.chat_send_player(name, S("You denied the request @1 sent you.", name2))
tphr_list[name] = nil
else
minetest.chat_send_player(name, S("Usage: /tpn allows you to deny teleport requests sent to you by other players."))
return
end
end
@ -242,8 +294,6 @@ function tpr_accept(name, param)
return
end
local chatmsg, source, target, name2
if tpr_list[name] then
name2 = tpr_list[name]
source = minetest.get_player_by_name(name)
@ -263,18 +313,13 @@ function tpr_accept(name, param)
-- Could happen if either player disconnects (or timeout); if so just abort
if not source
or not target then
minetest.chat_send_player(name, S("@1 just disconnected/left (by timeout).", name2))
return
end
minetest.chat_send_player(name2, S("Request Accepted!"))
minetest.chat_send_player(name, chatmsg)
local target_coords = source:get_pos()
local target_sound = target:get_pos()
target:set_pos(find_free_position_near(target_coords))
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
minetest.sound_play("whoosh", {pos = target_sound, gain = 0.5, max_hear_distance = 10})
--parti2(target_coords)
tpr_teleport_player()
end
-- Teleport Jump - Relative Position Teleportation by number of nodes
@ -293,11 +338,11 @@ function tpj(player, param)
end
if not tonumber(args[2]) then
return false, "Not a Number!"
return false, S("Not a number!")
end
-- Initially generate the target coords from the player's current position (since it's relative) and then perform the math.
local target_coords = minetest.get_player_by_name(player):get_pos()
target_coords = minetest.get_player_by_name(player):get_pos()
if args[1] == "x" then
target_coords["x"] = target_coords["x"] + tonumber(args[2])
elseif args[1] == "y" then
@ -312,10 +357,7 @@ function tpj(player, param)
minetest.chat_send_player(player, S("You cannot teleport to a location outside the map!"))
return
end
minetest.sound_play("whoosh", {pos = pname:get_pos(), gain = 0.5, max_hear_distance = 10})
pname:set_pos(find_free_position_near(target_coords))
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
--parti2(target_coords)
tpc_teleport_player(player)
end
-- Evade
@ -338,7 +380,7 @@ function tpe(player)
distance = isnegative .. math.random(mindistance,maxdistance) -- the distance to jump
axis = options[math.random(3)]
local command = axis .. " " .. distance
tpj(player,command)
tpj(player, command)
end
)
iteration = iteration + 0.5
@ -358,6 +400,7 @@ if enable_tpp_command then
-- Show the available places to the player (taken from shivajiva101's POI mod, thanks!).
if param == "" then
local places = {}
if not available_places then available_places = {} end
for key, value in pairs(available_places) do
table.insert(places, key)
end
@ -366,14 +409,11 @@ if enable_tpp_command then
end
table.insert(places, S("Usage: /tpp <place>"))
return true, table.concat(places, "\n")
-- Teleport player to the specified place (taken from shivajiva101's POI mod, thanks!).
elseif available_places[param] then
minetest.sound_play("whoosh", {pos = pname:get_pos(), gain = 0.5, max_hear_distance = 10})
local pos = {x = available_places[param].x, y = available_places[param].y, z = available_places[param].z}
pname:set_pos(pos)
pos = {x = available_places[param].x, y = available_places[param].y, z = available_places[param].z}
tpp_teleport_player(player)
minetest.chat_send_player(player, S("Teleporting to @1.", param))
minetest.sound_play("whoosh", {pos = pos, gain = 0.5, max_hear_distance = 10})
-- Check if the place exists.
elseif not available_places[param] then
minetest.chat_send_player(player, S("There is no place by that name. Keep in mind this is case-sensitive."))

@ -48,6 +48,10 @@ msgstr "@1 esta pidiendo teletransportarse a ti. /tpy para aceptar"
msgid "Teleport request sent! It will timeout in @1 seconds"
msgstr "¡Solicitud enviada! Se agotara en @1 segundos"
#: init.lua
msgid "Request timed-out."
msgstr "La solicitud enviada expiró."
#: init.lua:147
msgid "@1 is teleporting to you."
msgstr "@1 se esta teletransportando a ti."
@ -66,7 +70,7 @@ msgstr "Uso: /tpc <x, y, z>"
#: init.lua:194
msgid "You cannot teleport to a location outside the map!"
msgstr "No puedes teletransportarte afuera del mundo!"
msgstr "¡No puedes teletransportarte afuera del mundo!"
#: init.lua:204
msgid "Teleporting to: @1, @2, @3"
@ -84,13 +88,25 @@ msgstr "Error: No tienes permiso para teletransportarte a esas coordenadas."
msgid "Teleport request denied."
msgstr "Solicitud denegada."
#: init.lua
msgid "You denied the request @1 sent you."
msgstr "Tú denegaste la solicitud de teletransporte que @1 te mando."
#: init.lua
msgid "Usage: /tpn allows you to deny teleport requests sent to you by other players."
msgstr "Uso: /tpn te permite denegar solicitudes enviadas para ti de otros jugadores."
#: init.lua:278
msgid "Usage: /tpy allows you to accept teleport requests sent to you by other players"
msgstr "Uso: /tpy te permite aceptar solicitudes enviadas para ti de otros jugadores"
#: init.lua
msgid "@1 just disconnected/left (by timeout)."
msgstr "@1 se desconecto/fue."
#: init.lua:317
msgid "Request Accepted!"
msgstr "Solicitud aceptada!"
msgstr "¡Solicitud aceptada!"
#: init.lua:330
msgid "Usage: <x|y|z> <number>"
@ -100,6 +116,10 @@ msgstr "Uso: <x|y|z> <numero>"
msgid "Not a valid axis. Valid options are X, Y or Z"
msgstr "Eje invalido. Opciones validas son x, y, o z"
#: init.lua
msgid "Not a number!"
msgstr "¡No un número!"
#: init.lua:367
msgid "EVADE!"
msgstr "¡EVADIR!"

@ -48,6 +48,10 @@ msgstr ""
msgid "Teleport request sent! It will timeout in @1 seconds"
msgstr ""
#: init.lua
msgid "Request timed-out."
msgstr ""
#: init.lua:147
msgid "@1 is teleporting to you."
msgstr ""
@ -84,10 +88,22 @@ msgstr ""
msgid "Teleport request denied."
msgstr ""
#: init.lua
msgid "You denied the request @1 sent you."
msgstr ""
#: init.lua
msgid "Usage: /tpn allows you to deny teleport requests sent to you by other players."
msgstr ""
#: init.lua:278
msgid "Usage: /tpy allows you to accept teleport requests sent to you by other players"
msgstr ""
#: init.lua
msgid "@1 just disconnected/left (by timeout)."
msgstr ""
#: init.lua:317
msgid "Request Accepted!"
msgstr ""
@ -100,6 +116,10 @@ msgstr ""
msgid "Not a valid axis. Valid options are X, Y or Z"
msgstr ""
#: init.lua
msgid "Not a number!"
msgstr ""
#: init.lua:367
msgid "EVADE!"
msgstr ""

@ -1,3 +1,3 @@
name = tpr
optional_depends = areas, intllib
description = Allows players to send a request to other players to teleport to them.
description = Allows players to send a request to other players to teleport to them, and do much more.