forked from Mirrorlandia_minetest/mod-sneeker
Add debugging output in case of denied spawn
This commit is contained in:
parent
ea60b5fe9b
commit
8485715aba
80
spawn.lua
80
spawn.lua
@ -17,50 +17,56 @@ minetest.register_abm({
|
|||||||
interval = spawn_interval,
|
interval = spawn_interval,
|
||||||
chance = spawn_chance,
|
chance = spawn_chance,
|
||||||
action = function(pos, node, _, active_object_count_wider)
|
action = function(pos, node, _, active_object_count_wider)
|
||||||
|
local spawnit = true
|
||||||
|
|
||||||
if active_object_count_wider > 5 then
|
if active_object_count_wider > 5 then
|
||||||
return
|
spawnit = false
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Check light value of node
|
if spawnit then
|
||||||
pos.y = pos.y+1
|
-- Check light value of node
|
||||||
local node_light = minetest.get_node_light(pos)
|
pos.y = pos.y+1
|
||||||
|
local node_light = minetest.get_node_light(pos)
|
||||||
|
|
||||||
-- Debugging spawning
|
-- Debugging spawning
|
||||||
sneeker.log_debug('Node light level at ' .. tostring(pos.x) .. ',' .. tostring(pos.y) .. ': ' .. tostring(node_light))
|
sneeker.log_debug('Node light level at ' .. tostring(pos.x) .. ',' .. tostring(pos.y) .. ': ' .. tostring(node_light))
|
||||||
|
|
||||||
if not node_light then
|
if not node_light or node_light > sneeker.spawn_maxlight or node_light < -1 then
|
||||||
return
|
spawnit = false
|
||||||
end
|
end
|
||||||
if node_light > sneeker.spawn_maxlight then
|
|
||||||
return
|
-- Spawn range
|
||||||
end
|
if pos.y > 31000 then
|
||||||
if node_light < -1 then
|
spawnit = false
|
||||||
return
|
end
|
||||||
|
|
||||||
|
-- Node must be touching air
|
||||||
|
if minetest.get_node(pos).name ~= 'air' then
|
||||||
|
spawnit = false
|
||||||
|
end
|
||||||
|
pos.y = pos.y+1
|
||||||
|
if minetest.get_node(pos).name ~= 'air' then
|
||||||
|
spawnit = false
|
||||||
|
end
|
||||||
|
|
||||||
|
if spawnit then
|
||||||
|
-- Get total count of sneekers in world
|
||||||
|
local name, count
|
||||||
|
for name in pairs(minetest.luaentities) do
|
||||||
|
if name == sneeker.mob_name then
|
||||||
|
count = count + 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if count >= sneeker.spawn_cap then
|
||||||
|
spawnit = false -- Max sneekers already exist
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Spawn range
|
if spawnit then
|
||||||
if pos.y > 31000 then
|
sneeker.spawn(pos)
|
||||||
return
|
else
|
||||||
|
sneeker.log_debug('Spawn denied')
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Node must be touching air
|
|
||||||
if minetest.get_node(pos).name ~= 'air' then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
pos.y = pos.y+1
|
|
||||||
if minetest.get_node(pos).name ~= 'air' then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Get total count of sneekers in world
|
|
||||||
local name, count
|
|
||||||
for name in pairs(minetest.luaentities) do
|
|
||||||
if name == sneeker.mob_name then
|
|
||||||
count = count + 1
|
|
||||||
end
|
|
||||||
end
|
|
||||||
if count >= sneeker.spawn_cap then return end -- Max sneekers already exist
|
|
||||||
|
|
||||||
sneeker.spawn(pos)
|
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
Loading…
Reference in New Issue
Block a user