summaryrefslogtreecommitdiff
path: root/item_drop
diff options
context:
space:
mode:
authorShadowNinja <noreply@gmail.com>2013-07-17 15:34:35 -0400
committerShadowNinja <noreply@gmail.com>2013-09-17 16:37:56 -0400
commitee0765804c0a21deeb2f33c22ac1a36cb0db5f43 (patch)
treed6445b48f5663e10a83a2f718ffbcce5883be798 /item_drop
parent48ea6fb99de29a58e01c8c923bdca626aaf47c65 (diff)
Partial rewrite
Diffstat (limited to 'item_drop')
-rw-r--r--item_drop/init.lua39
1 files changed, 20 insertions, 19 deletions
diff --git a/item_drop/init.lua b/item_drop/init.lua
index 54b617f..aa7ab11 100644
--- a/item_drop/init.lua
+++ b/item_drop/init.lua
@@ -1,38 +1,39 @@
dofile(minetest.get_modpath("item_drop").."/item_entity.lua")
time_pick = 3
-if technic.config:getBool("enable_item_pickup") then
+if technic.config:get_bool("enable_item_pickup") then
minetest.register_globalstep(function(dtime)
for _,player in ipairs(minetest.get_connected_players()) do
if player and player:get_hp() > 0 then
- local pos = player:getpos()
- pos.y = pos.y+0.5
- local inv = player:get_inventory()
- for _,object in ipairs(minetest.env:get_objects_inside_radius(pos, 2)) do
- if not object:is_player() and object:get_luaentity() then
- local obj=object:get_luaentity()
- if obj.name == "__builtin:item" then
- if inv:room_for_item("main", ItemStack(obj.itemstring)) then
- if obj.timer > time_pick then
- inv:add_item("main", ItemStack(obj.itemstring))
- if obj.itemstring ~= "" then
- minetest.sound_play("item_drop_pickup",{pos = pos, gain = 1.0, max_hear_distance = 10})
- end
- if object:get_luaentity() then
- object:get_luaentity().itemstring = ""
- object:remove()
+ local pos = player:getpos()
+ pos.y = pos.y + 0.5
+ local inv = player:get_inventory()
+ for _, object in ipairs(minetest.get_objects_inside_radius(pos, 2)) do
+ if not object:is_player() and object:get_luaentity() then
+ local obj = object:get_luaentity()
+ if obj.name == "__builtin:item" then
+ if inv and inv:room_for_item("main", ItemStack(obj.itemstring)) then
+ if obj.timer > time_pick then
+ inv:add_item("main", ItemStack(obj.itemstring))
+ if obj.itemstring ~= "" then
+ minetest.sound_play("item_drop_pickup",
+ {pos = pos, gain = 1.0, max_hear_distance = 10})
+ end
+ if object:get_luaentity() then
+ object:get_luaentity().itemstring = ""
+ object:remove()
+ end
end
end
end
end
end
end
- end
end
end)
end
-if technic.config:getBool("enable_item_drop") then
+if technic.config:get_bool("enable_item_drop") then
function minetest.handle_node_drops(pos, drops, digger)
for _,item in ipairs(drops) do
local count, name