mirror of
https://github.com/joe7575/techpack.git
synced 2025-01-26 16:01:29 +01:00
V2.03, Piston/WorldEdit/replacer detection added, farming and grinder recipes added
This commit is contained in:
parent
a5e18c3d79
commit
a7a6b50492
@ -150,6 +150,7 @@ tubelib_addons1 optional: unified_inventory
|
||||
- 2019-01-12 V2.00 * release
|
||||
- 2019-01-27 V2.01 * SaferLua Controller Terminal added
|
||||
- 2019-01-28 V2.02 * Logic Not added, output reduction on Harvester, Fermenter, and Gravel Sieve
|
||||
- 2019-04-23 V2.03 * Piston/WorldEdit/replacer detection added, farming and grinder recipes added
|
||||
|
||||
|
||||
## New in v2 (from players point of view)
|
||||
|
@ -1,5 +1,21 @@
|
||||
# Release Notes for ModPack TechPack [techpack]
|
||||
|
||||
2019-04-23 V2.03 * ,
|
||||
|
||||
## V2.03 (2019-04-23)
|
||||
|
||||
### Additions
|
||||
- Farming and Grinder recipes added (thanks to obl3pplifp)
|
||||
- Support for Signs Bot chest and Box added
|
||||
|
||||
### Removals
|
||||
|
||||
### Changes
|
||||
|
||||
### Fixes
|
||||
- Piston/WorldEdit/Replacer tool detection added. If node is replaced/removed/copied,
|
||||
it will switch to a "defect" dummy node.
|
||||
|
||||
|
||||
## V2.02.06 (2019-03-23)
|
||||
|
||||
|
@ -33,11 +33,14 @@ end
|
||||
|
||||
|
||||
local function on_time(pos, elasped)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local number = meta:get_string("number")
|
||||
local mem = tubelib.get_data(number, "memory") or table.copy(DEFAULT_MEM)
|
||||
meta:set_string("infotext", "Server "..number..": ("..(mem.size or 0).."/"..SERVER_CAPA..")")
|
||||
return true
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local number = meta:get_string("number")
|
||||
local mem = tubelib.get_data(number, "memory") or table.copy(DEFAULT_MEM)
|
||||
meta:set_string("infotext", "Server "..number..": ("..(mem.size or 0).."/"..SERVER_CAPA..")")
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
minetest.register_node("sl_controller:server", {
|
||||
|
@ -15,47 +15,51 @@
|
||||
|
||||
|
||||
local function switch_on(pos, node)
|
||||
node.name = "smartline:button_active"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.sound_play("button", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
max_hear_distance = 5,
|
||||
})
|
||||
local meta = minetest.get_meta(pos)
|
||||
local own_num = meta:get_string("own_num")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local cycle_time = meta:get_int("cycle_time")
|
||||
if cycle_time > 0 then -- button mode?
|
||||
minetest.get_node_timer(pos):start(cycle_time)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
node.name = "smartline:button_active"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.sound_play("button", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
max_hear_distance = 5,
|
||||
})
|
||||
local meta = minetest.get_meta(pos)
|
||||
local own_num = meta:get_string("own_num")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local cycle_time = meta:get_int("cycle_time")
|
||||
if cycle_time > 0 then -- button mode?
|
||||
minetest.get_node_timer(pos):start(cycle_time)
|
||||
end
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
local clicker_name = nil
|
||||
if meta:get_string("public") == "false" then
|
||||
clicker_name = meta:get_string("clicker_name")
|
||||
end
|
||||
tubelib.send_message(numbers, placer_name, clicker_name, "on", own_num)
|
||||
end
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
local clicker_name = nil
|
||||
if meta:get_string("public") == "false" then
|
||||
clicker_name = meta:get_string("clicker_name")
|
||||
end
|
||||
tubelib.send_message(numbers, placer_name, clicker_name, "on", own_num)
|
||||
end
|
||||
|
||||
local function switch_off(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
node.name = "smartline:button"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.get_node_timer(pos):stop()
|
||||
minetest.sound_play("button", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
max_hear_distance = 5,
|
||||
})
|
||||
local meta = minetest.get_meta(pos)
|
||||
local own_num = meta:get_string("own_num")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
local clicker_name = nil
|
||||
if meta:get_string("public") == "false" then
|
||||
clicker_name = meta:get_string("clicker_name")
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local node = minetest.get_node(pos)
|
||||
node.name = "smartline:button"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.get_node_timer(pos):stop()
|
||||
minetest.sound_play("button", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
max_hear_distance = 5,
|
||||
})
|
||||
local meta = minetest.get_meta(pos)
|
||||
local own_num = meta:get_string("own_num")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
local clicker_name = nil
|
||||
if meta:get_string("public") == "false" then
|
||||
clicker_name = meta:get_string("clicker_name")
|
||||
end
|
||||
tubelib.send_message(numbers, placer_name, clicker_name, "off", own_num)
|
||||
end
|
||||
tubelib.send_message(numbers, placer_name, clicker_name, "off", own_num)
|
||||
end
|
||||
|
||||
|
||||
|
@ -67,27 +67,30 @@ end
|
||||
|
||||
|
||||
local function on_timer(pos,elapsed)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local poll_numbers = meta:get_string("poll_numbers")
|
||||
local idx = meta:get_int("index") + 1
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local poll_numbers = meta:get_string("poll_numbers")
|
||||
local idx = meta:get_int("index") + 1
|
||||
|
||||
if poll_numbers == "" then
|
||||
local own_number = meta:get_string("own_number")
|
||||
meta:set_string("infotext", "SmartLine State Collector "..own_number..": stopped")
|
||||
meta:set_int("state", 0)
|
||||
meta:set_int("stored_state", 0)
|
||||
return false
|
||||
if poll_numbers == "" then
|
||||
local own_number = meta:get_string("own_number")
|
||||
meta:set_string("infotext", "SmartLine State Collector "..own_number..": stopped")
|
||||
meta:set_int("state", 0)
|
||||
meta:set_int("stored_state", 0)
|
||||
return false
|
||||
end
|
||||
|
||||
if idx > meta:get_int("num_numbers") then
|
||||
idx = 1
|
||||
send_event(meta)
|
||||
end
|
||||
meta:set_int("index", idx)
|
||||
|
||||
request_state(meta, poll_numbers, idx)
|
||||
|
||||
return true
|
||||
end
|
||||
|
||||
if idx > meta:get_int("num_numbers") then
|
||||
idx = 1
|
||||
send_event(meta)
|
||||
end
|
||||
meta:set_int("index", idx)
|
||||
|
||||
request_state(meta, poll_numbers, idx)
|
||||
|
||||
return true
|
||||
return false
|
||||
end
|
||||
|
||||
minetest.register_node("smartline:collector", {
|
||||
|
@ -578,16 +578,19 @@ local function execute(meta, number, debug)
|
||||
end
|
||||
|
||||
local function check_rules(pos, elapsed)
|
||||
--local t = minetest.get_us_time()
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_int("runtime", (meta:get_int("runtime") or 1) + 1)
|
||||
local number = meta:get_string("number")
|
||||
local state = meta:get_int("state")
|
||||
if state == tubelib.RUNNING and number then
|
||||
execute(meta, number, debug)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
--local t = minetest.get_us_time()
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_int("runtime", (meta:get_int("runtime") or 1) + 1)
|
||||
local number = meta:get_string("number")
|
||||
local state = meta:get_int("state")
|
||||
if state == tubelib.RUNNING and number then
|
||||
execute(meta, number, debug)
|
||||
end
|
||||
--print("time", minetest.get_us_time() - t)
|
||||
return true
|
||||
end
|
||||
--print("time", minetest.get_us_time() - t)
|
||||
return true
|
||||
return false
|
||||
end
|
||||
|
||||
local function switch_state(pos, state, fs_data)
|
||||
|
@ -28,8 +28,11 @@ local function display_update(pos, objref)
|
||||
end
|
||||
|
||||
local function on_timer(pos)
|
||||
local meta = minetest.get_meta(pos)
|
||||
lcdlib.update_entities(pos)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
lcdlib.update_entities(pos)
|
||||
return false
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
|
@ -139,12 +139,15 @@ minetest.register_node("smartline:playerdetector", {
|
||||
end,
|
||||
|
||||
on_timer = function (pos, elapsed)
|
||||
if scan_for_player(pos) then
|
||||
switch_on(pos)
|
||||
minetest.get_node_timer(pos):start(1)
|
||||
return false
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
if scan_for_player(pos) then
|
||||
switch_on(pos)
|
||||
minetest.get_node_timer(pos):start(1)
|
||||
return false
|
||||
end
|
||||
return true
|
||||
end
|
||||
return true
|
||||
return false
|
||||
end,
|
||||
|
||||
paramtype = "light",
|
||||
|
@ -75,9 +75,12 @@ minetest.register_node("smartline:repeater", {
|
||||
end,
|
||||
|
||||
on_timer = function(pos,elapsed)
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_int("overload_cnt", 0)
|
||||
return true
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_int("overload_cnt", 0)
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end,
|
||||
|
||||
after_dig_node = function(pos)
|
||||
|
@ -98,37 +98,40 @@ local function restart_timer(pos, time)
|
||||
end
|
||||
|
||||
local function check_rules(pos, elapsed)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local rules = minetest.deserialize(meta:get_string("rules"))
|
||||
if rules then
|
||||
local running = meta:get_int("running")
|
||||
local index = meta:get_int("index") or 1
|
||||
local number = meta:get_string("number")
|
||||
local endless = meta:get_int("endless") or 0
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
while true do -- process all rules as long as offs == 0
|
||||
local rule = rules[index]
|
||||
local offs = rules[index].offs
|
||||
if type(offs) == "string" then
|
||||
offs = 0
|
||||
end
|
||||
tubelib.send_message(rule.num, placer_name, nil, tAction[rule.act], number)
|
||||
index = get_next_slot(index, rules, endless)
|
||||
if index ~= nil and offs ~= nil and running == 1 then
|
||||
-- after the last rule a pause with 2 or more sec is required
|
||||
if index == 1 and offs < 1 then
|
||||
offs = 2
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local rules = minetest.deserialize(meta:get_string("rules"))
|
||||
if rules then
|
||||
local running = meta:get_int("running")
|
||||
local index = meta:get_int("index") or 1
|
||||
local number = meta:get_string("number")
|
||||
local endless = meta:get_int("endless") or 0
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
while true do -- process all rules as long as offs == 0
|
||||
local rule = rules[index]
|
||||
local offs = rules[index].offs
|
||||
if type(offs) == "string" then
|
||||
offs = 0
|
||||
end
|
||||
meta:set_string("infotext", "SmartLine Sequencer "..number..": running ("..index.."/"..NUM_SLOTS..")")
|
||||
meta:set_int("index", index)
|
||||
if offs > 0 then
|
||||
minetest.after(0, restart_timer, pos, offs)
|
||||
return false
|
||||
tubelib.send_message(rule.num, placer_name, nil, tAction[rule.act], number)
|
||||
index = get_next_slot(index, rules, endless)
|
||||
if index ~= nil and offs ~= nil and running == 1 then
|
||||
-- after the last rule a pause with 2 or more sec is required
|
||||
if index == 1 and offs < 1 then
|
||||
offs = 2
|
||||
end
|
||||
meta:set_string("infotext", "SmartLine Sequencer "..number..": running ("..index.."/"..NUM_SLOTS..")")
|
||||
meta:set_int("index", index)
|
||||
if offs > 0 then
|
||||
minetest.after(0, restart_timer, pos, offs)
|
||||
return false
|
||||
end
|
||||
else
|
||||
return stop_the_sequencer(pos)
|
||||
end
|
||||
else
|
||||
return stop_the_sequencer(pos)
|
||||
end
|
||||
end
|
||||
return false
|
||||
end
|
||||
return false
|
||||
end
|
||||
@ -147,7 +150,7 @@ local function start_the_sequencer(pos)
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local running = meta:get_int("running")
|
||||
if minetest.is_protected(pos, player:get_player_name()) then
|
||||
|
@ -86,41 +86,44 @@ local function formspec_help()
|
||||
end
|
||||
|
||||
local function check_rules(pos,elapsed)
|
||||
local hour = math.floor(minetest.get_timeofday() * 24)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local events = minetest.deserialize(meta:get_string("events"))
|
||||
local numbers = minetest.deserialize(meta:get_string("numbers"))
|
||||
local actions = minetest.deserialize(meta:get_string("actions"))
|
||||
local done = minetest.deserialize(meta:get_string("done"))
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
local own_num = meta:get_string("own_num")
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local hour = math.floor(minetest.get_timeofday() * 24)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local events = minetest.deserialize(meta:get_string("events"))
|
||||
local numbers = minetest.deserialize(meta:get_string("numbers"))
|
||||
local actions = minetest.deserialize(meta:get_string("actions"))
|
||||
local done = minetest.deserialize(meta:get_string("done"))
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
local own_num = meta:get_string("own_num")
|
||||
|
||||
-- check all rules
|
||||
for idx,act in ipairs(actions) do
|
||||
if act ~= "" and numbers[idx] ~= "" then
|
||||
local hr = (events[idx] - 1) * 2
|
||||
if ((hour - hr) % 24) <= 4 then -- last 4 hours?
|
||||
if done[idx] == false then -- not already executed?
|
||||
-- check all rules
|
||||
for idx,act in ipairs(actions) do
|
||||
if act ~= "" and numbers[idx] ~= "" then
|
||||
local hr = (events[idx] - 1) * 2
|
||||
if ((hour - hr) % 24) <= 4 then -- last 4 hours?
|
||||
if done[idx] == false then -- not already executed?
|
||||
tubelib.send_message(numbers[idx], placer_name, nil, act, own_num)
|
||||
done[idx] = true
|
||||
end
|
||||
else
|
||||
done[idx] = false
|
||||
end
|
||||
if hour == hr and done[idx] == false then
|
||||
tubelib.send_message(numbers[idx], placer_name, nil, act, own_num)
|
||||
done[idx] = true
|
||||
end
|
||||
else
|
||||
done[idx] = false
|
||||
end
|
||||
if hour == hr and done[idx] == false then
|
||||
tubelib.send_message(numbers[idx], placer_name, nil, act, own_num)
|
||||
done[idx] = true
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
-- prepare for the next day
|
||||
if hour == 23 then
|
||||
done = {false,false,false,false,false,false}
|
||||
-- prepare for the next day
|
||||
if hour == 23 then
|
||||
done = {false,false,false,false,false,false}
|
||||
end
|
||||
meta:set_string("done", minetest.serialize(done))
|
||||
meta:set_string("infotext","SmartLine Timer ("..own_num..")"..hour..":00")
|
||||
return true
|
||||
end
|
||||
meta:set_string("done", minetest.serialize(done))
|
||||
meta:set_string("infotext","SmartLine Timer ("..own_num..")"..hour..":00")
|
||||
return true
|
||||
return false
|
||||
end
|
||||
|
||||
|
||||
|
@ -268,38 +268,41 @@ function techpack_warehouse.after_place_node(self, pos, placer, itemstack)
|
||||
end
|
||||
|
||||
function techpack_warehouse.on_timer(self, pos, elapsed)
|
||||
local meta = M(pos)
|
||||
local inv = meta:get_inventory()
|
||||
if not inv:is_empty("shift") then
|
||||
--local number = meta:get_string("tubelib_number")
|
||||
local player_name = meta:get_string("player_name")
|
||||
local offs = meta:get_int("offs")
|
||||
local push_dir = meta:get_string("push_dir")
|
||||
if push_dir == "" then push_dir = "L" end
|
||||
meta:set_int("offs", offs + 1)
|
||||
for i = 0,7 do
|
||||
local idx = ((i + offs) % 8) + 1
|
||||
local stack = inv:get_stack("shift", idx)
|
||||
if stack:get_count() > 0 then
|
||||
if tubelib.push_items(pos, push_dir, stack, player_name) then
|
||||
-- The effort is needed here for the case the
|
||||
-- pusher pushes into its own chest.
|
||||
local num = stack:get_count()
|
||||
stack = inv:get_stack("shift", idx)
|
||||
stack:take_item(num)
|
||||
inv:set_stack("shift", idx, stack)
|
||||
self.State:keep_running(pos, meta, COUNTDOWN_TICKS)
|
||||
break
|
||||
else
|
||||
self.State:blocked(pos, meta)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
local inv = meta:get_inventory()
|
||||
if not inv:is_empty("shift") then
|
||||
--local number = meta:get_string("tubelib_number")
|
||||
local player_name = meta:get_string("player_name")
|
||||
local offs = meta:get_int("offs")
|
||||
local push_dir = meta:get_string("push_dir")
|
||||
if push_dir == "" then push_dir = "L" end
|
||||
meta:set_int("offs", offs + 1)
|
||||
for i = 0,7 do
|
||||
local idx = ((i + offs) % 8) + 1
|
||||
local stack = inv:get_stack("shift", idx)
|
||||
if stack:get_count() > 0 then
|
||||
if tubelib.push_items(pos, push_dir, stack, player_name) then
|
||||
-- The effort is needed here for the case the
|
||||
-- pusher pushes into its own chest.
|
||||
local num = stack:get_count()
|
||||
stack = inv:get_stack("shift", idx)
|
||||
stack:take_item(num)
|
||||
inv:set_stack("shift", idx, stack)
|
||||
self.State:keep_running(pos, meta, COUNTDOWN_TICKS)
|
||||
break
|
||||
else
|
||||
self.State:blocked(pos, meta)
|
||||
end
|
||||
end
|
||||
end
|
||||
else
|
||||
self.State:idle(pos, meta)
|
||||
end
|
||||
else
|
||||
self.State:idle(pos, meta)
|
||||
end
|
||||
|
||||
return self.State:is_active(meta)
|
||||
return self.State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
function techpack_warehouse.can_dig(self, pos)
|
||||
|
@ -16,47 +16,51 @@
|
||||
|
||||
|
||||
local function switch_on(pos, node)
|
||||
node.name = "tubelib:button_active"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.sound_play("button", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
max_hear_distance = 5,
|
||||
})
|
||||
local meta = minetest.get_meta(pos)
|
||||
local own_num = meta:get_string("own_num")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local cycle_time = meta:get_int("cycle_time")
|
||||
if cycle_time > 0 then -- button mode?
|
||||
minetest.get_node_timer(pos):start(cycle_time)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
node.name = "tubelib:button_active"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.sound_play("button", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
max_hear_distance = 5,
|
||||
})
|
||||
local meta = minetest.get_meta(pos)
|
||||
local own_num = meta:get_string("own_num")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local cycle_time = meta:get_int("cycle_time")
|
||||
if cycle_time > 0 then -- button mode?
|
||||
minetest.get_node_timer(pos):start(cycle_time)
|
||||
end
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
local clicker_name = nil
|
||||
if meta:get_string("public") == "false" then
|
||||
clicker_name = meta:get_string("clicker_name")
|
||||
end
|
||||
tubelib.send_message(numbers, placer_name, clicker_name, "on", own_num) -- <<=== tubelib
|
||||
end
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
local clicker_name = nil
|
||||
if meta:get_string("public") == "false" then
|
||||
clicker_name = meta:get_string("clicker_name")
|
||||
end
|
||||
tubelib.send_message(numbers, placer_name, clicker_name, "on", own_num) -- <<=== tubelib
|
||||
end
|
||||
|
||||
local function switch_off(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
node.name = "tubelib:button"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.get_node_timer(pos):stop()
|
||||
minetest.sound_play("button", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
max_hear_distance = 5,
|
||||
})
|
||||
local meta = minetest.get_meta(pos)
|
||||
local own_num = meta:get_string("own_num")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
local clicker_name = nil
|
||||
if meta:get_string("public") == "false" then
|
||||
clicker_name = meta:get_string("clicker_name")
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local node = minetest.get_node(pos)
|
||||
node.name = "tubelib:button"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.get_node_timer(pos):stop()
|
||||
minetest.sound_play("button", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
max_hear_distance = 5,
|
||||
})
|
||||
local meta = minetest.get_meta(pos)
|
||||
local own_num = meta:get_string("own_num")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
local clicker_name = nil
|
||||
if meta:get_string("public") == "false" then
|
||||
clicker_name = meta:get_string("clicker_name")
|
||||
end
|
||||
tubelib.send_message(numbers, placer_name, clicker_name, "off", own_num) -- <<=== tubelib
|
||||
end
|
||||
tubelib.send_message(numbers, placer_name, clicker_name, "off", own_num) -- <<=== tubelib
|
||||
end
|
||||
|
||||
|
||||
|
48
tubelib/defect.lua
Normal file
48
tubelib/defect.lua
Normal file
@ -0,0 +1,48 @@
|
||||
minetest.register_node("tubelib:defect_dummy", {
|
||||
description = "Corrupted Tubelib Node",
|
||||
tiles = {
|
||||
"tubelib_front.png",
|
||||
"tubelib_front.png",
|
||||
"tubelib_front.png^tubelib_defect.png",
|
||||
"tubelib_front.png^tubelib_defect.png",
|
||||
"tubelib_front.png^tubelib_defect.png",
|
||||
"tubelib_front.png^tubelib_defect.png",
|
||||
},
|
||||
drop = "",
|
||||
groups = {cracky=3, crumbly=3, choppy=3, not_in_creative_inventory=1},
|
||||
is_ground_content = false,
|
||||
})
|
||||
|
||||
|
||||
function tubelib.data_not_corrupted(pos)
|
||||
if minetest.pos_to_string(pos) ~= minetest.get_meta(pos):get_string("my_pos") then
|
||||
-- node number corrupt?
|
||||
local meta = minetest.get_meta(pos)
|
||||
local number = meta:get_string("tubelib_number")
|
||||
if number == "" then
|
||||
number = meta:get_string("number")
|
||||
end
|
||||
if number == "" then
|
||||
number = meta:get_string("own_num")
|
||||
end
|
||||
if number == "" then
|
||||
number = meta:get_string("own_number")
|
||||
end
|
||||
if number == "" then
|
||||
tubelib.remove_node(pos)
|
||||
minetest.set_node(pos, {name = "tubelib:defect_dummy"})
|
||||
meta:from_table(nil)
|
||||
return false
|
||||
end
|
||||
-- node moved?
|
||||
local info = tubelib.get_node_info(number)
|
||||
if not info or not vector.equals(info.pos, pos) then
|
||||
tubelib.remove_node(pos)
|
||||
minetest.set_node(pos, {name = "tubelib:defect_dummy"})
|
||||
meta:from_table(nil)
|
||||
return false
|
||||
end
|
||||
minetest.get_meta(pos):get_string("my_pos", minetest.pos_to_string(pos))
|
||||
end
|
||||
return true
|
||||
end
|
@ -270,9 +270,12 @@ end
|
||||
|
||||
-- move items to the output slots
|
||||
local function keep_running(pos, elapsed)
|
||||
local meta = M(pos)
|
||||
distributing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
distributing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
|
@ -101,6 +101,7 @@ else
|
||||
-- conversion from v1.16 to v2.00
|
||||
dofile(minetest.get_modpath("tubelib") .. "/migrate.lua")
|
||||
dofile(minetest.get_modpath("tubelib") .. "/states.lua")
|
||||
dofile(minetest.get_modpath("tubelib") .. "/defect.lua")
|
||||
dofile(minetest.get_modpath("tubelib") .. "/node_states.lua")
|
||||
dofile(minetest.get_modpath("tubelib") .. "/pusher.lua")
|
||||
dofile(minetest.get_modpath("tubelib") .. "/blackhole.lua")
|
||||
|
@ -104,4 +104,32 @@ tubelib.register_node("shop:shop", {}, {
|
||||
end,
|
||||
})
|
||||
|
||||
tubelib.register_node("signs_bot:box", {}, {
|
||||
on_pull_item = function(pos, side)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return tubelib.get_item(meta, "main")
|
||||
end,
|
||||
on_push_item = function(pos, side, item)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return tubelib.put_item(meta, "main", item)
|
||||
end,
|
||||
on_unpull_item = function(pos, side, item)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return tubelib.put_item(meta, "main", item)
|
||||
end,
|
||||
})
|
||||
|
||||
tubelib.register_node("signs_bot:chest", {}, {
|
||||
on_pull_item = function(pos, side)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return tubelib.get_item(meta, "main")
|
||||
end,
|
||||
on_push_item = function(pos, side, item)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return tubelib.put_item(meta, "main", item)
|
||||
end,
|
||||
on_unpull_item = function(pos, side, item)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return tubelib.put_item(meta, "main", item)
|
||||
end,
|
||||
})
|
||||
|
@ -376,17 +376,9 @@ function NodeStates:on_node_load(pos, not_start_timer)
|
||||
meta:set_int("counter", 0)
|
||||
end
|
||||
|
||||
-- node number corrupt?
|
||||
number = meta:get_string("tubelib_number")
|
||||
if number == "" then
|
||||
number = tubelib.get_new_number(pos, self.node_name_passive)
|
||||
meta:set_string("tubelib_number", number)
|
||||
else
|
||||
local info = tubelib.get_node_info(number)
|
||||
if not info or info.pos ~= pos then
|
||||
number = tubelib.get_new_number(pos, self.node_name_passive)
|
||||
meta:set_string("tubelib_number", number)
|
||||
end
|
||||
-- node corrupt?
|
||||
if not tubelib.data_not_corrupted(pos) then
|
||||
return
|
||||
end
|
||||
|
||||
-- state corrupt?
|
||||
|
@ -66,9 +66,12 @@ local function pushing(pos, meta)
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
local meta = M(pos)
|
||||
pushing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
pushing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
minetest.register_node("tubelib:pusher", {
|
||||
|
@ -6,6 +6,12 @@ the automated mining, farming, and crafting.
|
||||
A Tutorial to this Mod is available as ![Wiki](https://github.com/joe7575/techpack/wiki)
|
||||
|
||||
|
||||
With contributions from:
|
||||
* obl3pplifp, https://github.com/obl3pplifp/techpack_compat and as pull requests
|
||||
* realmicu, as pull requests
|
||||
* theFox6, as pull request
|
||||
|
||||
|
||||
## Dependencies
|
||||
tubelib, default
|
||||
opt. unified_inventory
|
||||
|
@ -127,12 +127,15 @@ end
|
||||
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
local meta = M(pos)
|
||||
local inv = meta:get_inventory()
|
||||
local craft = get_craft(pos, inv)
|
||||
local output_item = craft.output.item
|
||||
autocraft(pos, meta, inv, craft)
|
||||
return State:is_active(meta)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
local inv = meta:get_inventory()
|
||||
local craft = get_craft(pos, inv)
|
||||
local output_item = craft.output.item
|
||||
autocraft(pos, meta, inv, craft)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
-- note, that this function assumes allready being updated to virtual items
|
||||
|
@ -14,26 +14,30 @@
|
||||
|
||||
|
||||
local function switch_on(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
node.name = "tubelib_addons1:detector_active"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.get_node_timer(pos):start(1)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local own_num = meta:get_string("own_num")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
tubelib.send_message(numbers, placer_name, nil, "on", own_num)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local node = minetest.get_node(pos)
|
||||
node.name = "tubelib_addons1:detector_active"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.get_node_timer(pos):start(1)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local own_num = meta:get_string("own_num")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
tubelib.send_message(numbers, placer_name, nil, "on", own_num)
|
||||
end
|
||||
end
|
||||
|
||||
local function switch_off(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
node.name = "tubelib_addons1:detector"
|
||||
minetest.swap_node(pos, node)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local own_num = meta:get_string("own_num")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
tubelib.send_message(numbers, placer_name, nil, "off", own_num)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local node = minetest.get_node(pos)
|
||||
node.name = "tubelib_addons1:detector"
|
||||
minetest.swap_node(pos, node)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local own_num = meta:get_string("own_num")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
tubelib.send_message(numbers, placer_name, nil, "off", own_num)
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
|
@ -144,9 +144,12 @@ local function convert_leaves_to_biogas(pos, meta)
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
local meta = M(pos)
|
||||
convert_leaves_to_biogas(pos, meta)
|
||||
return State:is_active(meta)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
convert_leaves_to_biogas(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
|
@ -103,10 +103,13 @@ local function grinding(pos, meta, inv)
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
local meta = M(pos)
|
||||
local inv = meta:get_inventory()
|
||||
grinding(pos, meta, inv)
|
||||
return State:is_active(meta)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
local inv = meta:get_inventory()
|
||||
grinding(pos, meta, inv)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
|
@ -243,30 +243,33 @@ end
|
||||
|
||||
-- move the "harvesting copter" to the next pos and harvest the field below
|
||||
local function keep_running(pos, elapsed)
|
||||
local meta = M(pos)
|
||||
local this = minetest.deserialize(meta:get_string("this"))
|
||||
this.num_items = 0
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
local this = minetest.deserialize(meta:get_string("this"))
|
||||
this.num_items = 0
|
||||
|
||||
if not_blocked(pos, this, meta) then
|
||||
if check_fuel(pos, this, meta) then
|
||||
if calc_new_pos(pos, this, meta) then
|
||||
if harvest_field(this, meta) then
|
||||
meta:set_string("this", minetest.serialize(this))
|
||||
meta:set_string("infotext",
|
||||
"Tubelib Harvester "..this.number..
|
||||
": running ("..this.idx.."/"..this.max..")")
|
||||
State:keep_running(pos, meta, COUNTDOWN_TICKS, this.num_items)
|
||||
if not_blocked(pos, this, meta) then
|
||||
if check_fuel(pos, this, meta) then
|
||||
if calc_new_pos(pos, this, meta) then
|
||||
if harvest_field(this, meta) then
|
||||
meta:set_string("this", minetest.serialize(this))
|
||||
meta:set_string("infotext",
|
||||
"Tubelib Harvester "..this.number..
|
||||
": running ("..this.idx.."/"..this.max..")")
|
||||
State:keep_running(pos, meta, COUNTDOWN_TICKS, this.num_items)
|
||||
else
|
||||
State:blocked(pos, meta)
|
||||
end
|
||||
else
|
||||
State:blocked(pos, meta)
|
||||
State:stop(pos, meta)
|
||||
end
|
||||
else
|
||||
State:stop(pos, meta)
|
||||
State:fault(pos, meta)
|
||||
end
|
||||
else
|
||||
State:fault(pos, meta)
|
||||
end
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return State:is_active(meta)
|
||||
return false
|
||||
end
|
||||
|
||||
|
||||
|
@ -112,9 +112,12 @@ local function allow_metadata_inventory_take(pos, listname, index, stack, player
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
local meta = M(pos)
|
||||
sample_liquid(pos, meta)
|
||||
return State:is_active(meta)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
sample_liquid(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
|
@ -48,6 +48,7 @@ local tn = tubelib_addons1.register_tree_node
|
||||
local dn = tubelib_addons1.register_default_farming_node
|
||||
local fn = tubelib_addons1.register_farming_node
|
||||
local gn = tubelib_addons1.register_ground_node
|
||||
local gr = tubelib.add_grinder_recipe
|
||||
|
||||
-------------------------------------------------------------------------------
|
||||
-- Default Farming
|
||||
@ -103,6 +104,13 @@ if farming.mod == "redo" then
|
||||
fn("farming:oat_8", "farming:oat", "farming:oat_1")
|
||||
fn("farming:rye_8", "farming:rye", "farming:rye_1")
|
||||
fn("farming:rice_8", "farming:rice", "farming:rice_1")
|
||||
fn('farming:beetroot_5', 'farming:beetroot 2', 'farming:beetroot_1')
|
||||
fn('farming:cocoa_4', 'farming:cocoa_beans 2', 'farming:cocoa_1')
|
||||
fn('farming:garlic_5', 'farming:garlic 2', 'farming:garlic_1')
|
||||
fn('farming:onion_5', 'farming:onion 2', 'farming:onion_1')
|
||||
fn('farming:pea_5', 'farming:pea_pod 3', 'farming:pea_1')
|
||||
fn('farming:pepper_5', 'farming:pepper 2', 'farming:pepper_1')
|
||||
fn('farming:pineapple_8', 'farming:pineapple 1', 'farming:pineapple_1')
|
||||
end
|
||||
|
||||
-------------------------------------------------------------------------------
|
||||
@ -246,3 +254,55 @@ end
|
||||
|
||||
minetest.after(10, register_flowers)
|
||||
|
||||
-------------------------------------------------------------------------------
|
||||
-- moretrees
|
||||
-------------------------------------------------------------------------------
|
||||
|
||||
if minetest.global_exists("moretrees") then
|
||||
local function register_tree(treename)
|
||||
local trunk_name = 'moretrees:' .. treename .. '_trunk'
|
||||
local sappling_name = 'moretrees:' .. treename .. '_sapling'
|
||||
local leaves_name = 'moretrees:' .. treename .. '_leaves'
|
||||
|
||||
tn(trunk_name, trunk_name, sappling_name)
|
||||
fn(leaves_name)
|
||||
gr({input=trunk_name, output=leaves_name .. ' 8'})
|
||||
end
|
||||
|
||||
-- "ordinary" moretrees blocks
|
||||
for i in ipairs(moretrees.treelist) do
|
||||
local treename = moretrees.treelist[i][1]
|
||||
|
||||
if treename ~= 'jungletree' then
|
||||
register_tree(treename)
|
||||
end
|
||||
end
|
||||
|
||||
-- "weird" moretrees trunks
|
||||
tn('moretrees:date_palm_fruit_trunk', 'moretrees:date_palm_trunk', 'moretrees:date_palm_sapling')
|
||||
gr({input='moretrees:date_palm_fruit_trunk', output='moretrees:date_palm_leaves 8'})
|
||||
tn('moretrees:date_palm_ffruit_trunk', 'moretrees:date_palm_trunk', 'moretrees:date_palm_sapling')
|
||||
gr({input='moretrees:date_palm_ffruit_trunk', output='moretrees:date_palm_leaves 8'})
|
||||
tn('moretrees:date_palm_mfruit_trunk', 'moretrees:date_palm_trunk', 'moretrees:date_palm_sapling')
|
||||
gr({input='moretrees:date_palm_mfruit_trunk', output='moretrees:date_palm_leaves 8'})
|
||||
tn('moretrees:jungletree_trunk', 'default:jungletree', 'default:junglesapling')
|
||||
gr({input='moretrees:jungletree_trunk', output='default:jungleleaves 8'})
|
||||
tn('moretrees:palm_fruit_trunk', 'moretrees:palm_trunk', 'moretrees:palm_sapling')
|
||||
gr({input='moretrees:palm_fruit_trunk', output='moretrees:palm_leaves 8'})
|
||||
tn('moretrees:palm_fruit_trunk_gen', 'moretrees:palm_trunk', 'moretrees:palm_sapling')
|
||||
gr({input='moretrees:palm_fruit_trunk_gen', output='moretrees:palm_leaves 8'})
|
||||
tn('moretrees:rubber_tree_trunk_empty', 'moretrees:rubber_tree_trunk_empty', 'moretrees:rubber_tree_sapling')
|
||||
gr({input='moretrees:rubber_tree_trunk_empty', output='moretrees:rubber_tree_leaves 8'})
|
||||
|
||||
-- moretrees fruit and leaves
|
||||
fn('moretrees:acorn')
|
||||
fn('moretrees:cedar_cone')
|
||||
fn('moretrees:coconut_3', 'moretrees:coconut')
|
||||
fn('moretrees:dates_f4', 'moretrees:date 16')
|
||||
fn('moretrees:fir_cone')
|
||||
fn('moretrees:fir_leaves_bright')
|
||||
fn('moretrees:jungletree_leaves_red')
|
||||
fn('moretrees:jungletree_leaves_yellow')
|
||||
fn('moretrees:spruce_cone')
|
||||
end
|
||||
|
||||
|
@ -66,9 +66,12 @@ local function pushing(pos, meta)
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
local meta = M(pos)
|
||||
pushing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
pushing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
minetest.register_node("tubelib_addons1:pusher_fast", {
|
||||
|
@ -238,9 +238,12 @@ local function quarry_next_node(pos, meta)
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
local meta = M(pos)
|
||||
quarry_next_node(pos, meta)
|
||||
return State:is_active(meta)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
quarry_next_node(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
|
@ -139,9 +139,12 @@ end
|
||||
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
local meta = M(pos)
|
||||
convert_biogas_to_biofuel(pos, meta)
|
||||
return State:is_active(meta)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
convert_biogas_to_biofuel(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
|
@ -13,29 +13,33 @@
|
||||
]]--
|
||||
|
||||
local function switch_on(pos, meta)
|
||||
minetest.sound_play("tubelib_addons2_door", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
max_hear_distance = 5,
|
||||
})
|
||||
local numbers = meta:get_string("numbers")
|
||||
local number = meta:get_string("number")
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
tubelib.send_message(numbers, placer_name, nil, "on", number)
|
||||
minetest.get_node_timer(pos):start(4)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
minetest.sound_play("tubelib_addons2_door", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
max_hear_distance = 5,
|
||||
})
|
||||
local numbers = meta:get_string("numbers")
|
||||
local number = meta:get_string("number")
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
tubelib.send_message(numbers, placer_name, nil, "on", number)
|
||||
minetest.get_node_timer(pos):start(4)
|
||||
end
|
||||
end
|
||||
|
||||
local function switch_off(pos)
|
||||
minetest.sound_play("tubelib_addons2_door", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
max_hear_distance = 5,
|
||||
})
|
||||
local meta = minetest.get_meta(pos)
|
||||
local numbers = meta:get_string("numbers")
|
||||
local number = meta:get_string("number")
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
tubelib.send_message(numbers, placer_name, nil, "off", number)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
minetest.sound_play("tubelib_addons2_door", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
max_hear_distance = 5,
|
||||
})
|
||||
local meta = minetest.get_meta(pos)
|
||||
local numbers = meta:get_string("numbers")
|
||||
local number = meta:get_string("number")
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
tubelib.send_message(numbers, placer_name, nil, "off", number)
|
||||
end
|
||||
end
|
||||
|
||||
local function formspec1(numbers)
|
||||
|
@ -76,19 +76,21 @@ minetest.register_craft({
|
||||
|
||||
tubelib.register_node("tubelib_addons2:logic_not", {}, {
|
||||
on_recv_message = function(pos, topic, payload)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local owner = meta:get_string("owner")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local own_number = meta:get_string("own_number")
|
||||
if topic == "set_numbers" then
|
||||
meta:set_string("infotext", "Tubelib Logic Not "..own_number..": connected with "..payload)
|
||||
meta:set_string("numbers", payload)
|
||||
meta:set_string("formspec", formspec(meta))
|
||||
return true
|
||||
elseif topic == "on" then
|
||||
return tubelib.send_message(numbers, owner, nil, "off", payload)
|
||||
elseif topic == "off" then
|
||||
return tubelib.send_message(numbers, owner, nil, "on", payload)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local owner = meta:get_string("owner")
|
||||
local numbers = meta:get_string("numbers")
|
||||
local own_number = meta:get_string("own_number")
|
||||
if topic == "set_numbers" then
|
||||
meta:set_string("infotext", "Tubelib Logic Not "..own_number..": connected with "..payload)
|
||||
meta:set_string("numbers", payload)
|
||||
meta:set_string("formspec", formspec(meta))
|
||||
return true
|
||||
elseif topic == "on" then
|
||||
return tubelib.send_message(numbers, owner, nil, "off", payload)
|
||||
elseif topic == "off" then
|
||||
return tubelib.send_message(numbers, owner, nil, "on", payload)
|
||||
end
|
||||
end
|
||||
end,
|
||||
})
|
||||
|
@ -108,9 +108,12 @@ minetest.register_node("tubelib_addons2:mesecons_converter", {
|
||||
},
|
||||
|
||||
on_timer = function(pos,elapsed)
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_int("overload_cnt", 0)
|
||||
return true
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_int("overload_cnt", 0)
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end,
|
||||
|
||||
after_dig_node = function(pos)
|
||||
|
@ -62,9 +62,12 @@ minetest.register_node("tubelib_addons2:repeater", {
|
||||
end,
|
||||
|
||||
on_timer = function(pos,elapsed)
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_int("overload_cnt", 0)
|
||||
return true
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_int("overload_cnt", 0)
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end,
|
||||
|
||||
after_dig_node = function(pos)
|
||||
|
@ -89,37 +89,40 @@ local function restart_timer(pos, time)
|
||||
end
|
||||
|
||||
local function check_rules(pos, elapsed)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local rules = minetest.deserialize(meta:get_string("rules"))
|
||||
if rules then
|
||||
local running = meta:get_int("running")
|
||||
local index = meta:get_int("index") or 1
|
||||
local number = meta:get_string("number")
|
||||
local endless = meta:get_int("endless") or 0
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
while true do -- process all rules as long as offs == 0
|
||||
local rule = rules[index]
|
||||
local offs = rules[index].offs
|
||||
if type(offs) == "string" then
|
||||
offs = 0
|
||||
end
|
||||
tubelib.send_message(rule.num, placer_name, nil, tAction[rule.act], number)
|
||||
index = get_next_slot(index, rules, endless)
|
||||
if index ~= nil and offs ~= nil and running == 1 then
|
||||
-- after the last rule a pause with 1 or more sec is required
|
||||
if index == 1 and offs < 1 then
|
||||
offs = 1
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local rules = minetest.deserialize(meta:get_string("rules"))
|
||||
if rules then
|
||||
local running = meta:get_int("running")
|
||||
local index = meta:get_int("index") or 1
|
||||
local number = meta:get_string("number")
|
||||
local endless = meta:get_int("endless") or 0
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
while true do -- process all rules as long as offs == 0
|
||||
local rule = rules[index]
|
||||
local offs = rules[index].offs
|
||||
if type(offs) == "string" then
|
||||
offs = 0
|
||||
end
|
||||
meta:set_string("infotext", "Tubelib Sequencer "..number..": running ("..index.."/"..NUM_SLOTS..")")
|
||||
meta:set_int("index", index)
|
||||
if offs > 0 then
|
||||
minetest.after(0, restart_timer, pos, offs)
|
||||
return false
|
||||
tubelib.send_message(rule.num, placer_name, nil, tAction[rule.act], number)
|
||||
index = get_next_slot(index, rules, endless)
|
||||
if index ~= nil and offs ~= nil and running == 1 then
|
||||
-- after the last rule a pause with 1 or more sec is required
|
||||
if index == 1 and offs < 1 then
|
||||
offs = 1
|
||||
end
|
||||
meta:set_string("infotext", "Tubelib Sequencer "..number..": running ("..index.."/"..NUM_SLOTS..")")
|
||||
meta:set_int("index", index)
|
||||
if offs > 0 then
|
||||
minetest.after(0, restart_timer, pos, offs)
|
||||
return false
|
||||
end
|
||||
else
|
||||
return stop_the_sequencer(pos)
|
||||
end
|
||||
else
|
||||
return stop_the_sequencer(pos)
|
||||
end
|
||||
end
|
||||
return false
|
||||
end
|
||||
return false
|
||||
end
|
||||
@ -139,54 +142,56 @@ local function start_the_sequencer(pos)
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local running = meta:get_int("running")
|
||||
if minetest.is_protected(pos, player:get_player_name()) then
|
||||
return
|
||||
end
|
||||
|
||||
if fields.help ~= nil then
|
||||
meta:set_string("formspec", formspec_help())
|
||||
return
|
||||
end
|
||||
|
||||
local endless = meta:get_int("endless") or 0
|
||||
if fields.endless ~= nil then
|
||||
endless = fields.endless == "true" and 1 or 0
|
||||
meta:set_int("index", 1)
|
||||
end
|
||||
meta:set_int("endless", endless)
|
||||
|
||||
local rules = minetest.deserialize(meta:get_string("rules"))
|
||||
if fields.exit ~= nil then
|
||||
meta:set_string("formspec", formspec(tubelib.state(running), rules, endless))
|
||||
return
|
||||
end
|
||||
|
||||
for idx = 1,NUM_SLOTS do
|
||||
if fields["offs"..idx] ~= nil then
|
||||
rules[idx].offs = tonumber(fields["offs"..idx]) or ""
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local running = meta:get_int("running")
|
||||
if minetest.is_protected(pos, player:get_player_name()) then
|
||||
return
|
||||
end
|
||||
if fields["num"..idx] ~= nil and tubelib.check_numbers(fields["num"..idx]) then
|
||||
rules[idx].num = fields["num"..idx]
|
||||
end
|
||||
if fields["act"..idx] ~= nil then
|
||||
rules[idx].act = kvAction[fields["act"..idx]]
|
||||
end
|
||||
end
|
||||
meta:set_string("rules", minetest.serialize(rules))
|
||||
|
||||
if fields.button ~= nil then
|
||||
if running > STOP_STATE then
|
||||
if fields.help ~= nil then
|
||||
meta:set_string("formspec", formspec_help())
|
||||
return
|
||||
end
|
||||
|
||||
local endless = meta:get_int("endless") or 0
|
||||
if fields.endless ~= nil then
|
||||
endless = fields.endless == "true" and 1 or 0
|
||||
meta:set_int("index", 1)
|
||||
end
|
||||
meta:set_int("endless", endless)
|
||||
|
||||
local rules = minetest.deserialize(meta:get_string("rules"))
|
||||
if fields.exit ~= nil then
|
||||
meta:set_string("formspec", formspec(tubelib.state(running), rules, endless))
|
||||
return
|
||||
end
|
||||
|
||||
for idx = 1,NUM_SLOTS do
|
||||
if fields["offs"..idx] ~= nil then
|
||||
rules[idx].offs = tonumber(fields["offs"..idx]) or ""
|
||||
end
|
||||
if fields["num"..idx] ~= nil and tubelib.check_numbers(fields["num"..idx]) then
|
||||
rules[idx].num = fields["num"..idx]
|
||||
end
|
||||
if fields["act"..idx] ~= nil then
|
||||
rules[idx].act = kvAction[fields["act"..idx]]
|
||||
end
|
||||
end
|
||||
meta:set_string("rules", minetest.serialize(rules))
|
||||
|
||||
if fields.button ~= nil then
|
||||
if running > STOP_STATE then
|
||||
stop_the_sequencer(pos)
|
||||
else
|
||||
start_the_sequencer(pos)
|
||||
end
|
||||
elseif fields.num1 ~= nil then -- any other change?
|
||||
stop_the_sequencer(pos)
|
||||
else
|
||||
start_the_sequencer(pos)
|
||||
local endless = meta:get_int("endless") or 0
|
||||
meta:set_string("formspec", formspec(tubelib.state(running), rules, endless))
|
||||
end
|
||||
elseif fields.num1 ~= nil then -- any other change?
|
||||
stop_the_sequencer(pos)
|
||||
else
|
||||
local endless = meta:get_int("endless") or 0
|
||||
meta:set_string("formspec", formspec(tubelib.state(running), rules, endless))
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -67,37 +67,40 @@ end
|
||||
|
||||
|
||||
local function check_rules(pos,elapsed)
|
||||
local hour = math.floor(minetest.get_timeofday() * 24)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local events = minetest.deserialize(meta:get_string("events"))
|
||||
local numbers = minetest.deserialize(meta:get_string("numbers"))
|
||||
local actions = minetest.deserialize(meta:get_string("actions"))
|
||||
local done = minetest.deserialize(meta:get_string("done"))
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
local number = meta:get_string("number")
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local hour = math.floor(minetest.get_timeofday() * 24)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local events = minetest.deserialize(meta:get_string("events"))
|
||||
local numbers = minetest.deserialize(meta:get_string("numbers"))
|
||||
local actions = minetest.deserialize(meta:get_string("actions"))
|
||||
local done = minetest.deserialize(meta:get_string("done"))
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
local number = meta:get_string("number")
|
||||
|
||||
-- check all rules
|
||||
for idx,act in ipairs(actions) do
|
||||
if act ~= "" and numbers[idx] ~= "" then
|
||||
local hr = (events[idx] - 1) * 2
|
||||
if ((hour - hr) % 24) <= 4 then -- last 4 hours?
|
||||
if done[idx] == false then -- not already executed?
|
||||
tubelib.send_message(numbers[idx], placer_name, nil, act, number)
|
||||
done[idx] = true
|
||||
-- check all rules
|
||||
for idx,act in ipairs(actions) do
|
||||
if act ~= "" and numbers[idx] ~= "" then
|
||||
local hr = (events[idx] - 1) * 2
|
||||
if ((hour - hr) % 24) <= 4 then -- last 4 hours?
|
||||
if done[idx] == false then -- not already executed?
|
||||
tubelib.send_message(numbers[idx], placer_name, nil, act, number)
|
||||
done[idx] = true
|
||||
end
|
||||
else
|
||||
done[idx] = false
|
||||
end
|
||||
else
|
||||
done[idx] = false
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
-- prepare for the next day
|
||||
if hour == 23 then
|
||||
done = {false,false,false,false,false,false}
|
||||
-- prepare for the next day
|
||||
if hour == 23 then
|
||||
done = {false,false,false,false,false,false}
|
||||
end
|
||||
meta:set_string("done", minetest.serialize(done))
|
||||
meta:set_string("infotext","Tubelib Timer "..hour..":00")
|
||||
return true
|
||||
end
|
||||
meta:set_string("done", minetest.serialize(done))
|
||||
meta:set_string("infotext","Tubelib Timer "..hour..":00")
|
||||
return true
|
||||
return false
|
||||
end
|
||||
|
||||
|
||||
|
@ -254,9 +254,12 @@ end
|
||||
|
||||
-- move items to the output slots
|
||||
local function keep_running(pos, elapsed)
|
||||
local meta = M(pos)
|
||||
distributing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
distributing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
|
@ -51,9 +51,12 @@ local function pushing(pos, meta)
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
local meta = M(pos)
|
||||
pushing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
pushing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
minetest.register_node("tubelib_addons3:pusher", {
|
||||
|
@ -90,33 +90,36 @@ local function configured(pos, item)
|
||||
end
|
||||
|
||||
local function shift_items(pos, elapsed)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local inv = meta:get_inventory()
|
||||
if not inv:is_empty("shift") then
|
||||
local number = meta:get_string("number")
|
||||
local player_name = meta:get_string("player_name")
|
||||
local offs = meta:get_int("offs")
|
||||
meta:set_int("offs", offs + 1)
|
||||
for i = 0,7 do
|
||||
local idx = ((i + offs) % 8) + 1
|
||||
local stack = inv:get_stack("shift", idx)
|
||||
if stack:get_count() > 0 then
|
||||
if tubelib.push_items(pos, "R", stack, player_name) then
|
||||
-- The effort is needed here for the case the
|
||||
-- pusher pushes into its own chest.
|
||||
local num = stack:get_count()
|
||||
stack = inv:get_stack("shift", idx)
|
||||
stack:take_item(num)
|
||||
inv:set_stack("shift", idx, stack)
|
||||
aging(pos, meta)
|
||||
return true
|
||||
else
|
||||
set_state(meta, "blocked")
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local inv = meta:get_inventory()
|
||||
if not inv:is_empty("shift") then
|
||||
local number = meta:get_string("number")
|
||||
local player_name = meta:get_string("player_name")
|
||||
local offs = meta:get_int("offs")
|
||||
meta:set_int("offs", offs + 1)
|
||||
for i = 0,7 do
|
||||
local idx = ((i + offs) % 8) + 1
|
||||
local stack = inv:get_stack("shift", idx)
|
||||
if stack:get_count() > 0 then
|
||||
if tubelib.push_items(pos, "R", stack, player_name) then
|
||||
-- The effort is needed here for the case the
|
||||
-- pusher pushes into its own chest.
|
||||
local num = stack:get_count()
|
||||
stack = inv:get_stack("shift", idx)
|
||||
stack:take_item(num)
|
||||
inv:set_stack("shift", idx, stack)
|
||||
aging(pos, meta)
|
||||
return true
|
||||
else
|
||||
set_state(meta, "blocked")
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
return true
|
||||
end
|
||||
return true
|
||||
return false
|
||||
end
|
||||
|
||||
local function formspec()
|
||||
|
Loading…
Reference in New Issue
Block a user