Added player checking for player effects

This commit is contained in:
TenPlus1 2017-02-23 10:05:21 +00:00
parent 5d1f2e2c01
commit 950fb7e7cf

@ -1,10 +1,8 @@
-- older privelage for admins to rbypass protected nodes, do not use anymore
-- instead grant admin 'protection_bypass' privelage.
-- 'delprotect' priv removed, use 'protection_bypass' instead -- 'delprotect' priv removed, use 'protection_bypass' instead
--minetest.register_privilege("delprotect","Ignore player protection") --minetest.register_privilege("delprotect","Ignore player protection")
-- get minetest.conf settings -- get minetest.conf settings
protector = {} protector = {}
protector.mod = "redo" protector.mod = "redo"
@ -15,9 +13,11 @@ protector.hurt = tonumber(minetest.setting_get("protector_hurt")) or 0
protector.spawn = tonumber(minetest.setting_get("protector_spawn") protector.spawn = tonumber(minetest.setting_get("protector_spawn")
or minetest.setting_get("protector_pvp_spawn")) or 0 or minetest.setting_get("protector_pvp_spawn")) or 0
-- get static spawn position -- get static spawn position
local statspawn = minetest.setting_get_pos("static_spawnpoint") or {x = 0, y = 2, z = 0} local statspawn = minetest.setting_get_pos("static_spawnpoint") or {x = 0, y = 2, z = 0}
-- Intllib -- Intllib
local S local S
if minetest.get_modpath("intllib") then if minetest.get_modpath("intllib") then
@ -40,18 +40,21 @@ else
end end
protector.intllib = S protector.intllib = S
-- return list of members as a table -- return list of members as a table
protector.get_member_list = function(meta) protector.get_member_list = function(meta)
return meta:get_string("members"):split(" ") return meta:get_string("members"):split(" ")
end end
-- write member list table in protector meta as string -- write member list table in protector meta as string
protector.set_member_list = function(meta, list) protector.set_member_list = function(meta, list)
meta:set_string("members", table.concat(list, " ")) meta:set_string("members", table.concat(list, " "))
end end
-- check if player name is a member -- check if player name is a member
protector.is_member = function (meta, name) protector.is_member = function (meta, name)
@ -65,6 +68,7 @@ protector.is_member = function (meta, name)
return false return false
end end
-- add player name to table as member -- add player name to table as member
protector.add_member = function(meta, name) protector.add_member = function(meta, name)
@ -79,6 +83,7 @@ protector.add_member = function(meta, name)
protector.set_member_list(meta, list) protector.set_member_list(meta, list)
end end
-- remove player name from table -- remove player name from table
protector.del_member = function(meta, name) protector.del_member = function(meta, name)
@ -95,6 +100,7 @@ protector.del_member = function(meta, name)
protector.set_member_list(meta, list) protector.set_member_list(meta, list)
end end
-- protector interface -- protector interface
protector.generate_formspec = function(meta) protector.generate_formspec = function(meta)
@ -145,6 +151,7 @@ protector.generate_formspec = function(meta)
return formspec return formspec
end end
-- check if pos is inside a protected spawn area -- check if pos is inside a protected spawn area
local function inside_spawn(pos, radius) local function inside_spawn(pos, radius)
@ -165,6 +172,7 @@ local function inside_spawn(pos, radius)
return false return false
end end
-- Infolevel: -- Infolevel:
-- 0 for no info -- 0 for no info
-- 1 for "This area is owned by <owner> !" if you can't dig -- 1 for "This area is owned by <owner> !" if you can't dig
@ -273,16 +281,15 @@ function minetest.is_protected(pos, digger)
local player = minetest.get_player_by_name(digger) local player = minetest.get_player_by_name(digger)
if player and player:is_player() then
-- hurt player if protection violated -- hurt player if protection violated
if protector.hurt > 0 if protector.hurt > 0 and player:get_hp() > 0 then
and player then
player:set_hp(player:get_hp() - protector.hurt) player:set_hp(player:get_hp() - protector.hurt)
end end
-- flip player when protection violated -- flip player when protection violated
if protector.flip if protector.flip then
and player then
-- yaw + 180° -- yaw + 180°
--local yaw = player:get_look_horizontal() + math.pi --local yaw = player:get_look_horizontal() + math.pi
local yaw = player:get_look_yaw() + math.pi local yaw = player:get_look_yaw() + math.pi
@ -312,8 +319,7 @@ function minetest.is_protected(pos, digger)
end end
-- drop tool/item if protection violated -- drop tool/item if protection violated
if protector.drop == true if protector.drop == true then
and player then
local holding = player:get_wielded_item() local holding = player:get_wielded_item()
@ -333,7 +339,7 @@ function minetest.is_protected(pos, digger)
obj:setvelocity({x = 0, y = 5, z = 0}) obj:setvelocity({x = 0, y = 5, z = 0})
end end
end) end)
end
end end
end end
@ -342,9 +348,9 @@ function minetest.is_protected(pos, digger)
-- otherwise can dig or place -- otherwise can dig or place
return protector.old_is_protected(pos, digger) return protector.old_is_protected(pos, digger)
end end
-- make sure protection block doesn't overlap another protector's area -- make sure protection block doesn't overlap another protector's area
function protector.check_overlap(itemstack, placer, pointed_thing) function protector.check_overlap(itemstack, placer, pointed_thing)
@ -378,6 +384,7 @@ function protector.check_overlap(itemstack, placer, pointed_thing)
end end
-- protection node -- protection node
minetest.register_node("protector:protect", { minetest.register_node("protector:protect", {
description = S("Protection Block"), description = S("Protection Block"),
@ -457,6 +464,7 @@ minetest.register_craft({
} }
}) })
-- protection logo -- protection logo
minetest.register_node("protector:protect2", { minetest.register_node("protector:protect2", {
description = S("Protection Logo"), description = S("Protection Logo"),
@ -537,6 +545,7 @@ minetest.register_craft({
} }
}) })
-- check formspec buttons or when name entered -- check formspec buttons or when name entered
minetest.register_on_player_receive_fields(function(player, formname, fields) minetest.register_on_player_receive_fields(function(player, formname, fields)
@ -578,6 +587,7 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
end end
end) end)
-- display entity shown when protector node is punched -- display entity shown when protector node is punched
minetest.register_entity("protector:display", { minetest.register_entity("protector:display", {
physical = false, physical = false,
@ -599,6 +609,7 @@ minetest.register_entity("protector:display", {
end, end,
}) })
-- Display-zone node, Do NOT place the display as a node, -- Display-zone node, Do NOT place the display as a node,
-- it is made to be used as an entity (see above) -- it is made to be used as an entity (see above)
@ -632,6 +643,7 @@ minetest.register_node("protector:display_node", {
drop = "", drop = "",
}) })
local path = minetest.get_modpath("protector") local path = minetest.get_modpath("protector")
dofile(path .. "/doors_chest.lua") dofile(path .. "/doors_chest.lua")
@ -640,6 +652,7 @@ dofile(path .. "/admin.lua")
dofile(path .. "/tool.lua") dofile(path .. "/tool.lua")
dofile(path .. "/lucky_block.lua") dofile(path .. "/lucky_block.lua")
-- stop mesecon pistons from pushing protectors -- stop mesecon pistons from pushing protectors
if minetest.get_modpath("mesecons_mvps") then if minetest.get_modpath("mesecons_mvps") then
mesecon.register_mvps_stopper("protector:protect") mesecon.register_mvps_stopper("protector:protect")
@ -647,4 +660,5 @@ if minetest.get_modpath("mesecons_mvps") then
mesecon.register_mvps_stopper("protector:chest") mesecon.register_mvps_stopper("protector:chest")
end end
print (S("[MOD] Protector Redo loaded")) print (S("[MOD] Protector Redo loaded"))