166cfe5f14
The problem was pointed out by Josh (gitlab.com/krazy-j) in merge request !22. Apparently MT is not very smart about marking mapblocks dirty to send to clients based on calling mt.set_node(), i.e. it will mark them dirty presumptively even if you set the node to the same value it had already been. This behavior can be confirmed by registering an ABM against a common node like grass and setting action = minetest.set_node. This causes every mapblock containing that node to be invalidated every interval, causing a big spike in the packets received each interval that you can clearly see on the F5 graph. Rather than just fixing it for the most easily observed case (fire checks), add utlity functions to check this for ALL node change situations, and apply it more or less universally anywhere that we are not certain that the node is being changed and we don't need to worry about the extra overhead cost of the check. Note that we don't need a nodecore.set_loud_check call, as set_loud was only ever being used already in cases where we were pretty sure we were actually changing a node.
84 lines
2.2 KiB
Lua
84 lines
2.2 KiB
Lua
-- LUALOCALS < ---------------------------------------------------------
|
|
local minetest, nodecore, pairs, vector
|
|
= minetest, nodecore, pairs, vector
|
|
-- LUALOCALS > ---------------------------------------------------------
|
|
|
|
local modname = minetest.get_current_modname()
|
|
|
|
local wetdef = {
|
|
description = "Flux",
|
|
tiles = {modname .. "_base.png^[opacity:64"},
|
|
special_tiles = {modname .. "_base.png^[opacity:64", modname .. "_base.png^[opacity:64"},
|
|
use_texture_alpha = "blend",
|
|
paramtype = "light",
|
|
liquid_viscosity = 0,
|
|
liquid_renewable = false,
|
|
liquid_range = 2,
|
|
liquid_alternative_flowing = modname .. ":flux_flowing",
|
|
liquid_alternative_source = modname .. ":flux_source",
|
|
pointable = false,
|
|
walkable = false,
|
|
buildable_to = true,
|
|
light_source = 10,
|
|
sunlight_propagates = true,
|
|
air_pass = true,
|
|
drowning = 0,
|
|
groups = {
|
|
lux_emit = 16,
|
|
lux_fluid = 1
|
|
},
|
|
post_effect_color = {a = 64, r = 251, g = 241, b = 143}
|
|
}
|
|
minetest.register_node(modname .. ":flux_source", nodecore.underride({
|
|
drawtype = "liquid",
|
|
liquidtype = "source"
|
|
}, wetdef))
|
|
minetest.register_node(modname .. ":flux_flowing", nodecore.underride({
|
|
drawtype = "flowingliquid",
|
|
liquidtype = "flowing",
|
|
paramtype2 = "flowingliquid"
|
|
}, wetdef))
|
|
|
|
local outdirs = {}
|
|
for _, v in pairs(nodecore.dirs()) do
|
|
if v.y <= 0 then
|
|
outdirs[#outdirs + 1] = v
|
|
end
|
|
end
|
|
minetest.register_abm({
|
|
label = "lux flow leak",
|
|
interval = 1,
|
|
chance = 2,
|
|
nodenames = {"group:lux_cobble_max"},
|
|
action = function(pos)
|
|
for _, v in pairs(outdirs) do
|
|
local p = vector.add(pos, v)
|
|
if nodecore.buildable_to(p) then
|
|
nodecore.set_node_check(p, {name = modname .. ":flux_source"})
|
|
end
|
|
end
|
|
end
|
|
})
|
|
|
|
local indirs = {}
|
|
for _, v in pairs(nodecore.dirs()) do
|
|
if v.y >= 0 then
|
|
indirs[#indirs + 1] = v
|
|
end
|
|
end
|
|
minetest.register_abm({
|
|
label = "lux flow ebb",
|
|
interval = 1,
|
|
chance = 2,
|
|
nodenames = {modname .. ":flux_source"},
|
|
arealoaded = 1,
|
|
action = function(pos)
|
|
for _, v in pairs(indirs) do
|
|
local p = vector.add(pos, v)
|
|
local def = minetest.registered_nodes[minetest.get_node(p).name]
|
|
if def and def.groups and def.groups.lux_cobble_max then return end
|
|
end
|
|
return minetest.set_node(pos, {name = modname .. ":flux_flowing", param2 = 7})
|
|
end
|
|
})
|