From 232773eebe151d64546af30103581672ca501ce2 Mon Sep 17 00:00:00 2001 From: sapier Date: Tue, 6 May 2014 22:08:48 +0200 Subject: [PATCH] Fix mob lost in case of not enough room in player inventory --- mobf/harvesting.lua | 41 +++++++++++++++++++++++++++++------------ 1 file changed, 29 insertions(+), 12 deletions(-) diff --git a/mobf/harvesting.lua b/mobf/harvesting.lua index 4bb4b5a..5f39945 100644 --- a/mobf/harvesting.lua +++ b/mobf/harvesting.lua @@ -64,6 +64,12 @@ function harvesting.callback(entity,player,now) if entity.data.catching ~= nil and entity.data.catching.tool ~= "" then + assert( + (entity.dynamic_data.spawning.player_spawned and entity.dynamic_data.spawning.spawner ~= nil) + or + (not entity.dynamic_data.spawning.player_spawned) + ) + --grief protection if minetest.world_setting_get("mobf_grief_protection") and entity.dynamic_data.spawning.player_spawned and @@ -78,6 +84,29 @@ function harvesting.callback(entity,player,now) if tool:get_name() == entity.data.catching.tool then dbg_mobf.harvesting_lvl1("MOBF: player wearing ".. entity.data.catching.tool) + --check if player has enough room + local inventory_add_result = nil + + if entity.data.generic.addoncatch ~= nil then + inventory_add_result = player:get_inventory():add_item("main", + entity.data.generic.addoncatch.." 1") + dbg_mobf.harvesting_lvl2( + "MOBF: adding specified oncatch item: " .. + entity.data.generic.addoncatch) + else + inventory_add_result = player:get_inventory():add_item("main", + entity.data.modname ..":"..entity.data.name.." 1") + dbg_mobf.harvesting_lvl2( + "MOBF: adding automatic oncatch item: " .. + entity.data.modname ..":"..entity.data.name) + end + + if not inventory_add_result:is_empty() then + minetest.chat_send_player(player:get_player_name(), + "You don't have any room left in inventory!") + return true + end + --play catch sound if entity.data.sound ~= nil then sound.play(entity.object:getpos(),entity.data.sound.catch); @@ -92,20 +121,8 @@ function harvesting.callback(entity,player,now) else mobf_bug_warning(LOGLEVEL_ERROR,"MOBF: BUG!!! player is" .. " wearing a item he doesn't have in inventory!!!") - --handled but not ok so don't attack - return true end end - - --TODO check if player has enough room - - if entity.data.generic.addoncatch ~= nil then - player:get_inventory():add_item("main", - entity.data.generic.addoncatch.." 1") - else - player:get_inventory():add_item("main", - entity.data.modname ..":"..entity.data.name.." 1") - end spawning.remove(entity, "cought") return true end