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
|
|
|
|
|
2017-05-31 21:01:44 +02:00
|
|
|
local spawn_cap = minetest.setting_get('sneeker.spawn_cap') or 25 -- Maximum number of spawns active at one time
|
2017-05-29 11:57:06 +02:00
|
|
|
local spawn_chance = minetest.setting_get('sneeker.spawn_chance') or 2 -- 50% chance of spawn
|
2017-05-29 11:57:56 +02:00
|
|
|
local spawn_interval = minetest.setting_get('sneeker.spawn_interval') or time_min * 2 -- Default interval is 2 minutes
|
2017-05-31 20:56:20 +02:00
|
|
|
local spawn_maxlight = minetest.setting_get('sneeker.spawn_maxlight') or 5 -- Maximum light of node for spawn
|
2017-05-28 04:13:47 +02:00
|
|
|
|
2017-05-29 11:55:13 +02:00
|
|
|
local spawn_chance_percent = tostring(math.floor(1 / spawn_chance * 100)) .. '%'
|
|
|
|
|
2017-05-31 21:01:44 +02:00
|
|
|
sneeker.log('Spawn cap: ' .. tostring(sneeker.spawn_cap))
|
2017-05-29 11:55:13 +02:00
|
|
|
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-31 20:56:20 +02:00
|
|
|
sneeker.log('Maximum light value for spawn: ' .. tostring(spawn_maxlight))
|
2017-05-28 04:15:23 +02:00
|
|
|
|
2017-05-13 12:35:54 +02:00
|
|
|
minetest.register_abm({
|
2017-05-29 09:06:18 +02:00
|
|
|
nodenames = {'default:dirt_with_grass', 'default:stone'},
|
2017-05-28 02:26:10 +02:00
|
|
|
neighbors = {'air'},
|
2017-05-28 04:13:47 +02:00
|
|
|
interval = spawn_interval,
|
|
|
|
chance = spawn_chance,
|
2017-05-13 12:35:54 +02:00
|
|
|
action = function(pos, node, _, active_object_count_wider)
|
2017-05-29 10:40:40 +02:00
|
|
|
if active_object_count_wider > 5 then
|
2017-05-29 11:53:20 +02:00
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
-- Check light value of node
|
|
|
|
pos.y = pos.y+1
|
|
|
|
local node_light = minetest.get_node_light(pos)
|
|
|
|
|
|
|
|
-- Debugging spawning
|
|
|
|
sneeker.log_debug('Node light level at ' .. sneeker.get_pos_string(pos) .. ': ' .. tostring(node_light))
|
|
|
|
|
2017-05-31 20:56:20 +02:00
|
|
|
if not node_light or node_light > 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
|
2017-05-13 12:35:54 +02:00
|
|
|
end
|
2017-05-29 10:01:14 +02:00
|
|
|
|
2017-05-29 11:53:20 +02:00
|
|
|
-- Spawn range
|
|
|
|
if pos.y > 31000 then
|
|
|
|
return
|
2017-05-13 12:35:54 +02:00
|
|
|
end
|
2017-05-29 10:01:14 +02:00
|
|
|
|
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
|
2017-05-13 12:35:54 +02:00
|
|
|
end
|
2017-05-29 11:53:20 +02:00
|
|
|
|
|
|
|
-- Get total count of sneekers in world
|
2017-05-29 11:54:14 +02:00
|
|
|
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
|
|
|
|
end
|
|
|
|
|
2017-05-31 21:01:44 +02:00
|
|
|
sneeker.log_debug('Current active spawns: ' .. tostring(count) .. '/' .. tostring(spawn_cap))
|
2017-05-29 11:55:13 +02:00
|
|
|
|
2017-05-31 21:01:44 +02:00
|
|
|
if count >= spawn_cap then
|
2017-05-29 11:53:20 +02:00
|
|
|
sneeker.log_debug('Max spawns reached')
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
sneeker.spawn(pos)
|
2017-05-13 12:35:54 +02:00
|
|
|
end
|
|
|
|
})
|