Try on claiming

This commit is contained in:
Anthony Recascino 2016-07-30 16:33:10 -04:00
parent 1b1465e1fb
commit 41c8a64394
2 changed files with 61 additions and 17 deletions

View File

@ -102,11 +102,13 @@ function factionsmod_chat.cmdhandler(playername,parameter)
end end
if cmd == "claim" then if cmd == "claim" then
local playerfactionsmod = factionsmod.get_factionsmod(player) local playerfaction = factionsmod.get_factionsmod(player)
factionsmod.claim(playerfaction[1],player)
return return
end end
if cmd == "unclaim" then if cmd == "unclaim" then
local playerfaction = factionsmod.get_factionsmod(player)
factionsmod.unclaim(playerfaction[1],player)
return return
end end
--list all known factionsmod --list all known factionsmod
@ -454,4 +456,4 @@ function factionsmod_chat.show_help(playername)
MSG("\t\t/factionsmod set_free <factionname> <value> -> set faction free to join") MSG("\t\t/factionsmod set_free <factionname> <value> -> set faction free to join")
MSG("\t\t/factionsmod admin <factionname> <playername> <value> -> make player admin of faction") MSG("\t\t/factionsmod admin <factionname> <playername> <value> -> make player admin of faction")
MSG("\t\t/factionsmod description <factionname> <text> -> set description for faction") MSG("\t\t/factionsmod description <factionname> <text> -> set description for faction")
end end

View File

@ -54,8 +54,7 @@ function factionsmod.add_faction(name)
factionsmod.data.factionsmod[name].adminlist = {} factionsmod.data.factionsmod[name].adminlist = {}
factionsmod.data.factionsmod[name].invitations = {} factionsmod.data.factionsmod[name].invitations = {}
factionsmod.data.factionsmod[name].owner = "" factionsmod.data.factionsmod[name].owner = ""
factionsmod.data.factionsmod[name].chunk = {} factionsmod.data.factionsmod[name].chunk = {}
factionsmod.dynamic_data.membertable[name] = {} factionsmod.dynamic_data.membertable[name] = {}
factionsmod.save() factionsmod.save()
@ -115,6 +114,31 @@ function factionsmod.get_base_reputation(faction1,faction2)
return 0 return 0
end end
function factionsmod.testifallowed(pos,digger)
if next(factionsmod.get_faction_list()) ~= nil then
for k,v in pairs(factionsmod.get_faction_list()) do
--minetest.log("warning",v)
if factionsmod.data.factionsmod[v].chunk ~= nil then
for i =1, factionsmod.data.factionsmod[v].chunk.maxn() do
if factionsmod.data.factionsmod[v].chunk[i][1] == math.floor(pos.x/16) then
if factionsmod.data.factionsmod[v].chunk[i][2] == math.floor(pos.z/16) then
if digger == nil then
for k2,v2 in pairs(factionsmod.get_factionsmod(digger)) do
if k2 ~= nil and k2 ~= v then
return true
end
end
else
return true
end
end
end
end
end
end
end
return
end
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
-- name: set_description(name,description) -- name: set_description(name,description)
-- --
@ -234,9 +258,30 @@ end
--! --!
--! @return true/false (succesfully added faction or not) --! @return true/false (succesfully added faction or not)
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
function factionsmod.claim() function factionsmod.claim(name,player)
--if factionsmod.data.factionsmod[name].chunk ~= nil then
local pos = player:getpos()
local is_owned = factionsmod.testifallowed(pos,nil)
if is_owned ~= true then
table.insert(factionsmod.data.factionsmod[name].chunk[table.getn(chunk) + 1],{})
factionsmod.data.factionsmod[name].chunk[table.getn(chunk)][0] = math.floor(pos.x/16.0)
factionsmod.data.factionsmod[name].chunk[table.getn(chunk)][1] = math.floor(pos.z/16.0)
end
--end
end end
function factionsmod.unclaim() function factionsmod.unclaim(name,player)
local pos = player:getpos()
local is_owned = factionsmod.testifallowed(pos,nil)
if is_owned then
for i =1, factionsmod.data.factionsmod[name].chunk.maxn() do
if chunk[i][0] == math.floor(pos.x/16.0) and chunk[i][1] == math.floor(pos.y/16.0) then
table.remove(factionsmod.data.factionsmod[name].chunk,i)
end
end
end
end end
function factionsmod.member_add(name, object) function factionsmod.member_add(name, object)
local new_entry = {} local new_entry = {}
@ -779,19 +824,16 @@ function factionsmod.load()
minetest.log("error","MOD factionsmod: unable to save factionsmod world specific data!: " .. error) minetest.log("error","MOD factionsmod: unable to save factionsmod world specific data!: " .. error)
end end
end end
--create special faction players --create special faction players
--factionsmod.add_faction("players") --factionsmod.add_faction("players")
minetest.register_on_dignode(function(pos,oldnode,digger) minetest.register_on_dignode(function(pos,oldnode,digger)
if next(factionsmod.data.factionsmod) ~= nil then return factionsmod.testifallowed(pos,digger)
for k,v in pairs(factionsmod.data.factionsmod) do end
for i =1, v.chunk.maxn() do )
if v.chunk[i][1] == math.floor(pos.x/16) then minetest.register_on_placenode(function(pos,oldnode,digger,nothanks,noreally,please)
end return factionsmod.testifallowed(pos,digger)
end
end
end end
end
) )
--autojoin players to faction players --autojoin players to faction players
minetest.register_on_joinplayer( minetest.register_on_joinplayer(
@ -801,4 +843,4 @@ function factionsmod.load()
end end
end end
) )
end end