2020-09-11 17:20:21 -04:00

65 lines
2.0 KiB
Lua

-- LUALOCALS < ---------------------------------------------------------
local math, minetest, nodecore, pairs
= math, minetest, nodecore, pairs
local math_random
= math.random
-- LUALOCALS > ---------------------------------------------------------
local harden_to = {}
local harden_idx = {}
local soften_to = {}
minetest.after(0, function()
for _, v in pairs(minetest.registered_nodes) do
if v.strata then
for i, n in pairs(v.strata) do
harden_to[n] = v.strata[i + 1]
soften_to[n] = v.strata[i - 1]
harden_idx[n] = i
end
end
end
end)
local queue = {}
local function process(pos)
local water = #nodecore.find_nodes_around(pos, "group:water")
local lux = #nodecore.find_nodes_around(pos, "group:lux_fluid")
if water == lux then return end
local node = minetest.get_node(pos)
node.name = (water > lux and harden_to or soften_to)[node.name]
if not node.name then return end
local lava = #nodecore.find_nodes_around(pos, "group:lava")
if lava < 1 then return end
local fluid = water > lux and (water - lux) or (lux - water)
local chance = harden_idx[node.name] - (fluid > lava and fluid or lava) / 8
if (chance > 0) and (math_random() > (1/3) ^ chance) then return end
nodecore.log("action", (water > lux and "hardened" or "softened")
.. " to " .. node.name .. " at " .. minetest.pos_to_string(pos))
nodecore.witness(pos, "stone " .. (water > lux and "hardened" or "softened"))
return nodecore.set_loud(pos, node)
end
nodecore.register_globalstep("stone hardening", function()
for _, p in pairs(queue) do process(p) end
queue = {}
end)
nodecore.register_limited_abm({
label = "stone hardening",
nodenames = {"group:lava"},
neighbors = {"group:stone"},
interval = 10,
chance = 50,
action = function(pos)
if not minetest.find_node_near(pos, 2,
{"group:water", "group:lux_fluid"}) then return end
for _, p in pairs(nodecore.find_nodes_around(pos, "group:stone")) do
queue[minetest.hash_node_position(p)] = p
end
end
})