Add warning for long server timesteps, fix comparator-hopper interaction after rebase, disable mesecons dig/place updating redstone state, fix power flow on first couple of switch togglings, add traceback print to mesecon.receptor_{on,off}

This commit is contained in:
teknomunk 2024-04-28 13:04:07 +00:00
parent b67f2261ed
commit ef257f0131
6 changed files with 60 additions and 21 deletions

View file

@ -104,6 +104,10 @@ if false then
end
local function run_scheduler(dtime)
if dtime > 0.11 then
minetest.log("warning", "Timestep greater than 110ms("..tostring(math.floor(dtime*1000)).." ms), server lag detected")
end
local start_time = minetest_get_us_time()
local end_time = start_time + 50000
time = time + dtime

View file

@ -87,7 +87,23 @@ local function update_self(pos, node)
end
end
function mod.trigger_update(pos)
local node_readings = {}
function mod.trigger_update(pos, node)
local node = node or minetest.get_node(pos)
local nodedef = minetest.registered_nodes[node.name] or {}
-- If this position can't provide a comparator reading, we should
-- never trigger a comparator update
local get_reading = nodedef._mcl_comparators_get_reading
if not get_reading then return end
-- Only update if the reading has changed
local pos_hash = minetest.hash_node_position(pos)
local old_reading = node_readings[pos_hash]
local new_reading = get_reading(pos)
if old_reading == new_reading then return end
node_readings[pos_hash] = new_reading
-- try to find a comparator with the back rule leading to pos
for i = 1,#POSSIBLE_COMPARATOR_POSITIONS do
local candidate = vector.add(pos, POSSIBLE_COMPARATOR_POSITIONS[i])
@ -106,7 +122,7 @@ function mod.read_inventory(inv, inv_name)
for i=1,#stacks do
count = count + ( stacks[i]:get_count() / stacks[i]:get_stack_max() )
end
return math.floor(count * 16 / 5)
return math.floor(count * 16 / #stacks)
end
-- compute tile depending on state and mode

View file

@ -88,6 +88,7 @@ end)
function mesecon.receptor_on(pos, rules)
print("receptor_on(pos="..vector.to_string(pos)..",rules="..dump(rules))
print(debug.traceback())
--mesecon.queue:add_action(pos, "receptor_on", {rules}, nil, rules)
end
@ -116,6 +117,7 @@ end)
function mesecon.receptor_off(pos, rules)
print("receptor_off(pos="..vector.to_string(pos)..",rules="..dump(rules))
print(debug.traceback())
--mesecon.queue:add_action(pos, "receptor_off", {rules}, nil, rules)
end

View file

@ -2,6 +2,7 @@
function mesecon.on_placenode(pos, node)
mesecon.execute_autoconnect_hooks_now(pos, node)
--[[
-- Receptors: Send on signal when active
if mesecon.is_receptor_on(node.name) then
@ -68,6 +69,7 @@ function mesecon.on_placenode(pos, node)
end
end
end
]]
end
function mesecon.on_dignode(pos, node)
@ -103,7 +105,7 @@ function mesecon.on_blastnode(pos, node)
end
minetest.register_on_placenode(mesecon.on_placenode)
minetest.register_on_dignode(mesecon.on_dignode)
--minetest.register_on_dignode(mesecon.on_dignode)
-- Overheating service for fast circuits
local OVERHEAT_MAX = mesecon.setting("overheat_max", 8)

View file

