Add debugging output in case of denied spawn

This commit is contained in:
AntumDeluge 2017-05-29 01:40:40 -07:00
parent ea60b5fe9b
commit 8485715aba

@ -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
sneeker.log_debug('Node light level at ' .. tostring(pos.x) .. ',' .. tostring(pos.y) .. ': ' .. tostring(node_light)) -- Debugging spawning
sneeker.log_debug('Node light level at ' .. tostring(pos.x) .. ',' .. tostring(pos.y) .. ': ' .. tostring(node_light))
if not node_light then
return if not node_light or node_light > sneeker.spawn_maxlight or node_light < -1 then
end spawnit = false
if node_light > sneeker.spawn_maxlight then end
return
end -- Spawn range
if node_light < -1 then if pos.y > 31000 then
return spawnit = false
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
}) })