forked from mtcontrib/factions
Code clean up and bug fix.
This commit is contained in:
parent
b52f1c6760
commit
663ad93e81
@ -425,7 +425,7 @@ factions.register_command("rank_privileges", {
|
|||||||
end
|
end
|
||||||
},false)
|
},false)
|
||||||
|
|
||||||
if factions.faction_diplomacy then
|
if factions_config.faction_diplomacy then
|
||||||
factions.register_command("send_alliance", {
|
factions.register_command("send_alliance", {
|
||||||
description = "Send an alliance request to another faction.",
|
description = "Send an alliance request to another faction.",
|
||||||
global_privileges = {"faction_user"},
|
global_privileges = {"faction_user"},
|
||||||
@ -704,7 +704,7 @@ factions.register_command("who", {
|
|||||||
end
|
end
|
||||||
},false)
|
},false)
|
||||||
|
|
||||||
local parcel_size_center = factions.parcel_size / 2
|
local parcel_size_center = factions_config.parcel_size / 2
|
||||||
|
|
||||||
factions.register_command("showparcel", {
|
factions.register_command("showparcel", {
|
||||||
description = "Shows parcel for six seconds.",
|
description = "Shows parcel for six seconds.",
|
||||||
@ -718,7 +718,7 @@ factions.register_command("showparcel", {
|
|||||||
local pscx = parcel_size_center
|
local pscx = parcel_size_center
|
||||||
local pscy = parcel_size_center
|
local pscy = parcel_size_center
|
||||||
local pscz = parcel_size_center
|
local pscz = parcel_size_center
|
||||||
local fps = factions.parcel_size
|
local fps = factions_config.parcel_size
|
||||||
|
|
||||||
if pos.x < 0 then
|
if pos.x < 0 then
|
||||||
pscx = -pscx
|
pscx = -pscx
|
||||||
|
96
factions.lua
96
factions.lua
@ -12,38 +12,12 @@ factions.players = {}
|
|||||||
|
|
||||||
|
|
||||||
factions.factions = {}
|
factions.factions = {}
|
||||||
--- settings
|
|
||||||
factions.protection_max_depth = factions_config.protection_max_depth
|
|
||||||
factions.protection_max_height = factions_config.protection_max_height
|
|
||||||
factions.power_per_parcel = factions_config.power_per_parcel
|
|
||||||
factions.power_per_death = factions_config.power_per_death
|
|
||||||
factions.power_per_tick = factions_config.power_per_tick
|
|
||||||
factions.tick_time = factions_config.tick_time
|
|
||||||
factions.power_per_attack = factions_config.power_per_attack
|
|
||||||
factions.faction_name_max_length = factions_config.faction_name_max_length
|
|
||||||
factions.rank_name_max_length = factions_config.rank_name_max_length
|
|
||||||
factions.maximum_faction_inactivity = factions_config.maximum_faction_inactivity
|
|
||||||
factions.maximum_parcelless_faction_time = factions_config.maximum_parcelless_faction_time
|
|
||||||
factions.attack_parcel = factions_config.attack_parcel
|
|
||||||
factions.faction_diplomacy = factions_config.faction_diplomacy
|
|
||||||
factions.power_per_player = factions_config.power_per_player
|
|
||||||
factions.powermax_per_player = factions_config.powermax_per_player
|
|
||||||
factions.protection_depth_height_limit = factions_config.protection_depth_height_limit
|
|
||||||
factions.enable_power_per_player = factions_config.enable_power_per_player
|
|
||||||
factions.power = factions_config.power
|
|
||||||
factions.maxpower = factions_config.maxpower
|
|
||||||
factions.attack_parcel = factions_config.attack_parcel
|
|
||||||
factions.parcel_size = factions_config.parcel_size
|
|
||||||
factions.protection_style = factions_config.protection_style
|
|
||||||
|
|
||||||
-- clear mem.
|
|
||||||
factions_config = nil
|
|
||||||
|
|
||||||
---------------------
|
---------------------
|
||||||
--! @brief returns whether a faction can be created or not (allows for implementation of blacklists and the like)
|
--! @brief returns whether a faction can be created or not (allows for implementation of blacklists and the like)
|
||||||
--! @param name String containing the faction's name
|
--! @param name String containing the faction's name
|
||||||
factions.can_create_faction = function(name)
|
factions.can_create_faction = function(name)
|
||||||
if #name > factions.faction_name_max_length then
|
if #name > factions_config.faction_name_max_length then
|
||||||
return false
|
return false
|
||||||
elseif factions.factions[name] then
|
elseif factions.factions[name] then
|
||||||
return false
|
return false
|
||||||
@ -78,16 +52,16 @@ factions.Faction.__index = factions.Faction
|
|||||||
|
|
||||||
factions.permissions = {"disband", "claim", "playerslist", "build", "description", "ranks", "spawn", "promote"}
|
factions.permissions = {"disband", "claim", "playerslist", "build", "description", "ranks", "spawn", "promote"}
|
||||||
|
|
||||||
if factions.faction_diplomacy then
|
if factions_config.faction_diplomacy then
|
||||||
table.insert(factions.permissions,"diplomacy")
|
table.insert(factions.permissions,"diplomacy")
|
||||||
end
|
end
|
||||||
|
|
||||||
function factions.Faction:new(faction)
|
function factions.Faction:new(faction)
|
||||||
faction = {
|
faction = {
|
||||||
--! @brief power of a faction (needed for parcel claiming)
|
--! @brief power of a faction (needed for parcel claiming)
|
||||||
power = factions.power,
|
power = factions_config.power,
|
||||||
--! @brief maximum power of a faction
|
--! @brief maximum power of a faction
|
||||||
maxpower = factions.maxpower,
|
maxpower = factions_config.maxpower,
|
||||||
--! @brief power currently in use
|
--! @brief power currently in use
|
||||||
usedpower = 0.,
|
usedpower = 0.,
|
||||||
--! @brief list of player names
|
--! @brief list of player names
|
||||||
@ -218,7 +192,7 @@ function factions.Faction.add_player(self, player, rank)
|
|||||||
self.players[player] = rank or self.default_rank
|
self.players[player] = rank or self.default_rank
|
||||||
factions.players[player] = self.name
|
factions.players[player] = self.name
|
||||||
self.invited_players[player] = nil
|
self.invited_players[player] = nil
|
||||||
if factions.enable_power_per_player then
|
if factions_config.enable_power_per_player then
|
||||||
local ip = factions_ip.player_ips[player]
|
local ip = factions_ip.player_ips[player]
|
||||||
local notsame = true
|
local notsame = true
|
||||||
for i,k in pairs(self.players) do
|
for i,k in pairs(self.players) do
|
||||||
@ -229,9 +203,9 @@ function factions.Faction.add_player(self, player, rank)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
if notsame then
|
if notsame then
|
||||||
self:increase_power(factions.power_per_player)
|
self:increase_power(factions_config.power_per_player)
|
||||||
self:increase_maxpower(factions.powermax_per_player)
|
self:increase_maxpower(factions_config.powermax_per_player)
|
||||||
self:decrease_usedpower(factions.power_per_player)
|
self:decrease_usedpower(factions_config.power_per_player)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
local pdata = minetest.get_player_by_name(player)
|
local pdata = minetest.get_player_by_name(player)
|
||||||
@ -260,7 +234,7 @@ function factions.Faction.remove_player(self, player)
|
|||||||
factions.players[player] = nil
|
factions.players[player] = nil
|
||||||
self:on_player_leave(player)
|
self:on_player_leave(player)
|
||||||
self:check_players_in_faction(self)
|
self:check_players_in_faction(self)
|
||||||
if factions.enable_power_per_player then
|
if factions_config.enable_power_per_player then
|
||||||
local ip = factions_ip.player_ips[player]
|
local ip = factions_ip.player_ips[player]
|
||||||
local notsame = true
|
local notsame = true
|
||||||
for i,k in pairs(self.players) do
|
for i,k in pairs(self.players) do
|
||||||
@ -271,7 +245,7 @@ function factions.Faction.remove_player(self, player)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
if notsame then
|
if notsame then
|
||||||
self:decrease_maxpower(factions.powermax_per_player)
|
self:decrease_maxpower(factions_config.powermax_per_player)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
local pdata = minetest.get_player_by_name(player)
|
local pdata = minetest.get_player_by_name(player)
|
||||||
@ -290,12 +264,12 @@ end
|
|||||||
function factions.Faction.can_claim_parcel(self, parcelpos)
|
function factions.Faction.can_claim_parcel(self, parcelpos)
|
||||||
local fac = factions.parcels[parcelpos]
|
local fac = factions.parcels[parcelpos]
|
||||||
if fac then
|
if fac then
|
||||||
if factions.factions[fac].power < 0. and self.power >= factions.power_per_parcel and not self.allies[factions.factions[fac].name] and not self.at_peace_with[factions.factions[fac].name] then
|
if factions.factions[fac].power < 0. and self.power >= factions_config.power_per_parcel and not self.allies[factions.factions[fac].name] and not self.at_peace_with[factions.factions[fac].name] then
|
||||||
return true
|
return true
|
||||||
else
|
else
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
elseif self.power < factions.power_per_parcel then
|
elseif self.power < factions_config.power_per_parcel then
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
return true
|
return true
|
||||||
@ -312,8 +286,8 @@ function factions.Faction.claim_parcel(self, parcelpos)
|
|||||||
end
|
end
|
||||||
factions.parcels[parcelpos] = self.name
|
factions.parcels[parcelpos] = self.name
|
||||||
self.land[parcelpos] = true
|
self.land[parcelpos] = true
|
||||||
self:decrease_power(factions.power_per_parcel)
|
self:decrease_power(factions_config.power_per_parcel)
|
||||||
self:increase_usedpower(factions.power_per_parcel)
|
self:increase_usedpower(factions_config.power_per_parcel)
|
||||||
self:on_claim_parcel(parcelpos)
|
self:on_claim_parcel(parcelpos)
|
||||||
self:parcelless_check()
|
self:parcelless_check()
|
||||||
factions.save()
|
factions.save()
|
||||||
@ -323,8 +297,8 @@ end
|
|||||||
function factions.Faction.unclaim_parcel(self, parcelpos)
|
function factions.Faction.unclaim_parcel(self, parcelpos)
|
||||||
factions.parcels[parcelpos] = nil
|
factions.parcels[parcelpos] = nil
|
||||||
self.land[parcelpos] = nil
|
self.land[parcelpos] = nil
|
||||||
self:increase_power(factions.power_per_parcel)
|
self:increase_power(factions_config.power_per_parcel)
|
||||||
self:decrease_usedpower(factions.power_per_parcel)
|
self:decrease_usedpower(factions_config.power_per_parcel)
|
||||||
self:on_unclaim_parcel(parcelpos)
|
self:on_unclaim_parcel(parcelpos)
|
||||||
self:parcelless_check()
|
self:parcelless_check()
|
||||||
factions.save()
|
factions.save()
|
||||||
@ -343,7 +317,7 @@ function factions.Faction.parcelless_check(self)
|
|||||||
self.no_parcel = -1
|
self.no_parcel = -1
|
||||||
else
|
else
|
||||||
self.no_parcel = os.time()
|
self.no_parcel = os.time()
|
||||||
self:broadcast("Faction " .. self.name .. " will disband in " .. factions.maximum_parcelless_faction_time .. " seconds because it has no parcels.")
|
self:broadcast("Faction " .. self.name .. " will disband in " .. factions_config.maximum_parcelless_faction_time .. " seconds because it has no parcels.")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -548,11 +522,11 @@ function factions.Faction.is_online(self)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function factions.Faction.attack_parcel(self, parcelpos)
|
function factions.Faction.attack_parcel(self, parcelpos)
|
||||||
if factions.attack_parcel then
|
if factions_config.attack_parcel then
|
||||||
local attacked_faction = factions.get_parcel_faction(parcelpos)
|
local attacked_faction = factions.get_parcel_faction(parcelpos)
|
||||||
if attacked_faction then
|
if attacked_faction then
|
||||||
if not self.allies[attacked_faction.name] then
|
if not self.allies[attacked_faction.name] then
|
||||||
self.power = self.power - factions.power_per_attack
|
self.power = self.power - factions_config.power_per_attack
|
||||||
if attacked_faction.attacked_parcels[parcelpos] then
|
if attacked_faction.attacked_parcels[parcelpos] then
|
||||||
attacked_faction.attacked_parcels[parcelpos][self.name] = true
|
attacked_faction.attacked_parcels[parcelpos][self.name] = true
|
||||||
else
|
else
|
||||||
@ -686,10 +660,10 @@ function factions.Faction.on_revoke_invite(self, player)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function factions.get_parcel_pos(pos)
|
function factions.get_parcel_pos(pos)
|
||||||
if factions.protection_style == "classic" then
|
if factions_config.protection_style == "classic" then
|
||||||
return math.floor(pos.x / factions.parcel_size)..","..math.floor(pos.z / factions.parcel_size)
|
return math.floor(pos.x / factions_config.parcel_size)..","..math.floor(pos.z / factions_config.parcel_size)
|
||||||
elseif factions.protection_style == "pb-style" then
|
elseif factions_config.protection_style == "pb-style" then
|
||||||
return math.floor(pos.x / factions.parcel_size)..","..math.floor(pos.y / factions.parcel_size)..","..math.floor(pos.z / factions.parcel_size)
|
return math.floor(pos.x / factions_config.parcel_size)..","..math.floor(pos.y / factions_config.parcel_size)..","..math.floor(pos.z / factions_config.parcel_size)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -717,7 +691,7 @@ end
|
|||||||
|
|
||||||
function factions.get_faction_at(pos)
|
function factions.get_faction_at(pos)
|
||||||
local y = pos.y
|
local y = pos.y
|
||||||
if factions.protection_depth_height_limit and (pos.y < factions.protection_max_depth or pos.y > factions.protection_max_height) then
|
if factions_config.protection_depth_height_limit and (pos.y < factions_config.protection_max_depth or pos.y > factions_config.protection_max_height) then
|
||||||
return nil
|
return nil
|
||||||
end
|
end
|
||||||
local parcelpos = factions.get_parcel_pos(pos)
|
local parcelpos = factions.get_parcel_pos(pos)
|
||||||
@ -828,17 +802,15 @@ function factions.load()
|
|||||||
faction.attacked_parcels = {}
|
faction.attacked_parcels = {}
|
||||||
end
|
end
|
||||||
if not faction.usedpower then
|
if not faction.usedpower then
|
||||||
faction.usedpower = faction:count_land() * factions.power_per_parcel
|
faction.usedpower = faction:count_land() * factions_config.power_per_parcel
|
||||||
end
|
end
|
||||||
if #faction.name > factions.faction_name_max_length then
|
if #faction.name > factions_config.faction_name_max_length then
|
||||||
faction:disband()
|
faction:disband()
|
||||||
end
|
end
|
||||||
if not faction.last_logon then
|
if not faction.last_logon then
|
||||||
faction.last_logon = os.time()
|
faction.last_logon = os.time()
|
||||||
end
|
end
|
||||||
if not faction.no_parcel then
|
faction.no_parcel = os.time()
|
||||||
faction.no_parcel = os.time()
|
|
||||||
end
|
|
||||||
for i, _ in pairs(faction.onlineplayers) do
|
for i, _ in pairs(faction.onlineplayers) do
|
||||||
faction.offlineplayers[i] = _
|
faction.offlineplayers[i] = _
|
||||||
end
|
end
|
||||||
@ -891,7 +863,7 @@ function(player)
|
|||||||
if not faction then
|
if not faction then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
faction:decrease_power(factions.power_per_death)
|
faction:decrease_power(factions_config.power_per_death)
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
)
|
)
|
||||||
@ -901,16 +873,16 @@ function factions.faction_tick()
|
|||||||
local now = os.time()
|
local now = os.time()
|
||||||
for facname, faction in pairs(factions.factions) do
|
for facname, faction in pairs(factions.factions) do
|
||||||
if faction:is_online() then
|
if faction:is_online() then
|
||||||
if factions.enable_power_per_player then
|
if factions_config.enable_power_per_player then
|
||||||
local t = faction.onlineplayers
|
local t = faction.onlineplayers
|
||||||
local count = 0
|
local count = 0
|
||||||
for _ in pairs(t) do count = count + 1 end
|
for _ in pairs(t) do count = count + 1 end
|
||||||
faction:increase_power(factions.power_per_player*count)
|
faction:increase_power(factions_config.power_per_player*count)
|
||||||
else
|
else
|
||||||
faction:increase_power(factions.power_per_tick)
|
faction:increase_power(factions_config.power_per_tick)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if now - faction.last_logon > factions.maximum_faction_inactivity or (faction.no_parcel ~= -1 and now - faction.no_parcel > factions.maximum_parcelless_faction_time) then
|
if now - faction.last_logon > factions_config.maximum_faction_inactivity or (faction.no_parcel ~= -1 and now - faction.no_parcel > factions_config.maximum_parcelless_faction_time) then
|
||||||
faction:disband()
|
faction:disband()
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -966,7 +938,7 @@ minetest.register_on_respawnplayer(
|
|||||||
local default_is_protected = minetest.is_protected
|
local default_is_protected = minetest.is_protected
|
||||||
minetest.is_protected = function(pos, player)
|
minetest.is_protected = function(pos, player)
|
||||||
local y = pos.y
|
local y = pos.y
|
||||||
if factions.protection_depth_height_limit and (pos.y < factions.protection_max_depth or pos.y > factions.protection_max_height) then
|
if factions_config.protection_depth_height_limit and (pos.y < factions_config.protection_max_depth or pos.y > factions_config.protection_max_height) then
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
if factions.disallow_edit_nofac and not player_faction then
|
if factions.disallow_edit_nofac and not player_faction then
|
||||||
@ -1006,7 +978,7 @@ minetest.is_protected = function(pos, player)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function factionUpdate()
|
function factionUpdate()
|
||||||
minetest.after(factions.tick_time,
|
minetest.after(factions_config.tick_time,
|
||||||
function()
|
function()
|
||||||
factions.faction_tick()
|
factions.faction_tick()
|
||||||
factionUpdate()
|
factionUpdate()
|
||||||
|
@ -71,7 +71,7 @@ minetest.register_craft({
|
|||||||
|
|
||||||
-- Code below was copied from TenPlus1's protector mod(MIT) and changed up a bit.
|
-- Code below was copied from TenPlus1's protector mod(MIT) and changed up a bit.
|
||||||
|
|
||||||
local x = math.floor(factions.parcel_size / 2.1)
|
local x = math.floor(factions_config.parcel_size / 2.1)
|
||||||
|
|
||||||
minetest.register_node("factions:display_node", {
|
minetest.register_node("factions:display_node", {
|
||||||
tiles = {"factions_display.png"},
|
tiles = {"factions_display.png"},
|
||||||
|
@ -37,8 +37,8 @@ parcel_size (parcel-size) float 16
|
|||||||
|
|
||||||
# Enable or disabled power-per-player.
|
# Enable or disabled power-per-player.
|
||||||
power_per_playerb (Enable power-per-player) bool true
|
power_per_playerb (Enable power-per-player) bool true
|
||||||
# Enable or disabled attack_parcel function.
|
# Enable or disabled factions_config.attack_parcel function.
|
||||||
attack_parcel (Enable attack parcel) bool false
|
factions_config.attack_parcel (Enable attack parcel) bool false
|
||||||
# Enable or disabled faction diplomacy.
|
# Enable or disabled faction diplomacy.
|
||||||
faction_diplomacy (Enable faction diplomacy) bool false
|
faction_diplomacy (Enable faction diplomacy) bool false
|
||||||
# Enable or disabled the max depth and height limit for a parcel
|
# Enable or disabled the max depth and height limit for a parcel
|
||||||
|
Loading…
Reference in New Issue
Block a user