Return: default metadata on move, take, put

This commit is contained in:
Coder12a 2019-05-05 17:23:45 -05:00
parent 7cb2f688a6
commit 1d57b3d0af
5 changed files with 59 additions and 47 deletions

View File

@ -109,7 +109,7 @@ factions.register_command = function(cmd_name, cmd, ignore_param_count, or_perm,
end end
-- get some more data -- get some more data
local pos = minetest.get_player_by_name(player):getpos() local pos = minetest.get_player_by_name(player):get_pos()
local parcelpos = factions.get_parcel_pos(pos) local parcelpos = factions.get_parcel_pos(pos)
return self.on_success(player, player_faction, pos, parcelpos, args) return self.on_success(player, player_faction, pos, parcelpos, args)
end, end,

View File

@ -1,6 +1,4 @@
factions_config = {} factions_config = {}
-- If you want to hardcode the config settings just delete settingstypes.txt, and the line up to END. And then uncomment the hardcoded settings below and change it to whatever you want.
-- settingstypes
local flip = tonumber(minetest.settings:get("protection_max_depth")) or 512 local flip = tonumber(minetest.settings:get("protection_max_depth")) or 512
factions_config.protection_max_depth = -flip factions_config.protection_max_depth = -flip
factions_config.protection_max_height = tonumber(minetest.settings:get("protection_max_height")) or 10000 factions_config.protection_max_height = tonumber(minetest.settings:get("protection_max_height")) or 10000
@ -25,30 +23,3 @@ factions_config.faction_diplomacy = minetest.settings:get_bool("faction_diplomac
factions_config.spawn_teleport = minetest.settings:get_bool("spawn_teleport") or false factions_config.spawn_teleport = minetest.settings:get_bool("spawn_teleport") or false
factions_config.protection_style = minetest.settings:get("protection_style") or "2d" factions_config.protection_style = minetest.settings:get("protection_style") or "2d"
factions_config.faction_user_priv = minetest.settings:get("faction_user_priv") or false factions_config.faction_user_priv = minetest.settings:get("faction_user_priv") or false
-- END
--[[
-- hardcoded config settings
factions_config.protection_max_depth = -512
factions_config.protection_max_height = 10000
factions_config.power_per_parcel = 1
factions_config.power_per_death = 1
factions_config.power_per_tick = 2
factions_config.tick_time = 60
factions_config.power_per_attack = 10
factions_config.faction_name_max_length = 50
factions_config.rank_name_max_length = 25
factions_config.maximum_faction_inactivity = 604800
factions_config.maximum_parcelless_faction_time = 10800
factions_config.power = 12
factions_config.maxpower = 0
factions_config.power_per_player = 1
factions_config.powermax_per_player = 12
factions_config.parcel_size = 16
factions_config.protection_depth_height_limit = true
factions_config.enable_power_per_player = true
factions_config.attack_parcel = false
factions_config.faction_diplomacy = true
factions_config.spawn_teleport = false
factions_config.protection_style = "2d"
factions_config.faction_user_priv = false
--]]

View File

@ -489,7 +489,7 @@ end
function factions.get_faction_at(pos) function factions.get_faction_at(pos)
local y = pos.y local y = pos.y
if factions_config.protection_depth_height_limit and (pos.y < factions_config.protection_max_depth or pos.y > factions_config.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)
return factions.get_parcel_faction(parcelpos) return factions.get_parcel_faction(parcelpos)

View File

@ -112,7 +112,7 @@ function hudUpdateClaimInfo()
for i in pairs(playerslist) do for i in pairs(playerslist) do
local player = playerslist[i] local player = playerslist[i]
local name = player:get_player_name() local name = player:get_player_name()
local faction, facname = factions.get_faction_at(player:getpos()) local faction, facname = factions.get_faction_at(player:get_pos())
local id_name = name .. "factionLand" local id_name = name .. "factionLand"
if hud_ids[id_name] then if hud_ids[id_name] then
@ -124,4 +124,4 @@ function hudUpdateClaimInfo()
end end
end end
minetest.after(3, hudUpdateClaimInfo) minetest.after(3, hudUpdateClaimInfo)
end end

View File

@ -30,6 +30,7 @@ if minetest.registered_nodes["default:chest"] then
end end
end end
}) })
local dc = minetest.registered_nodes["default:chest"] local dc = minetest.registered_nodes["default:chest"]
local def_on_rightclick = dc.on_rightclick local def_on_rightclick = dc.on_rightclick
@ -43,37 +44,77 @@ if minetest.registered_nodes["default:chest"] then
name .. ")") name .. ")")
end end
end end
local can_dig = function(pos, player) local can_dig = function(pos, player)
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
local inv = meta:get_inventory() local inv = meta:get_inventory()
return inv:is_empty("main") and return inv:is_empty("main") and
factions.can_use_node(pos, player:get_player_name(), "container") factions.can_use_node(pos, player:get_player_name(), "container")
end end
local allow_metadata_inventory_move = function(pos, from_list, from_index,
to_list, to_index, count, player) local allow_metadata_inventory_move
if not factions.can_use_node(pos, player:get_player_name(), "container") then local def_allow_metadata_inventory_move = dc.allow_metadata_inventory_move
return 0 if def_allow_metadata_inventory_move then
allow_metadata_inventory_move = function(pos, from_list, from_index,
to_list, to_index, count, player)
if not factions.can_use_node(pos, player:get_player_name(), "container") then
return 0
end
return def_allow_metadata_inventory_move(pos, from_list, from_index, to_list, to_index, count, player)
end end
return count else
end allow_metadata_inventory_move = function(pos, from_list, from_index,
local allow_metadata_inventory_put = function(pos, listname, index, stack, player) to_list, to_index, count, player)
if not factions.can_use_node(pos, player:get_player_name(), "container") then if not factions.can_use_node(pos, player:get_player_name(), "container") then
return 0 return 0
end
return count
end end
return stack:get_count()
end end
local allow_metadata_inventory_take = function(pos, listname, index, stack, player)
if not factions.can_use_node(pos, player:get_player_name(), "container") then local allow_metadata_inventory_put
return 0 local def_allow_metadata_inventory_put = dc.allow_metadata_inventory_put
if def_allow_metadata_inventory_put then
allow_metadata_inventory_put = function(pos, listname, index, stack, player)
if not factions.can_use_node(pos, player:get_player_name(), "container") then
return 0
end
return def_allow_metadata_inventory_put(pos, listname, index, stack, player)
end
else
allow_metadata_inventory_put = function(pos, listname, index, stack, player)
if not factions.can_use_node(pos, player:get_player_name(), "container") then
return 0
end
return stack:get_count()
end end
return stack:get_count()
end end
local allow_metadata_inventory_take
local def_allow_metadata_inventory_take = dc.allow_metadata_inventory_take
if def_allow_metadata_inventory_take then
allow_metadata_inventory_take = function(pos, listname, index, stack, player)
if not factions.can_use_node(pos, player:get_player_name(), "container") then
return 0
end
return def_allow_metadata_inventory_take(pos, listname, index, stack, player)
end
else
allow_metadata_inventory_take = function(pos, listname, index, stack, player)
if not factions.can_use_node(pos, player:get_player_name(), "container") then
return 0
end
return stack:get_count()
end
end
local on_rightclick = function(pos, node, clicker, itemstack, pointed_thing) local on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
if not factions.can_use_node(pos, clicker:get_player_name(), "container") then if not factions.can_use_node(pos, clicker:get_player_name(), "container") then
return itemstack return itemstack
end end
return def_on_rightclick(pos, node, clicker, itemstack, pointed_thing) return def_on_rightclick(pos, node, clicker, itemstack, pointed_thing)
end end
minetest.override_item("default:chest", {after_place_node = after_place_node, minetest.override_item("default:chest", {after_place_node = after_place_node,
can_dig = can_dig, can_dig = can_dig,
allow_metadata_inventory_move = allow_metadata_inventory_move, allow_metadata_inventory_move = allow_metadata_inventory_move,