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:
parent
07f426ae45
commit
a8491ae232
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user