This commit is contained in:
Anthony Recascino 2016-07-30 23:59:16 -04:00
parent 8f773c0a73
commit 63254c55fc
3 changed files with 53 additions and 25 deletions

View File

@ -103,12 +103,16 @@ function factionsmod_chat.cmdhandler(playername,parameter)
if cmd == "claim" then if cmd == "claim" then
local playerfaction = factionsmod.get_factionsmod(player) local playerfaction = factionsmod.get_factionsmod(player)
if next(playerfaction) ~= nil then
factionsmod.claim(playerfaction[1],player) factionsmod.claim(playerfaction[1],player)
end
return return
end end
if cmd == "unclaim" then if cmd == "unclaim" then
local playerfaction = factionsmod.get_factionsmod(player) local playerfaction = factionsmod.get_factionsmod(player)
if next(playerfaction) ~= nil then
factionsmod.unclaim(playerfaction[1],player) factionsmod.unclaim(playerfaction[1],player)
end
return return
end end
--list all known factionsmod --list all known factionsmod

View File

@ -119,26 +119,29 @@ if next(factionsmod.get_faction_list()) ~= nil then
for k,v in pairs(factionsmod.get_faction_list()) do for k,v in pairs(factionsmod.get_faction_list()) do
--minetest.log("warning",v) --minetest.log("warning",v)
if factionsmod.data.factionsmod[v].chunk ~= nil then if factionsmod.data.factionsmod[v].chunk ~= nil then
for i =1, factionsmod.data.factionsmod[v].chunk.maxn() do for i =1, #factionsmod.data.factionsmod[v].chunk do
if factionsmod.data.factionsmod[v].chunk[i][1] == math.floor(pos.x/16) then if factionsmod.data.factionsmod[v].chunk[i][1] == math.floor(pos.x/16.0) then
if factionsmod.data.factionsmod[v].chunk[i][2] == math.floor(pos.z/16) then if factionsmod.data.factionsmod[v].chunk[i][2] == math.floor(pos.z/16.0) then
print('test')
if digger == nil then if digger == nil then
return false
end
for k2,v2 in pairs(factionsmod.get_factionsmod(digger)) do for k2,v2 in pairs(factionsmod.get_factionsmod(digger)) do
if k2 ~= nil and k2 ~= v then print(v2)
if v2 == nil or v2 ~= v then
print('not allowed')
return false
end
end
end
end
end
end
end
end
return true return true
end end
end
else
return true
end
end
end
end
end
end
end
return
end
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
-- name: set_description(name,description) -- name: set_description(name,description)
-- --
@ -261,20 +264,23 @@ end
function factionsmod.claim(name,player) function factionsmod.claim(name,player)
--if factionsmod.data.factionsmod[name].chunk ~= nil then --if factionsmod.data.factionsmod[name].chunk ~= nil then
local pos = player:getpos() local pos = player:getpos()
local is_owned = factionsmod.testifallowed(pos,nil) local is_not_owned = factionsmod.testifallowed(pos,nil)
if is_owned ~= true then if is_not_owned == true then
print(name)
print(player)
print(dump(factionsmod.data.factionsmod))
table.insert(factionsmod.data.factionsmod[name].chunk,{}) table.insert(factionsmod.data.factionsmod[name].chunk,{})
factionsmod.data.factionsmod[name].chunk[#factionsmod.data.factionsmod[name].chunk][0] = math.floor(pos.x/16.0) factionsmod.data.factionsmod[name].chunk[#factionsmod.data.factionsmod[name].chunk][1] = math.floor(pos.x/16.0)
factionsmod.data.factionsmod[name].chunk[#factionsmod.data.factionsmod[name].chunk][1] = math.floor(pos.z/16.0) factionsmod.data.factionsmod[name].chunk[#factionsmod.data.factionsmod[name].chunk][2] = math.floor(pos.z/16.0)
end end
--end --end
end end
function factionsmod.unclaim(name,player) function factionsmod.unclaim(name,player)
local pos = player:getpos() local pos = player:getpos()
local is_owned = factionsmod.testifallowed(pos,nil) local is_not_owned = factionsmod.testifallowed(pos,nil)
if is_owned then if is_not_owned == false then
for i =1, factionsmod.data.factionsmod[name].chunk.maxn() do for i =1, #factionsmod.data.factionsmod[name].chunk do
if chunk[i][0] == math.floor(pos.x/16.0) and chunk[i][1] == math.floor(pos.y/16.0) then if chunk[i][1] == math.floor(pos.x/16.0) and chunk[i][2] == math.floor(pos.z/16.0) then
table.remove(factionsmod.data.factionsmod[name].chunk,i) table.remove(factionsmod.data.factionsmod[name].chunk,i)
end end
@ -794,7 +800,8 @@ function factionsmod.load()
factionsmod.data.factionsmod[key].adminlist = value.adminlist factionsmod.data.factionsmod[key].adminlist = value.adminlist
factionsmod.data.factionsmod[key].open = value.open factionsmod.data.factionsmod[key].open = value.open
factionsmod.data.factionsmod[key].invitations = value.invitations factionsmod.data.factionsmod[key].invitations = value.invitations
factionsmod.data.factionsmod[key].chunk = value.chunk
factionsmod.data.factionsmod[key].owner = value.owner
factionsmod.data.factionsmod[key].reputation = {} factionsmod.data.factionsmod[key].reputation = {}
for repkey,repvalue in pairs(value.reputation) do for repkey,repvalue in pairs(value.reputation) do
if temp_objects[repkey] == nil then if temp_objects[repkey] == nil then
@ -827,14 +834,14 @@ function factionsmod.load()
--create special faction players --create special faction players
--factionsmod.add_faction("players") --factionsmod.add_faction("players")
minetest.register_on_dignode(function(pos,oldnode,digger) old_is_protected = minetest.is_protected
return factionsmod.testifallowed(pos,digger) function minetest.is_protected(pos,name)
local player = minetest.get_player_by_name(name)
if factionsmod.testifallowed(pos,player) ~= true then
return true
end end
) return old_is_protected(pos,name)
minetest.register_on_placenode(function(pos,oldnode,digger,nothanks,noreally,please)
return factionsmod.testifallowed(pos,digger)
end end
)
--autojoin players to faction players --autojoin players to faction players
minetest.register_on_joinplayer( minetest.register_on_joinplayer(
function(player) function(player)

17
log Normal file
View File

@ -0,0 +1,17 @@
{
testou = {
adminlist = {
just_fuck_my_shit_u = true
},
reputation = {
},
base_reputation = {
},
invitations = {
}
}
}