Fix crash when the bow becomes fully worn

The crash only happened if toolranks was enabled.
This commit is contained in:
upsilon 2020-05-10 16:36:22 +02:00
parent 2d2368529f
commit 4c50e6baec
No known key found for this signature in database
GPG Key ID: A80DAE1F266E1C3C

View File

@ -109,13 +109,7 @@ local function shoot_arrow(def, toolranks_data, player, bow_index, throw_itself,
end end
if not minetest.settings:get_bool("creative_mode") then if not minetest.settings:get_bool("creative_mode") then
if new_stack then inventory:set_stack("main", arrow_index, new_stack)
inventory:set_stack("main", arrow_index, new_stack)
else
local stack = inventory:get_stack("main", arrow_index)
stack:take_item()
inventory:set_stack("main", arrow_index, stack)
end
end end
return true return true
@ -203,8 +197,9 @@ function throwing.arrow_step(self, dtime)
if self.toolranks then if self.toolranks then
local inventory = player:get_inventory() local inventory = player:get_inventory()
-- Check that the player did not move the bow -- Check that the player did not move the bow
if inventory:get_stack("main", self.toolranks.index):get_name() == self.toolranks.itemstack:get_name() then local current_stack = inventory:get_stack("main", self.toolranks.index)
local new_itemstack = toolranks.new_afteruse(self.toolranks.itemstack, player, nil, {wear = self.toolranks.wear}) if current_stack:get_name() == self.toolranks.name then
local new_itemstack = toolranks.new_afteruse(current_stack, player, nil, {wear = self.toolranks.wear})
inventory:set_stack("main", self.toolranks.index, new_itemstack) inventory:set_stack("main", self.toolranks.index, new_itemstack)
end end
end end
@ -401,12 +396,20 @@ function throwing.register_bow(name, def)
minetest.after(def.delay or 0, function() minetest.after(def.delay or 0, function()
-- Re-check that the arrow can be thrown. Overwrite the new_stack -- Re-check that the arrow can be thrown. Overwrite the new_stack
local old_new_stack = new_stack local old_new_stack = new_stack
res, new_stack = def.allow_shot(user, user:get_inventory():get_stack("main", arrow_index), arrow_index, true)
local arrow_stack = user:get_inventory():get_stack("main", arrow_index)
res, new_stack = def.allow_shot(user, arrow_stack, arrow_index, true)
if not res then
return
end
if not new_stack then if not new_stack then
new_stack = old_new_stack new_stack = old_new_stack
end end
if not res then if not new_stack then
return arrow_stack:take_item()
new_stack = arrow_stack
end end
-- Shoot arrow -- Shoot arrow
@ -414,7 +417,7 @@ function throwing.register_bow(name, def)
local toolranks_data local toolranks_data
if enable_toolranks then if enable_toolranks then
toolranks_data = { toolranks_data = {
itemstack = itemstack, name = itemstack:get_name(),
index = bow_index, index = bow_index,
wear = uses wear = uses
} }
@ -428,7 +431,7 @@ function throwing.register_bow(name, def)
if def.throw_itself then if def.throw_itself then
-- This is a bug. If we return ItemStack(nil), the player punches the entity, -- This is a bug. If we return ItemStack(nil), the player punches the entity,
-- and if the entity if a __builtin:item, it gets back to his inventory. -- and if the entity is a __builtin:item, it gets back to his inventory.
minetest.after(0.1, function() minetest.after(0.1, function()
user:get_inventory():remove_item("main", itemstack) user:get_inventory():remove_item("main", itemstack)
end) end)