mirror of
https://github.com/mt-mods/biome_lib.git
synced 2025-01-12 11:00:29 +01:00
rather than copy the re-check log back into the block log when it comes
time to run through it, just use it in-place, copying its entries back to the main block log if they have to be skipped again (essentially using the re-check list and the end of the block log as a double buffer)
This commit is contained in:
parent
e346fd599f
commit
531577afcf
46
init.lua
46
init.lua
@ -440,23 +440,51 @@ local function confirm_block_surroundings(p)
|
|||||||
end
|
end
|
||||||
|
|
||||||
biome_lib.block_recheck_list = {}
|
biome_lib.block_recheck_list = {}
|
||||||
|
biome_lib.run_block_recheck_list = false
|
||||||
|
|
||||||
function biome_lib.generate_block(shutting_down)
|
function biome_lib.generate_block(shutting_down)
|
||||||
if not biome_lib.block_log[1] then return end -- the block log is empty
|
|
||||||
|
|
||||||
local minp = biome_lib.block_log[1][1]
|
if shutting_down then
|
||||||
local maxp = biome_lib.block_log[1][2]
|
if #biome_lib.block_recheck_list > 0 then
|
||||||
local airflag = biome_lib.block_log[1][3]
|
for i = 1, #biome_lib.block_recheck_list do
|
||||||
|
biome_lib.block_log[#biome_lib.block_log + 1] = biome_lib.block_recheck_list[i]
|
||||||
|
end
|
||||||
|
biome_lib.block_recheck_list = {}
|
||||||
|
end
|
||||||
|
biome_lib.run_block_recheck_list = false
|
||||||
|
else
|
||||||
|
if biome_lib.run_block_recheck_list
|
||||||
|
and not biome_lib.block_recheck_list[1] then
|
||||||
|
biome_lib.run_block_recheck_list = false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local blocklog = biome_lib.run_block_recheck_list
|
||||||
|
and biome_lib.block_recheck_list
|
||||||
|
or biome_lib.block_log
|
||||||
|
|
||||||
|
if not blocklog[1] then return end
|
||||||
|
|
||||||
|
local minp = blocklog[1][1]
|
||||||
|
local maxp = blocklog[1][2]
|
||||||
|
local airflag = blocklog[1][3]
|
||||||
local pos_hash = minetest.hash_node_position(minp)
|
local pos_hash = minetest.hash_node_position(minp)
|
||||||
|
|
||||||
if not biome_lib.pos_hash then -- we need to read the maplock and get the surfaces list
|
if not biome_lib.pos_hash then -- we need to read the maplock and get the surfaces list
|
||||||
biome_lib.pos_hash = {}
|
biome_lib.pos_hash = {}
|
||||||
if not confirm_block_surroundings(minp) and not shutting_down then -- if any neighbors appear not to be loaded, move this block to the end of the queue
|
if not confirm_block_surroundings(minp)
|
||||||
biome_lib.block_recheck_list[#biome_lib.block_recheck_list + 1] = table.copy(biome_lib.block_log[1])
|
and not shutting_down then -- if any neighbors appear not to be loaded, skip this block for now
|
||||||
table.remove(biome_lib.block_log, 1)
|
|
||||||
|
if biome_lib.run_block_recheck_list then
|
||||||
|
biome_lib.block_log[#biome_lib.block_log + 1] = table.copy(biome_lib.block_recheck_list[1])
|
||||||
|
table.remove(biome_lib.block_recheck_list, 1)
|
||||||
|
else
|
||||||
|
biome_lib.block_recheck_list[#biome_lib.block_recheck_list + 1] = table.copy(biome_lib.block_log[1])
|
||||||
|
table.remove(biome_lib.block_log, 1)
|
||||||
|
end
|
||||||
biome_lib.pos_hash = nil
|
biome_lib.pos_hash = nil
|
||||||
biome_lib:dbg("Mapblock at "..minetest.pos_to_string(minp)..
|
biome_lib:dbg("Mapblock at "..minetest.pos_to_string(minp)..
|
||||||
" had a neighbor not fully emerged, moved it to the \"check-later\" list.")
|
" had a neighbor not fully emerged, skipped it for now.")
|
||||||
return
|
return
|
||||||
else
|
else
|
||||||
biome_lib.pos_hash.surface_node_list = airflag
|
biome_lib.pos_hash.surface_node_list = airflag
|
||||||
@ -475,7 +503,7 @@ function biome_lib.generate_block(shutting_down)
|
|||||||
if #biome_lib.pos_hash.surface_node_list > 0 then
|
if #biome_lib.pos_hash.surface_node_list > 0 then
|
||||||
biome_lib:dbg("Deleted mapblock "..minetest.pos_to_string(minp).." from the block log")
|
biome_lib:dbg("Deleted mapblock "..minetest.pos_to_string(minp).." from the block log")
|
||||||
end
|
end
|
||||||
table.remove(biome_lib.block_log, 1)
|
table.remove(blocklog, 1)
|
||||||
biome_lib.pos_hash = nil
|
biome_lib.pos_hash = nil
|
||||||
else
|
else
|
||||||
-- below, [1] is biome, [2] is the thing to be added
|
-- below, [1] is biome, [2] is the thing to be added
|
||||||
|
@ -70,10 +70,5 @@ minetest.register_on_generated(function(minp, maxp, blockseed)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if #biome_lib.block_recheck_list > 0 then
|
biome_lib.run_block_recheck_list = true
|
||||||
for i = 1, #biome_lib.block_recheck_list do
|
|
||||||
biome_lib.block_log[#biome_lib.block_log + 1] = table.copy(biome_lib.block_recheck_list[i])
|
|
||||||
end
|
|
||||||
end
|
|
||||||
biome_lib.block_recheck_list = {}
|
|
||||||
end)
|
end)
|
||||||
|
Loading…
Reference in New Issue
Block a user