Add flush command

This commit is contained in:
Joachim Stolberg 2023-09-16 12:03:57 +02:00
parent 957466f2e1
commit 38946d6d84

View File

@ -68,6 +68,21 @@ local function count_index(invlist)
return index return index
end end
local function flush_input_inventory(pos)
local inv = M(pos):get_inventory()
if not inv:is_empty("src") then
for idx = 1, 16 do
local stack = inv:get_stack("src", idx)
if not inv:room_for_item("dst", stack) then
return false
end
inv:add_item("dst", stack)
inv:set_stack("src", idx, nil)
end
end
return true
end
-- caches some recipe data -- caches some recipe data
local autocrafterCache = {} local autocrafterCache = {}
@ -224,13 +239,18 @@ local function on_output_change(pos, inventory, stack)
end end
local function determine_recipe_items(pos, input) local function determine_recipe_items(pos, input)
if input and type(input) == "string" then local num, idx
if input and type(input) == "string" then -- Lua controller
-- Test if "<node-number>.<recipe-number>" input -- Test if "<node-number>.<recipe-number>" input
local num, idx = unpack(string.split(input, ".", false, 1)) num, idx = unpack(string.split(input, ".", false, 1))
if num and idx then elseif input and type(input) == "table" then -- Beduino
input = get_input_from_recipeblock(pos, num, idx) num = tostring(input[1] * 65536 + input[2])
idx = tostring(input[3])
end end
if num and idx then
input = get_input_from_recipeblock(pos, num, idx)
if input then if input then
-- "<item>,<item>,..." input -- "<item>,<item>,..." input
local items = string.split(input, ",", true, 8) local items = string.split(input, ",", true, 8)
@ -443,13 +463,14 @@ local tubing = {
on_recv_message = function(pos, src, topic, payload) on_recv_message = function(pos, src, topic, payload)
if topic == "recipe" and CRD(pos).stage == 4 then if topic == "recipe" and CRD(pos).stage == 4 then
if payload and payload ~= "" then if payload and payload ~= "" then
local inv = M(pos):get_inventory()
on_new_recipe(pos, payload) on_new_recipe(pos, payload)
return true return true
else else
local inv = M(pos):get_inventory() local inv = M(pos):get_inventory()
return inv:get_stack("output", 1):get_name() return inv:get_stack("output", 1):get_name()
end end
elseif topic == "flush" and CRD(pos).stage == 4 then
return flush_input_inventory(pos)
elseif topic == "info" and CRD(pos).stage == 4 then elseif topic == "info" and CRD(pos).stage == 4 then
return INFO return INFO
else else
@ -457,6 +478,16 @@ local tubing = {
end end
end, end,
on_beduino_receive_cmnd = function(pos, src, topic, payload) on_beduino_receive_cmnd = function(pos, src, topic, payload)
if topic == 10 and CRD(pos).stage == 4 then
on_new_recipe(pos, payload)
return 1, ""
elseif topic == 11 and CRD(pos).stage == 4 then
if flush_input_inventory(pos) then
return 1, ""
else
return 0, ""
end
end
return CRD(pos).State:on_beduino_receive_cmnd(pos, topic, payload) return CRD(pos).State:on_beduino_receive_cmnd(pos, topic, payload)
end, end,
on_beduino_request_data = function(pos, src, topic, payload) on_beduino_request_data = function(pos, src, topic, payload)