summaryrefslogtreecommitdiff
path: root/moretrees
diff options
context:
space:
mode:
Diffstat (limited to 'moretrees')
-rw-r--r--moretrees/cocos_palm.lua10
-rw-r--r--moretrees/date_palm.lua18
-rw-r--r--moretrees/init.lua16
-rw-r--r--moretrees/saplings.lua79
4 files changed, 64 insertions, 59 deletions
diff --git a/moretrees/cocos_palm.lua b/moretrees/cocos_palm.lua
index 8dea25f..391819b 100644
--- a/moretrees/cocos_palm.lua
+++ b/moretrees/cocos_palm.lua
@@ -28,7 +28,7 @@ ftrunk.after_destruct = function(pos, oldnode)
-- minetest.dig_node(coconutpos) does not cause nearby coconuts to be dropped :-( ...
--minetest.dig_node(coconutpos)
local items = minetest.get_node_drops(minetest.get_node(coconutpos).name)
- minetest.remove_node(coconutpos)
+ minetest.swap_node(coconutpos, biome_lib.air)
for _, itemname in pairs(items) do
minetest.add_item(coconutpos, itemname)
end
@@ -56,7 +56,7 @@ local coconut_regrow_abm_spec = {
local coconutpos = {x=pos.x+dx, y=pos.y, z=pos.z+dz}
local coconutnode = minetest.get_node(coconutpos)
if coconutnode.name == "air" then
- minetest.set_node(coconutpos, {name="moretrees:coconut_0"})
+ minetest.swap_node(coconutpos, {name="moretrees:coconut_0"})
end
end
end
@@ -85,7 +85,7 @@ minetest.register_abm({
local gen
local count = 0
for _,gen in pairs(genlist) do
- minetest.set_node(gen.pos, {name = "moretrees:coconut_3"})
+ minetest.swap_node(gen.pos, {name = "moretrees:coconut_3"})
count = count + 1
if count == 4 then
break
@@ -115,7 +115,7 @@ local coconut_growfn = function(pos, elapsed)
minetest.add_item(pos, itemname)
end
end
- minetest.remove_node(pos)
+ minetest.swap_node(pos, biome_lib.air)
end
else
-- Grow coconuts to the next stage
@@ -240,7 +240,7 @@ if moretrees.coconuts_convert_existing_palms then
minetest.swap_node(tpos, {name = "moretrees:palm_fruit_trunk"})
coconuts = minetest.find_nodes_in_area({x=tpos.x-1, y=tpos.y, z=tpos.z-1}, {x=tpos.x+1, y=tpos.y, z=tpos.z+1}, "moretrees:coconut")
for _, coconutpos in pairs(coconuts) do
- minetest.set_node(coconutpos, {name = "moretrees:coconut_3"})
+ minetest.swap_node(coconutpos, {name = "moretrees:coconut_3"})
end
end
end,
diff --git a/moretrees/date_palm.lua b/moretrees/date_palm.lua
index f8b3e42..6e6cc4b 100644
--- a/moretrees/date_palm.lua
+++ b/moretrees/date_palm.lua
@@ -49,7 +49,7 @@ ftrunk.after_destruct = function(pos, oldnode)
for _,datespos in pairs(dates) do
-- minetest.dig_node(datespos) does not cause nearby dates to be dropped :-( ...
local items = minetest.get_node_drops(minetest.get_node(datespos).name)
- minetest.remove_node(datespos)
+ minetest.swap_node(datespos, biome_lib.air)
for _, itemname in pairs(items) do
minetest.add_item(datespos, itemname)
end
@@ -92,9 +92,9 @@ local date_regrow_abm_spec = {
local datenode = minetest.get_node(datepos)
if datenode.name == "air" then
if node.name == "moretrees:date_palm_ffruit_trunk" then
- minetest.set_node(datepos, {name="moretrees:dates_f0"})
+ minetest.swap_node(datepos, {name="moretrees:dates_f0"})
else
- minetest.set_node(datepos, {name="moretrees:dates_m0"})
+ minetest.swap_node(datepos, {name="moretrees:dates_m0"})
end
end
end
@@ -126,9 +126,9 @@ minetest.register_abm({
for _,genpos in pairs(dates1) do
if math.random(100) <= 20 then
if type == "m" then
- minetest.set_node(genpos, {name = "moretrees:dates_n"})
+ minetest.swap_node(genpos, {name = "moretrees:dates_n"})
else
- minetest.set_node(genpos, {name = "moretrees:dates_f4"})
+ minetest.swap_node(genpos, {name = "moretrees:dates_f4"})
end
end
end
@@ -136,9 +136,9 @@ minetest.register_abm({
for _,genpos in pairs(dates2) do
if math.random(100) <= 5 then
if type == "m" then
- minetest.set_node(genpos, {name = "moretrees:dates_n"})
+ minetest.swap_node(genpos, {name = "moretrees:dates_n"})
else
- minetest.set_node(genpos, {name = "moretrees:dates_f4"})
+ minetest.swap_node(genpos, {name = "moretrees:dates_f4"})
end
end
end
@@ -538,7 +538,7 @@ local dates_growfn = function(pos, elapsed)
elseif string.find(node.name, "moretrees:dates_m") then
minetest.swap_node(pos, {name="moretrees:dates_n"})
else
- minetest.remove_node(pos)
+ minetest.swap_node(pos, biome_lib.air)
end
return
elseif node.name == "moretrees:dates_f0" and math.random(100) <= 100 * dates_regrow_prob then
@@ -578,7 +578,7 @@ local dates_growfn = function(pos, elapsed)
elseif string.match(node.name, "n$") then
-- Remove stems.
if math.random(stems_drop_ichance) == 1 then
- minetest.remove_node(pos)
+ minetest.swap_node(pos, biome_lib.air)
return "stemdrop"
end
action = "nostemdrop"
diff --git a/moretrees/init.lua b/moretrees/init.lua
index f3f840f..6bad705 100644
--- a/moretrees/init.lua
+++ b/moretrees/init.lua
@@ -185,7 +185,7 @@ end
-- Code to spawn a birch tree
function moretrees.grow_birch(pos)
- minetest.remove_node(pos)
+ minetest.swap_node(pos, biome_lib.air)
if math.random(1,2) == 1 then
minetest.spawn_tree(pos, moretrees.birch_model1)
else
@@ -196,7 +196,7 @@ end
-- Code to spawn a spruce tree
function moretrees.grow_spruce(pos)
- minetest.remove_node(pos)
+ minetest.swap_node(pos, biome_lib.air)
if math.random(1,2) == 1 then
minetest.spawn_tree(pos, moretrees.spruce_model1)
else
@@ -250,10 +250,10 @@ function moretrees.grow_jungletree(pos)
moretrees.jungletree_model.rules_b = moretrees.jt_rules_b2
end
- minetest.remove_node(pos)
+ minetest.swap_node(pos, biome_lib.air)
local leaves = minetest.find_nodes_in_area({x = pos.x-1, y = pos.y, z = pos.z-1}, {x = pos.x+1, y = pos.y+10, z = pos.z+1}, "default:leaves")
for leaf in ipairs(leaves) do
- minetest.remove_node(leaves[leaf])
+ minetest.swap_node(leaves[leaf], biome_lib.air)
end
minetest.spawn_tree(pos, moretrees.jungletree_model)
end
@@ -277,10 +277,10 @@ function moretrees.grow_fir(pos)
moretrees.fir_model.iterations = 7
moretrees.fir_model.random_level = 5
- minetest.remove_node(pos)
+ minetest.swap_node(pos, biome_lib.air)
local leaves = minetest.find_nodes_in_area({x = pos.x, y = pos.y, z = pos.z}, {x = pos.x, y = pos.y+5, z = pos.z}, "default:leaves")
for leaf in ipairs(leaves) do
- minetest.remove_node(leaves[leaf])
+ minetest.swap_node(leaves[leaf], biome_lib.air)
end
minetest.spawn_tree(pos,moretrees.fir_model)
end
@@ -304,10 +304,10 @@ function moretrees.grow_fir_snow(pos)
moretrees.fir_model.iterations = 2
moretrees.fir_model.random_level = 2
- minetest.remove_node(pos)
+ minetest.swap_node(pos, biome_lib.air)
local leaves = minetest.find_nodes_in_area({x = pos.x, y = pos.y, z = pos.z}, {x = pos.x, y = pos.y+5, z = pos.z}, "default:leaves")
for leaf in ipairs(leaves) do
- minetest.remove_node(leaves[leaf])
+ minetest.swap_node(leaves[leaf], biome_lib.air)
end
minetest.spawn_tree(pos,moretrees.fir_model)
end
diff --git a/moretrees/saplings.lua b/moretrees/saplings.lua
index 8004612..bd20988 100644
--- a/moretrees/saplings.lua
+++ b/moretrees/saplings.lua
@@ -16,13 +16,15 @@ for i in ipairs(moretrees.treelist) do
grow_function = moretrees[tree_model],
})
- biome_lib:grow_plants({
- grow_delay = 2,
- grow_chance = 30,
- grow_plant = "moretrees:"..treename.."_sapling_ongen",
- grow_nodes = moretrees[tree_biome].surface,
- grow_function = moretrees[tree_model],
- })
+ if moretrees.spawn_saplings then
+ biome_lib:grow_plants({
+ grow_delay = 2,
+ grow_chance = 30,
+ grow_plant = "moretrees:"..treename.."_sapling_ongen",
+ grow_nodes = moretrees[tree_biome].surface,
+ grow_function = moretrees[tree_model],
+ })
+ end
end
end
@@ -35,13 +37,6 @@ biome_lib:grow_plants({
grow_function = "moretrees.grow_birch"
})
-biome_lib:grow_plants({
- grow_delay = 2,
- grow_chance = 30,
- grow_plant = "moretrees:birch_sapling_ongen",
- grow_nodes = moretrees.birch_biome.surface,
- grow_function = "moretrees.grow_birch"
-})
biome_lib:grow_plants({
grow_delay = moretrees.sapling_interval,
@@ -52,14 +47,6 @@ biome_lib:grow_plants({
})
biome_lib:grow_plants({
- grow_delay = 2,
- grow_chance = 30,
- grow_plant = "moretrees:spruce_sapling_ongen",
- grow_nodes = moretrees.spruce_biome.surface,
- grow_function = "moretrees.grow_spruce"
-})
-
-biome_lib:grow_plants({
grow_delay = moretrees.sapling_interval,
grow_chance = moretrees.sapling_chance,
grow_plant = "moretrees:fir_sapling",
@@ -68,14 +55,6 @@ biome_lib:grow_plants({
})
biome_lib:grow_plants({
- grow_delay = 2,
- grow_chance = 30,
- grow_plant = "moretrees:fir_sapling_ongen",
- grow_nodes = moretrees.fir_biome.surface,
- grow_function = "moretrees.grow_fir"
-})
-
-biome_lib:grow_plants({
grow_delay = moretrees.sapling_interval,
grow_chance = moretrees.sapling_chance,
grow_plant = "default:junglesapling",
@@ -83,11 +62,37 @@ biome_lib:grow_plants({
grow_function = "moretrees.grow_jungletree"
})
-biome_lib:grow_plants({
- grow_delay = 2,
- grow_chance = 30,
- grow_plant = "moretrees:jungletree_sapling_ongen",
- grow_nodes = moretrees.jungletree_biome.surface,
- grow_function = "moretrees.grow_jungletree"
-})
+if moretrees.spawn_saplings then
+ biome_lib:grow_plants({
+ grow_delay = 2,
+ grow_chance = 30,
+ grow_plant = "moretrees:jungletree_sapling_ongen",
+ grow_nodes = moretrees.jungletree_biome.surface,
+ grow_function = "moretrees.grow_jungletree"
+ })
+
+ biome_lib:grow_plants({
+ grow_delay = 2,
+ grow_chance = 30,
+ grow_plant = "moretrees:fir_sapling_ongen",
+ grow_nodes = moretrees.fir_biome.surface,
+ grow_function = "moretrees.grow_fir"
+ })
+
+ biome_lib:grow_plants({
+ grow_delay = 2,
+ grow_chance = 30,
+ grow_plant = "moretrees:spruce_sapling_ongen",
+ grow_nodes = moretrees.spruce_biome.surface,
+ grow_function = "moretrees.grow_spruce"
+ })
+
+ biome_lib:grow_plants({
+ grow_delay = 2,
+ grow_chance = 30,
+ grow_plant = "moretrees:birch_sapling_ongen",
+ grow_nodes = moretrees.birch_biome.surface,
+ grow_function = "moretrees.grow_birch"
+ })
+end