1
0
mirror of https://github.com/mt-mods/plantlife_modpack.git synced 2025-01-12 18:30:21 +01:00

added some code to further trim the number of nodes that have to be checked.

This causes trees to be just a tad more sparse than intended, but greatly
speeds up the map generator.

Worst case drops from thousands of nodes to test per tree type to a 5-15 nodes
per tree type.
This commit is contained in:
Vanessa Ezekowitz 2013-01-21 23:41:02 -05:00
parent 07f426ae45
commit a8491ae232

View File

@ -63,6 +63,7 @@ function plantslib:search_for_surfaces(minp, maxp, biome, funct_or_model)
if biome.temp_min == nil then biome.temp_min = 1 end if biome.temp_min == nil then biome.temp_min = 1 end
if biome.temp_max == nil then biome.temp_max = -1 end if biome.temp_max == nil then biome.temp_max = -1 end
if biome.rarity == nil then biome.rarity = 50 end if biome.rarity == nil then biome.rarity = 50 end
if biome.max_count == nil then biome.max_count = 5 end
plantslib:dbg("Started checking generated mapblock volume...") plantslib:dbg("Started checking generated mapblock volume...")
local searchnodes = minetest.env:find_nodes_in_area(minp, maxp, biome.surface) local searchnodes = minetest.env:find_nodes_in_area(minp, maxp, biome.surface)
@ -91,19 +92,32 @@ function plantslib:search_for_surfaces(minp, maxp, biome, funct_or_model)
end end
end end
plantslib:dbg("Found "..num_in_biome_nodes.." surface nodes of type "..biome.surface.." in 5x5x5 mapblock volume at {"..dump(minp)..":"..dump(maxp).."} to check.") if num_in_biome_nodes > 0 then
plantslib:dbg("Found "..num_in_biome_nodes.." surface nodes of type "..biome.surface.." in 5x5x5 mapblock volume at {"..dump(minp)..":"..dump(maxp).."} to check.")
for i in ipairs(in_biome_nodes) do for i = 1,biome.max_count do
local pos = in_biome_nodes[i] local tries = 0
local p_top = { x = pos.x, y = pos.y + 1, z = pos.z } local spawned = false
if minetest.env:find_node_near(p_top, biome.avoid_radius + math.random(-1.5,1.5), biome.avoid_nodes) == nil then while tries < 2 and not planted do
if type(funct_or_model) == "table" then local pos = in_biome_nodes[math.random(1, num_in_biome_nodes)]
plantslib:dbg("Spawn tree at {"..dump(pos).."}") local p_top = { x = pos.x, y = pos.y + 1, z = pos.z }
minetest.env:spawn_tree(pos, funct_or_model) if minetest.env:find_node_near(p_top, biome.avoid_radius + math.random(-1.5,1.5), biome.avoid_nodes) == nil then
else spawned = true
plantslib:dbg("Call function: "..funct_or_model.."("..dump(pos)..")") if type(funct_or_model) == "table" then
plantslib:dbg("Call function: "..funct_or_model.."("..dump(pos)..")") plantslib:dbg("Spawn tree at {"..dump(pos).."}")
assert(loadstring(funct_or_model.."("..dump(pos)..")"))() minetest.env:spawn_tree(pos, funct_or_model)
else
plantslib:dbg("Call function: "..funct_or_model.."("..dump(pos)..")")
plantslib:dbg("Call function: "..funct_or_model.."("..dump(pos)..")")
assert(loadstring(funct_or_model.."("..dump(pos)..")"))()
end
else
tries = tries + 1
spawned = false
plantslib:dbg("Couldn't spawn a tree at {"..dump(pos).."} -- trying again elsewhere")
end
end
if tries == 2 and spawned == false then
plantslib:dbg("Unable to spawn that tree. Giving up on it.")
end end
end end
end end