2019-01-05 23:11:38 -05:00
|
|
|
-- LUALOCALS < ---------------------------------------------------------
|
2019-10-06 09:26:18 -04:00
|
|
|
local ipairs, math, minetest, nodecore
|
|
|
|
= ipairs, math, minetest, nodecore
|
|
|
|
local math_sqrt
|
|
|
|
= math.sqrt
|
2019-01-05 23:11:38 -05:00
|
|
|
-- LUALOCALS > ---------------------------------------------------------
|
|
|
|
|
|
|
|
nodecore.register_leaf_drops, nodecore.registered_leaf_drops
|
|
|
|
= nodecore.mkreg()
|
|
|
|
|
2019-08-27 19:14:51 -04:00
|
|
|
function nodecore.leaf_decay(pos, node)
|
2019-01-05 23:11:38 -05:00
|
|
|
node = node or minetest.get_node(pos)
|
|
|
|
local t = {}
|
2019-08-31 09:26:53 -04:00
|
|
|
for _, v in ipairs(nodecore.registered_leaf_drops) do
|
2019-01-05 23:11:38 -05:00
|
|
|
t = v(pos, node, t) or t
|
|
|
|
end
|
|
|
|
local p = nodecore.pickrand(t, function(x) return x.prob end)
|
|
|
|
if not p then return end
|
|
|
|
minetest.set_node(pos, p)
|
2019-01-29 20:41:29 -05:00
|
|
|
if p.item then nodecore.item_eject(pos, p.item) end
|
2019-09-09 07:05:01 -04:00
|
|
|
return nodecore.fallcheck(pos)
|
2019-01-05 23:11:38 -05:00
|
|
|
end
|
2019-10-06 09:26:18 -04:00
|
|
|
|
2019-10-19 11:00:18 -04:00
|
|
|
function nodecore.tree_soil_rate(pos)
|
2019-10-06 09:26:18 -04:00
|
|
|
local d = 1
|
|
|
|
local w = 1
|
|
|
|
nodecore.scan_flood(pos, 3, function(p, r)
|
|
|
|
if r < 1 then return end
|
|
|
|
local nn = minetest.get_node(p).name
|
|
|
|
local def = minetest.registered_items[nn] or {}
|
|
|
|
if not def.groups then
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
if def.groups.soil then
|
|
|
|
d = d + def.groups.soil
|
|
|
|
w = w + 0.2
|
|
|
|
elseif def.groups.moist then
|
|
|
|
w = w + def.groups.moist
|
|
|
|
return false
|
|
|
|
else
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
end)
|
|
|
|
return math_sqrt(d * w)
|
|
|
|
end
|
2019-10-19 11:00:18 -04:00
|
|
|
|
|
|
|
function nodecore.tree_growth_rate(pos)
|
|
|
|
local above = {x = pos.x, y = pos.y + 1, z = pos.z}
|
|
|
|
if minetest.get_node(above).name ~= "air" then return end
|
|
|
|
local ll = minetest.get_node_light(above, 0.5)
|
|
|
|
if (not ll) or (ll < 8) then return end
|
|
|
|
for y = 2, 5 do
|
|
|
|
local p ={x = pos.x, y = pos.y + y, z = pos.z}
|
|
|
|
if minetest.get_node(p).name ~= "air" then return end
|
|
|
|
end
|
|
|
|
return nodecore.tree_soil_rate(pos) * math_sqrt((ll - 7) / 8)
|
|
|
|
end
|