@ -64,10 +64,10 @@ end
local function get_node_multipower_data(pos, no_create)
local hash = minetest_hash_node_pos(pos)
local node_multipower = multipower_cache[hash]
if not node_multipower and not no_create then
if not node_multipower then
local meta = minetest_get_meta(pos)
node_multipower = minetest_deserialize(meta:get_string("vl_redstone.multipower"))
if not node_multipower or node_multipower.version ~= 1 then
if not no_create and not node_multipower or node_multipower.version ~= 1 then
node_multipower = {
version = 1,
sources={}
@ -78,7 +78,7 @@ local function get_node_multipower_data(pos, no_create)
return node_multipower
end
local function calculate_driven_strength(pos, input_rules_hash)
local function calculate_driven_strength(pos, input_rules_hash, dir)
local dir_hash = dir and hash_from_direction(dir)
local node_multipower = get_node_multipower_data(pos)
local strength = 0
@ -117,8 +117,8 @@ local function calculate_driven_strength(pos, input_rules_hash)
return strength,HASH_REVERSES[strongest_direction_hash]
end
local function update_node(pos)
local node = mcl_util_force_get_node(pos)
local function update_node(pos, node)
local node = node or mcl_util_force_get_node(pos)
local nodedef = minetest.registered_nodes[node.name]
-- Only do this processing of signal sinks and conductors
@ -363,18 +363,24 @@ vl_scheduler.register_function("vl_redstone:flow_power",function(task, source_po
end
end)
function vl_redstone.set_power(pos, strength, delay)
function vl_redstone.set_power(pos, strength, delay, node)
-- Get existing multipower data, but don't create the data if the strength is zero
local no_create
if strength == 0 then no_create = true end
local node_multipower = get_node_multipower_data(pos, no_create)
if not node_multipower then return end
if not node_multipower then
print("No node multipower, no_create="..no_create)
return
end
-- Determine how far we need to trace conductors
local distance = node_multipower.drive_strength or 0
-- Don't perform an update if the power level is the same as before
if distance == strength then return end
if distance == strength then
print("Don't perform update distance="..tostring(distance)..",strength="..tostring(strength))
return
end
--print("previous="..tostring(distance)..", new="..tostring(strength))
@ -384,7 +390,7 @@ function vl_redstone.set_power(pos, strength, delay)
end
-- Schedule an update
vl_scheduler.add_task(delay or 0, "vl_redstone:flow_power", 2, {pos, strength, distance + 1})
vl_scheduler.add_task(delay or 0, "vl_redstone:flow_power", 2, {pos, strength, distance + 1, node})
end
function vl_redstone.get_power(pos)
@ -411,7 +417,7 @@ function vl_redstone.on_dignode(pos, node)
-- Node was dug, can't power anything
-- This doesn't work because the node is gone and we don't know what we were powering
-- TODO: get the rules here and use that for the first step
vl_redstone.set_power(pos, 0)
vl_redstone.set_power(pos, 0, nil, node)
end
-- Persist multipower data

View file

@ -34,6 +34,12 @@ local mcl_hoppers_formspec = table.concat({
"listring[current_player;main]",
})
local function get_reading(pos)
local meta = minetest.get_meta(pos)
local inv = meta:get_inventory()
return mcl_comparators.read_inventory(inv, "main")
end
local function straight_hopper_act(pos, node, active_object_count, active_count_wider)
local timer = minetest.get_node_timer(pos)
if timer:is_started() then
@ -52,9 +58,15 @@ local function straight_hopper_act(pos, node, active_object_count, active_count_
dst_def._mcl_hopper_act( dst_pos, dst_node, active_object_count, active_count_wider )
end
mcl_util.hopper_push(pos, dst_pos)
local pushed = mcl_util.hopper_push(pos, dst_pos)
local src_pos = vector.offset(pos, 0, 1, 0)
mcl_util.hopper_pull(pos, src_pos)
local pulled = mcl_util.hopper_pull(pos, src_pos)
if pushed or pulled then mcl_comparators.trigger_update(pos) end
-- Update comparators
mcl_comparators.trigger_update(pos, node)
end
local function bent_hopper_act(pos, node, active_object_count, active_object_count_wider)
@ -94,6 +106,9 @@ local function bent_hopper_act(pos, node, active_object_count, active_object_cou
local src_pos = vector.offset(pos, 0, 1, 0)
mcl_util.hopper_pull(pos, src_pos)
-- Update comparators
mcl_comparators.trigger_update(pos, node)
end
--[[
@ -188,12 +203,6 @@ local function hopper_pull_from_mc(mc_ent, dest_pos, inv_size)
end
mcl_hoppers.pull_from_minecart = hopper_pull_from_mc
local function get_reading(pos)
local meta = minetest.get_meta(pos)
local inv = meta:get_inventory()
return mcl_comparators.read_inventory(inv, "main")
end
-- Downwards hopper (base definition)
---@type node_definition