Fix leafdecay along unloaded block boundaries

Also added separate check and variable for decaying default jungle leaves.
This commit is contained in:
Vanessa Ezekowitz 2013-10-17 17:48:49 -04:00
parent b320a7db8f
commit fa64297c09
2 changed files with 59 additions and 17 deletions

View File

@ -38,17 +38,25 @@ moretrees.enable_leafdecay = true
moretrees.enable_default_leafdecay = true moretrees.enable_default_leafdecay = true
-- Enable this one for default *jungle* leaves
moretrees.enable_default_jungle_leafdecay = true
-- Enable this if you want moretrees to redefine default apples so that they -- Enable this if you want moretrees to redefine default apples so that they
-- fall when leaves decay/are dug. -- fall when leaves decay/are dug.
moretrees.enable_redefine_apple = true moretrees.enable_redefine_apple = true
-- various settings to configure leaf decay in general. -- various settings to configure default and default-jungle leaf decay.
moretrees.leafdecay_delay = 2 moretrees.leafdecay_delay = 2
moretrees.leafdecay_chance = 100 moretrees.leafdecay_chance = 100
moretrees.leafdecay_radius = 5 moretrees.leafdecay_radius = 5
moretrees.default_jungle_leafdecay_delay = 2
moretrees.default_jungle_leafdecay_chance = 100
moretrees.default_jungle_leafdecay_radius = 5
moretrees.palm_leafdecay_radius = 15 moretrees.palm_leafdecay_radius = 15
moretrees.default_leafdecay_delay = 3 moretrees.default_leafdecay_delay = 3

View File

@ -1,5 +1,14 @@
-- leaf decay -- leaf decay
function clone_node(name)
node2={}
node=minetest.registered_nodes[name]
for k,v in pairs(node) do
node2[k]=v
end
return node2
end
if moretrees.enable_leafdecay then if moretrees.enable_leafdecay then
for i in ipairs(moretrees.treelist) do for i in ipairs(moretrees.treelist) do
local treename = moretrees.treelist[i][1] local treename = moretrees.treelist[i][1]
@ -9,11 +18,11 @@ if moretrees.enable_leafdecay then
interval = moretrees.leafdecay_delay, interval = moretrees.leafdecay_delay,
chance = moretrees.leafdecay_chance, chance = moretrees.leafdecay_chance,
action = function(pos, node, active_object_count, active_object_count_wider) action = function(pos, node, active_object_count, active_object_count_wider)
if not minetest.find_node_near(pos, moretrees.leafdecay_radius, "moretrees:"..treename.."_trunk") then if minetest.find_node_near(pos, moretrees.leafdecay_radius, "moretrees:"..treename.."_trunk") then return end
if minetest.find_node_near(pos, moretrees.leafdecay_radius, "ignore") then return end
minetest.remove_node(pos) minetest.remove_node(pos)
nodeupdate(pos) nodeupdate(pos)
end end
end
}) })
end end
end end
@ -23,11 +32,11 @@ if moretrees.enable_leafdecay then
interval = moretrees.leafdecay_delay, interval = moretrees.leafdecay_delay,
chance = moretrees.leafdecay_chance, chance = moretrees.leafdecay_chance,
action = function(pos, node, active_object_count, active_object_count_wider) action = function(pos, node, active_object_count, active_object_count_wider)
if not minetest.find_node_near(pos, moretrees.leafdecay_radius, {"default:jungletree", "moretrees:jungletree_trunk"}) then if minetest.find_node_near(pos, moretrees.leafdecay_radius, {"default:jungletree", "moretrees:jungletree_trunk"}) then return end
if minetest.find_node_near(pos, moretrees.leafdecay_radius, "ignore") then return end
minetest.remove_node(pos) minetest.remove_node(pos)
nodeupdate(pos) nodeupdate(pos)
end end
end
}) })
minetest.register_abm({ minetest.register_abm({
@ -35,11 +44,11 @@ if moretrees.enable_leafdecay then
interval = moretrees.leafdecay_delay, interval = moretrees.leafdecay_delay,
chance = moretrees.leafdecay_chance, chance = moretrees.leafdecay_chance,
action = function(pos, node, active_object_count, active_object_count_wider) action = function(pos, node, active_object_count, active_object_count_wider)
if not minetest.find_node_near(pos, moretrees.leafdecay_radius, "moretrees:fir_trunk") then if minetest.find_node_near(pos, moretrees.leafdecay_radius, "moretrees:fir_trunk") then return end
if minetest.find_node_near(pos, moretrees.leafdecay_radius, "ignore") then return end
minetest.remove_node(pos) minetest.remove_node(pos)
nodeupdate(pos) nodeupdate(pos)
end end
end
}) })
minetest.register_abm({ minetest.register_abm({
@ -47,24 +56,49 @@ if moretrees.enable_leafdecay then
interval = moretrees.leafdecay_delay, interval = moretrees.leafdecay_delay,
chance = moretrees.leafdecay_chance, chance = moretrees.leafdecay_chance,
action = function(pos, node, active_object_count, active_object_count_wider) action = function(pos, node, active_object_count, active_object_count_wider)
if not minetest.find_node_near(pos, moretrees.palm_leafdecay_radius, "moretrees:palm_trunk") then if minetest.find_node_near(pos, moretrees.palm_leafdecay_radius, "moretrees:palm_trunk") then return end
if minetest.find_node_near(pos, moretrees.palm_leafdecay_radius, "ignore") then return end
minetest.remove_node(pos) minetest.remove_node(pos)
nodeupdate(pos) nodeupdate(pos)
end end
end
}) })
end end
if moretrees.enable_default_leafdecay then if moretrees.enable_default_leafdecay then
new_default_leaves = clone_node("default:leaves")
new_default_leaves.groups = {snappy=3, flammable=2, leaves=1}
minetest.register_node(":default:leaves", new_default_leaves)
minetest.register_abm({ minetest.register_abm({
nodenames = "default:leaves", nodenames = "default:leaves",
interval = moretrees.default_leafdecay_delay, interval = moretrees.default_leafdecay_delay,
chance = moretrees.default_leafdecay_chance, chance = moretrees.default_leafdecay_chance,
action = function(pos, node, active_object_count, active_object_count_wider) action = function(pos, node, active_object_count, active_object_count_wider)
if not minetest.find_node_near(pos, moretrees.default_leafdecay_radius, {"default:tree"}) then if minetest.find_node_near(pos, moretrees.default_leafdecay_radius, "default:tree") then return end
if minetest.find_node_near(pos, moretrees.default_leafdecay_radius, "ignore") then return end
minetest.remove_node(pos) minetest.remove_node(pos)
nodeupdate(pos) nodeupdate(pos)
end end
})
end
if moretrees.enable_default_jungle_leafdecay then
new_default_jungle_leaves = clone_node("default:jungleleaves")
new_default_jungle_leaves.groups = {snappy=3, flammable=2, leaves=1}
minetest.register_node(":default:jungleleaves", new_default_jungle_leaves)
minetest.register_abm({
nodenames = "default:jungleleaves",
interval = moretrees.default_jungle_leafdecay_delay,
chance = moretrees.default_jungle_leafdecay_chance,
action = function(pos, node, active_object_count, active_object_count_wider)
if minetest.find_node_near(pos, moretrees.default_jungle_leafdecay_radius, "default:jungletree") then return end
if minetest.find_node_near(pos, moretrees.default_jungle_leafdecay_radius, "ignore") then return end
minetest.remove_node(pos)
nodeupdate(pos)
end end
}) })
end end