2017-05-28 02:36:45 +02:00
|
|
|
-- Original code by Rui: WTFPL
|
|
|
|
|
2017-05-13 12:45:04 +02:00
|
|
|
|
2021-05-06 04:30:49 +02:00
|
|
|
local time_hr = sneeker.time_min * 60
|
2017-05-13 12:45:04 +02:00
|
|
|
local time_day = time_hr * 24
|
|
|
|
|
2017-06-08 05:33:46 +02:00
|
|
|
-- Display spawn chance as percentage in log
|
2021-05-06 04:30:49 +02:00
|
|
|
local spawn_chance_percent = math.floor(1 / sneeker.spawn_chance * 100)
|
2017-06-08 05:33:46 +02:00
|
|
|
if spawn_chance_percent < 1 then
|
|
|
|
spawn_chance_percent = "Less than 1%"
|
|
|
|
else
|
|
|
|
spawn_chance_percent = tostring(spawn_chance_percent) .. "%"
|
|
|
|
end
|
2017-05-29 11:55:13 +02:00
|
|
|
|
2021-05-06 04:30:49 +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)
|
2021-05-06 04:30:49 +02:00
|
|
|
sneeker.log("Spawn interval: " .. tostring(sneeker.spawn_interval) .. " (" .. tostring(sneeker.spawn_interval/60) .. " minute(s))")
|
|
|
|
sneeker.log("Maximum light value for spawn: " .. tostring(sneeker.spawn_maxlight))
|
2017-05-28 04:15:23 +02:00
|
|
|
|
2021-05-07 06:11:18 +02:00
|
|
|
local spawn_nodes = {"default:dirt_with_grass", "default:stone"}
|
|
|
|
if core.global_exists("nether") then
|
|
|
|
table.insert(spawn_nodes, "nether:rack")
|
|
|
|
end
|
|
|
|
|
2017-07-29 02:10:57 +02:00
|
|
|
core.register_abm({
|
2021-05-07 06:11:18 +02:00
|
|
|
nodenames = spawn_nodes,
|
2017-05-13 12:35:54 +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)
|
|
|
|
if active_object_count_wider > 5 then
|
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
|
|
|
-- Check light value of node
|
|
|
|
pos.y = pos.y+1
|
2017-07-29 02:10:57 +02:00
|
|
|
local node_light = core.get_node_light(pos)
|
2017-05-29 10:01:14 +02:00
|
|
|
|
2017-05-29 11:53:20 +02:00
|
|
|
-- Debugging spawning
|
2021-05-06 04:11:14 +02:00
|
|
|
sneeker.log("debug", "Node light level at " .. sneeker.get_pos_string(pos) .. ": " .. tostring(node_light))
|
2017-05-31 21:01:44 +02:00
|
|
|
|
2017-08-08 11:51:22 +02:00
|
|
|
-- Node light level
|
|
|
|
if not node_light or node_light > spawn_maxlight then
|
2021-05-06 04:11:14 +02:00
|
|
|
sneeker.log("debug", "Node not dark enough for spawn")
|
2017-05-29 11:53:20 +02:00
|
|
|
return
|
2017-08-08 11:51:22 +02:00
|
|
|
elseif node_light < spawn_minlight then
|
2021-05-06 04:11:14 +02:00
|
|
|
sneeker.log("debug", "Node too dark for spawn")
|
2017-08-08 11:51:22 +02:00
|
|
|
return
|
2017-05-29 11:53:20 +02:00
|
|
|
end
|
2017-05-29 10:01:14 +02:00
|
|
|
|
2017-05-29 11:53:20 +02:00
|
|
|
-- Spawn range
|
2017-08-08 11:51:22 +02:00
|
|
|
if spawn_minheight ~= nil and pos.y < spawn_minheight then
|
2021-05-06 04:11:14 +02:00
|
|
|
sneeker.log("debug", "Position is too low for spawn")
|
2017-08-08 11:51:22 +02:00
|
|
|
return
|
|
|
|
elseif pos.y > spawn_maxheight then
|
2021-05-06 04:11:14 +02:00
|
|
|
sneeker.log("debug", "Position is too high for spawn")
|
2017-05-29 11:53:20 +02:00
|
|
|
return
|
|
|
|
end
|
2017-05-29 10:01:14 +02:00
|
|
|
|
2017-05-29 11:53:20 +02:00
|
|
|
-- Node must be touching air
|
2017-07-29 02:10:57 +02:00
|
|
|
if core.get_node(pos).name ~= "air" then
|
2017-05-29 11:53:20 +02:00
|
|
|
return
|
|
|
|
end
|
|
|
|
pos.y = pos.y+1
|
2017-07-29 02:10:57 +02:00
|
|
|
if core.get_node(pos).name ~= "air" then
|
2017-05-29 11:53:20 +02:00
|
|
|
return
|
|
|
|
end
|
2017-05-29 10:01:14 +02:00
|
|
|
|
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
|
2017-07-29 02:10:57 +02:00
|
|
|
for I in pairs(core.luaentities) do
|
|
|
|
if core.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 10:01:14 +02:00
|
|
|
|
2021-05-06 04:11:14 +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
|
2021-05-06 04:11:14 +02:00
|
|
|
sneeker.log("debug", "Max spawns reached")
|
2017-05-29 11:53:20 +02:00
|
|
|
return
|
2017-05-29 10:40:40 +02:00
|
|
|
end
|
2017-05-29 11:53:20 +02:00
|
|
|
|
|
|
|
sneeker.spawn(pos)
|
2017-05-13 12:35:54 +02:00
|
|
|
end
|
|
|
|
})
|