diff options
-rw-r--r-- | .gitignore | 1 | ||||
-rw-r--r-- | README.md | 28 | ||||
-rwxr-xr-x | init.lua | 110 | ||||
-rw-r--r-- | settingtypes.txt | 2 |
4 files changed, 119 insertions, 22 deletions
diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..1377554 --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +*.swp diff --git a/README.md b/README.md new file mode 100644 index 0000000..fc6ffc3 --- /dev/null +++ b/README.md @@ -0,0 +1,28 @@ +# PvP Areas + +Sets an area for PvP control. + +Use safemode to make areas be safe zones; otherwise they are killzones by default. + +## Config + +* `pvp_areas.safemode` + * safemode = true --> PvP Control areas are safe zones + * default is `false`, making PvP Control areas kill zones + +* `pvp_areas.label` + * if ShadowNinja's `areas` mod is also present with HUD registration feature, this label will be displayed anywhere + a PvP Control area has been set. + +## Commands + +* `/pvp_areas` + * without arguments lists areas, if any. +* `/pvp_areas pos1` + * selects the players current position as the area minimum. +* `/pvp_areas pos2` + * selects the players current position as the area maximum. +* `/pvp_areas set` + * adds an entry using pos1 and pos2 values. +* `/pvp_areas remove n` + * removes an area entry. @@ -1,11 +1,46 @@ -- pvp_areas --- Copyright 2016 James Stevenson (everamzah) +-- Original : Copyright 2016 James Stevenson (everamzah) +-- Additional : Copyright Tai Kedzierski (DuCake) -- LGPL v2.1+ +local pvp_areas_worlddir = minetest.get_worldpath() +local pvp_areas_modname = minetest.get_current_modname() + +local hasareasmod = minetest.get_modpath("areas") + +local safemode = minetest.setting_getbool("pvp_areas.safemode") or false +local area_label = minetest.setting_get("pvp_areas.label") or "Defined area." -local pvp_areas = {} local pvp_areas_store = AreaStore() -pvp_areas_store:from_file(minetest.get_worldpath() .. "/pvp_areas_store.dat") +pvp_areas_store:from_file(pvp_areas_worlddir .. "/pvp_areas_store.dat") + +local pvp_default = minetest.is_yes(minetest.setting_getbool("pvp_areas_enable_pvp")) +minetest.log("action", "[" .. pvp_areas_modname .. "] PvP by Default: " .. tostring(pvp_default)) + +local pvp_areas_players = {} +local pvp_areas = {} + +local function update_pvp_areas() + local counter = 0 + pvp_areas = {} + while pvp_areas_store:get_area(counter) do + table.insert(pvp_areas, pvp_areas_store:get_area(counter)) + counter = counter + 1 + end +end +update_pvp_areas() + +local function save_pvp_areas() + pvp_areas_store:to_file(pvp_areas_worlddir .. "/pvp_areas_store.dat") +end + +local function areas_entity(pos,num) + if hasareasmod then + local obj = minetest.add_entity(pos, "areas:pos"..tostring(num)) + local ent = obj:get_luaentity() + ent.active = true + end +end -- Register privilege and chat command. minetest.register_privilege("pvp_areas_admin", "Can set and remove PvP areas.") @@ -17,33 +52,56 @@ minetest.register_chatcommand("pvp_areas", { func = function(name, param) local pos = vector.round(minetest.get_player_by_name(name):getpos()) if param == "pos1" then - if not pvp_areas[name] then - pvp_areas[name] = {pos1 = pos} + if not pvp_areas_players[name] then + pvp_areas_players[name] = {pos1 = pos} else - pvp_areas[name].pos1 = pos + pvp_areas_players[name].pos1 = pos end minetest.chat_send_player(name, "Position 1: " .. minetest.pos_to_string(pos)) elseif param == "pos2" then - if not pvp_areas[name] then - pvp_areas[name] = {pos2 = pos} + if not pvp_areas_players[name] then + pvp_areas_players[name] = {pos2 = pos} else - pvp_areas[name].pos2 = pos + pvp_areas_players[name].pos2 = pos end minetest.chat_send_player(name, "Position 2: " .. minetest.pos_to_string(pos)) elseif param == "set" then - if not pvp_areas[name] or not pvp_areas[name].pos1 then + if not pvp_areas_players[name] or not pvp_areas_players[name].pos1 then minetest.chat_send_player(name, "Position 1 missing, use \"/pvp_areas pos1\" to set.") - elseif not pvp_areas[name].pos2 then + elseif not pvp_areas_players[name].pos2 then minetest.chat_send_player(name, "Position 2 missing, use \"/pvp_areas pos2\" to set.") else - minetest.chat_send_player(name, "Setting.") - pvp_areas_store:insert_area(pvp_areas[name].pos1, pvp_areas[name].pos2, "pvp_areas") - pvp_areas_store:to_file(minetest.get_worldpath() .. "/pvp_areas_store.dat") + pvp_areas_store:insert_area(pvp_areas_players[name].pos1, pvp_areas_players[name].pos2, "pvp_areas", #pvp_areas) + table.insert(pvp_areas, pvp_areas_store:get_area(#pvp_areas)) + update_pvp_areas() + save_pvp_areas() + pvp_areas_players[name] = nil + minetest.chat_send_player(name, "Area set.") end - elseif param == "remove" then - minetest.chat_send_player(name, "Removing.") - else + elseif param:sub(1, 6) == "remove" then + local n = tonumber(param:sub(8, -1)) + if n and pvp_areas_store:get_area(n) then + pvp_areas_store:remove_area(n) + if pvp_areas_store:get_area(n + 1) then + -- Insert last entry in new empty (removed) slot. + local a = pvp_areas_store:get_area(#pvp_areas - 1) + pvp_areas_store:remove_area(#pvp_areas - 1) + pvp_areas_store:insert_area(a.min, a.max, "pvp_areas", n) + end + update_pvp_areas() + save_pvp_areas() + minetest.chat_send_player(name, "Removed " .. tostring(n)) + else + minetest.chat_send_player(name, "Invalid argument. You must enter a valid area identifier.") + end + elseif param ~= "" then minetest.chat_send_player(name, "Invalid usage. Type \"/help pvp_areas\" for more information.") + else + for k, v in pairs(pvp_areas) do + minetest.chat_send_player(name, k - 1 .. ": " .. + minetest.pos_to_string(v.min) .. " " .. + minetest.pos_to_string(v.max)) + end end end }) @@ -51,6 +109,14 @@ minetest.register_chatcommand("pvp_areas", { local KILL_NO = true local KILL_OK = false +local AREA_ACTIVATE = KILL_OK +local AREA_NOACTIVATE = KILL_NO + +if safemode then + AREA_ACTIVATE = KILL_NO + AREA_NOACTIVATE = KILL_OK +end + -- Register punchplayer callback. minetest.register_on_punchplayer(function(player, hitter, time_from_last_punch, tool_capabilities, dir, damage) for k, v in pairs(pvp_areas_store:get_areas_for_pos(player:getpos())) do @@ -61,15 +127,15 @@ minetest.register_on_punchplayer(function(player, hitter, time_from_last_punch, return KILL_OK end) -if areas then +if hasareasmod then if areas.registerHudHandler then local function advertise_nokillzone(pos, list) - for k, v in pairs(pvp_areas_store:get_areas_for_pos(player:getpos())) do + for k, v in pairs(pvp_areas_store:get_areas_for_pos(pos)) do if k then - list:insert( { - id = "pvp_areas:"..tostring(k), - name = k, + table.insert(list, { + id = "PvP Control Area "..tostring(k), + name = area_label, } ) return end diff --git a/settingtypes.txt b/settingtypes.txt new file mode 100644 index 0000000..d0c30d5 --- /dev/null +++ b/settingtypes.txt @@ -0,0 +1,2 @@ +# Allow PvP by default. +pvp_areas_enable_pvp (PvP by Default) bool false |