forked from mtcontrib/3d_armor
fix armor equip/unequip (#17)
This commit is contained in:
parent
294338d3b0
commit
7f63df230c
@ -103,25 +103,13 @@ armor.config = {
|
|||||||
-- Armor Registration
|
-- Armor Registration
|
||||||
|
|
||||||
armor.register_armor = function(self, name, def)
|
armor.register_armor = function(self, name, def)
|
||||||
local wear_on_rightclick = {
|
def.on_secondary_use = function(itemstack, player)
|
||||||
on_secondary_use = function(itemstack, player)
|
return armor:equip(player, itemstack)
|
||||||
armor:equip(player, itemstack:get_name())
|
|
||||||
end,
|
|
||||||
on_place = function(itemstack, player)
|
|
||||||
armor:equip(player, itemstack:get_name())
|
|
||||||
end
|
end
|
||||||
}
|
def.on_place = function(itemstack, player)
|
||||||
local function merge_tables(a, b)
|
return armor:equip(player, itemstack)
|
||||||
if type(a) == 'table' and type(b) == 'table' then
|
|
||||||
for k,v in pairs(b) do
|
|
||||||
if type(v)=='table' and type(a[k] or false)=='table' then
|
|
||||||
merge_tables(a[k],v) else a[k]=v
|
|
||||||
end
|
end
|
||||||
end
|
minetest.register_tool(name, def)
|
||||||
end
|
|
||||||
return a
|
|
||||||
end
|
|
||||||
minetest.register_tool(name, merge_tables(def, wear_on_rightclick))
|
|
||||||
end
|
end
|
||||||
|
|
||||||
armor.register_armor_group = function(self, group, base)
|
armor.register_armor_group = function(self, group, base)
|
||||||
@ -440,40 +428,38 @@ armor.get_weared_armor_elements = function(self, player)
|
|||||||
return weared_armor
|
return weared_armor
|
||||||
end
|
end
|
||||||
|
|
||||||
armor.equip = function(self, player, armor_name)
|
armor.equip = function(self, player, itemstack)
|
||||||
local name, inv = self:get_valid_player(player, "[equip]")
|
local name, armor_inv = self:get_valid_player(player, "[equip]")
|
||||||
local weared_armor = self:get_weared_armor_elements(player)
|
local weared_armor = self:get_weared_armor_elements(player)
|
||||||
local armor_element = self:get_element(armor_name)
|
local armor_element = self:get_element(itemstack:get_name())
|
||||||
if not name then
|
if name and armor_element then
|
||||||
return
|
|
||||||
elseif self:get_element(armor_name) == nil then
|
|
||||||
return
|
|
||||||
elseif inv:contains_item("armor", ItemStack(armor_name)) then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
if weared_armor[armor_element] ~= nil then
|
if weared_armor[armor_element] ~= nil then
|
||||||
self:unequip(player, weared_armor[armor_element])
|
self:unequip(player, armor_element)
|
||||||
end
|
end
|
||||||
inv:add_item("armor", ItemStack(armor_name))
|
armor_inv:add_item("armor", itemstack:take_item())
|
||||||
minetest.after(0, function() player:get_inventory():remove_item("main", ItemStack(armor_name)) end)
|
|
||||||
self:set_player_armor(player)
|
self:set_player_armor(player)
|
||||||
self:save_armor_inventory(player)
|
self:save_armor_inventory(player)
|
||||||
end
|
end
|
||||||
|
return itemstack
|
||||||
|
end
|
||||||
|
|
||||||
armor.unequip = function(self, player, armor_name)
|
armor.unequip = function(self, player, armor_element)
|
||||||
local name, inv = self:get_valid_player(player, "[unequip]")
|
local name, armor_inv = self:get_valid_player(player, "[unequip]")
|
||||||
if not name then
|
local weared_armor = self:get_weared_armor_elements(player)
|
||||||
return
|
if not name or not weared_armor[armor_element] then
|
||||||
elseif self:get_element(armor_name) == nil then
|
|
||||||
return
|
|
||||||
elseif not inv:contains_item("armor", ItemStack(armor_name)) then
|
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
inv:remove_item("armor", ItemStack(armor_name))
|
local itemstack = armor_inv:remove_item("armor", ItemStack(weared_armor[armor_element]))
|
||||||
minetest.after(0, function() player:get_inventory():add_item("main", ItemStack(armor_name)) end)
|
minetest.after(0, function()
|
||||||
|
local inv = player:get_inventory()
|
||||||
|
if inv:room_for_item("main", itemstack) then
|
||||||
|
inv:add_item("main", itemstack)
|
||||||
|
else
|
||||||
|
minetest.add_item(player:get_pos(), itemstack)
|
||||||
|
end
|
||||||
|
end)
|
||||||
self:set_player_armor(player)
|
self:set_player_armor(player)
|
||||||
self:save_armor_inventory(player)
|
self:save_armor_inventory(player)
|
||||||
self:save_armor_inventory(player)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
armor.remove_all = function(self, player)
|
armor.remove_all = function(self, player)
|
||||||
|
Loading…
Reference in New Issue
Block a user