2019-12-15 08:28:34 -05:00

74 lines
2.0 KiB
Lua

-- LUALOCALS < ---------------------------------------------------------
local ipairs, math, minetest, nodecore, vector
= ipairs, math, minetest, nodecore, vector
local math_floor, math_random
= math.floor, math.random
-- LUALOCALS > ---------------------------------------------------------
local falling = {groups = {falling_node = true}}
local function fallcheck(name, start)
if not nodecore.interact(name) then return end
local target = vector.add(start, {
x = math_random() * 128 - 64,
y = math_random() * 128 - 64,
z = math_random() * 128 - 64
})
local pointed = minetest.raycast(start, target, false)()
if not pointed or not pointed.under then return end
local pos = pointed.under
local found = nodecore.find_nodes_around(pos, "group:falling_node", 2)
if #found < 1 then return end
pos = nodecore.pickrand(found)
local miny = pos.y - 64
pos.y = pos.y - 1
while pos.y >= miny and nodecore.match(pos, falling) do pos.y = pos.y - 1 end
if pos.y < miny then return end
pos.y = pos.y + 1
return minetest.check_for_falling(pos)
end
local function queuechecks(qty, name, pos)
if qty < 1 then return end
minetest.after(0, function()
for _ = 1, qty do
fallcheck(name, pos)
end
end)
end
local oldpos = {}
local qtys = {}
local function playercheck(dtime, player)
if not nodecore.interact(player) then return end
local name = player:get_player_name()
local pos = player:get_pos()
local old = oldpos[name] or pos
oldpos[name] = pos
if player:get_player_control().sneak or
not nodecore.player_visible(player) then return end
local q = (qtys[name] or 0)
+ vector.distance(pos, old) * 0.25
+ dtime * 0.05
queuechecks(math_floor(q), name, pos)
qtys[name] = q - math_floor(q)
end
minetest.register_globalstep(function(dtime)
for _, player in ipairs(minetest.get_connected_players()) do
playercheck(dtime, player)
end
end)
minetest.register_on_dignode(function(pos, _, digger)
local name = "(unknown)"
if digger and digger.get_player_name then name = digger:get_player_name() end
queuechecks(4, name, pos)
end)