Add debugging output in case of denied spawn

This commit is contained in:
AntumDeluge 2017-05-29 01:40:40 -07:00 committed by Jordan Irwin
parent 3a3de549bf
commit 21d78e0b65

@ -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
}) })