summaryrefslogtreecommitdiff
path: root/init.lua
diff options
context:
space:
mode:
authorGabriel Pérez-Cerezo <gabriel@gpcf.eu>2018-09-23 12:32:35 +0200
committerGabriel Pérez-Cerezo <gabriel@gpcf.eu>2018-09-23 12:32:35 +0200
commitd0df24d7d9393d0d171df06db97f6e02e3a6db4a (patch)
tree64bdaed6c4f8145a6c73c43af8b5ca7913e7943d /init.lua
parentc846cb1c76fb54d2c3c56d5da13b155f73e0edba (diff)
When you freeze a stack of items, don't freeze them all at once.
Diffstat (limited to 'init.lua')
-rw-r--r--init.lua40
1 files changed, 13 insertions, 27 deletions
diff --git a/init.lua b/init.lua
index ba1f8ab..a5904a8 100644
--- a/init.lua
+++ b/init.lua
@@ -171,13 +171,9 @@ local function freezer_node_timer(pos, elapsed)
-- and of course what is hot can be cooled down
if minetest.get_modpath("farming") then
if inv:contains_item("src", "farming:coffee_cup_hot") then
- while inv:room_for_item("dst", "farming:coffee_cup") do
+ if inv:room_for_item("dst", "farming:coffee_cup") then
local removed = inv:remove_item("src", "farming:coffee_cup_hot")
- if removed:get_count() > 0 then
- inv:add_item("dst", "farming:coffee_cup")
- else
- break
- end
+ inv:add_item("dst", "farming:coffee_cup")
end
end
end
@@ -189,14 +185,10 @@ local function freezer_node_timer(pos, elapsed)
local input_name = input_stack:get_name();
if minetest.get_item_group(input_name, "juice") > 0 then
local output_name = input_name .. "_popsicle"
- while inv:room_for_item("dst", output_name) and inv:room_for_item("dst", "vessels:drinking_glass") do
+ if inv:room_for_item("dst", output_name) and inv:room_for_item("dst", "vessels:drinking_glass") then
local removed = inv:remove_item("src", input_name)
- if removed:get_count() > 0 then
- inv:add_item("dst", output_name)
- inv:add_item("dst", "vessels:drinking_glass")
- else
- break
- end
+ inv:add_item("dst", output_name)
+ inv:add_item("dst", "vessels:drinking_glass")
end
end
end
@@ -207,13 +199,9 @@ local function freezer_node_timer(pos, elapsed)
-- raw pelmeni -> pack of frozen pelmeni -> actual cooked pelmeni
if minetest.get_modpath("mobs") and mobs and mobs.mod == "redo" and minetest.get_modpath("farming") then
if inv:contains_item("src", "freezer:pelmeni_raw") then
- while inv:room_for_item("dst", "freezer:pelmeni_pack 3") do
+ if inv:room_for_item("dst", "freezer:pelmeni_pack 3") then
local removed = inv:remove_item("src", "freezer:pelmeni_raw")
- if removed:get_count() > 0 then
- inv:add_item("dst", "freezer:pelmeni_pack 3")
- else
- break
- end
+ inv:add_item("dst", "freezer:pelmeni_pack 3")
end
end
end
@@ -221,20 +209,18 @@ local function freezer_node_timer(pos, elapsed)
-- aspic
if minetest.get_modpath("mobs") and mobs and mobs.mod == "redo" and minetest.get_modpath("ethereal") then
if inv:contains_item("src", "freezer:meat_broth") then
- while inv:room_for_item("dst", "freezer:aspic 5") and inv:room_for_item("dst", "bucket:bucket_empty") do
+ if inv:room_for_item("dst", "freezer:aspic 5") and inv:room_for_item("dst", "bucket:bucket_empty") then
local removed = inv:remove_item("src", "freezer:meat_broth")
- if removed:get_count() > 0 then
inv:add_item("dst", "freezer:aspic 5")
inv:add_item("dst", "bucket:bucket_empty")
- else
- break
- end
end
end
end
- -- Check if we have cookable content
- return true
+ -- Check if we have freezable content
+ if not inv:is_empty("src") then
+ return true
+ end
end
@@ -496,4 +482,4 @@ if minetest.get_modpath("unified_inventory") and unified_inventory.register_craf
})
end
-end \ No newline at end of file
+end