mod-sneeker/spawn.lua

70 lines
1.9 KiB
Lua
Raw Normal View History

2017-05-28 02:36:45 +02:00
-- Original code by Rui: WTFPL
2017-05-13 12:45:04 +02:00
2017-05-28 04:07:41 +02:00
local time_min = 60
2017-05-13 12:45:04 +02:00
local time_hr = time_min * 60
local time_day = time_hr * 24
local spawn_chance = tonumber(minetest.settings:get("sneeker.spawn_chance")) or 2 -- 50% chance of spawn
local spawn_interval = tonumber(minetest.settings:get("sneeker.spawn_interval")) or time_min * 40 -- Default interval is 40 minutes
2017-05-29 11:55:13 +02:00
local spawn_chance_percent = tostring(math.floor(1 / spawn_chance * 100)) .. "%"
sneeker.log("Spawn chance: " .. spawn_chance_percent)
2017-05-29 10:25:51 +02:00
sneeker.log("Spawn interval: " .. tostring(spawn_interval) .. " (" .. tostring(spawn_interval/60) .. " minute(s))")
2017-05-28 04:15:23 +02:00
minetest.register_abm({
nodenames = {"default:dirt_with_grass", "default:stone"},
neighbors = {"air"},
interval = spawn_interval,
chance = spawn_chance,
action = function(pos, node, _, active_object_count_wider)
if active_object_count_wider > 5 then
2017-05-29 11:53:20 +02:00
return
end
2017-05-29 11:53:20 +02:00
-- Check light value of node
pos.y = pos.y+1
local node_light = minetest.get_node_light(pos)
2017-05-29 11:53:20 +02:00
-- Debugging spawning
sneeker.log_debug("Node light level at " .. sneeker.get_pos_string(pos) .. ": " .. tostring(node_light))
2017-05-29 11:53:20 +02:00
if not node_light or node_light > sneeker.spawn_maxlight or node_light < -1 then
2017-05-29 11:55:13 +02:00
sneeker.log_debug("Node not dark enough for spawn")
2017-05-29 11:53:20 +02:00
return
end
2017-05-29 11:53:20 +02:00
-- Spawn range
if pos.y > 31000 then
return
end
2017-05-29 11:53:20 +02:00
-- 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
2017-05-29 11:53:20 +02:00
-- Get total count of sneekers in world
local count = 0
for I in pairs(minetest.luaentities) do
if minetest.luaentities[I].name == sneeker.mob_name then
2017-05-29 11:53:20 +02:00
count = count + 1
end
2017-05-29 09:14:26 +02:00
end
2017-05-29 11:55:13 +02:00
sneeker.log_debug("Current active spawns: " .. tostring(count) .. "/" .. tostring(sneeker.spawn_cap))
2017-05-29 11:53:20 +02:00
if count >= sneeker.spawn_cap then
sneeker.log_debug("Max spawns reached")
return
end
2017-05-29 11:53:20 +02:00
sneeker.spawn(pos)
end
})