ENTITIES/mcl_mobs: fix broken passive mob timer

The timer has to be decremented by the full time elapsed since the last
call, but check_timer isn't called on every invocation of the globalstep
function and therefore misses time. Decrement it directly in the
globalstep function instead.

Previously check_timer seems to have assumed to be called with the
spawn_class as parameter (called mob_type, though), but actually it is
called on the spawn definition, leading to always returning true.
Instead retrieve spawn class from mob def found in registry.

The timer reset logic was reset even on non passive mobs, erronously
reducing the chance of spawning passive mobs. (Not noticable because
logic couldn't identify passive mobs correctly.)

Also PASSIVE_INTERVAL had been set to 200 instead of the 20 seconds
documented in the minecraft wiki. Change that, too.
This commit is contained in:
j-r 2023-12-01 17:14:56 +01:00 committed by ryvnf
parent 3f79549c3e
commit c20a7def3f

View File

@ -10,7 +10,7 @@ local overworld_threshold = tonumber(minetest.settings:get("mcl_mobs_overworld_t
local overworld_sky_threshold = tonumber(minetest.settings:get("mcl_mobs_overworld_sky_threshold")) or 7 local overworld_sky_threshold = tonumber(minetest.settings:get("mcl_mobs_overworld_sky_threshold")) or 7
local overworld_passive_threshold = tonumber(minetest.settings:get("mcl_mobs_overworld_passive_threshold")) or 7 local overworld_passive_threshold = tonumber(minetest.settings:get("mcl_mobs_overworld_passive_threshold")) or 7
local PASSIVE_INTERVAL = 200 local PASSIVE_INTERVAL = 20
local dbg_spawn_attempts = 0 local dbg_spawn_attempts = 0
local dbg_spawn_succ = 0 local dbg_spawn_succ = 0
local dbg_spawn_counts = {} local dbg_spawn_counts = {}
@ -384,11 +384,16 @@ end
local passive_timer = PASSIVE_INTERVAL local passive_timer = PASSIVE_INTERVAL
--timer function to check if passive mobs should spawn (every 20 secs) --timer function to check if passive mobs should spawn (only every 20 secs unlike other mob spawn classes)
local function check_timer(mob_type,dtime) local function check_timer(spawn_def, dtime)
passive_timer = passive_timer - dtime local mob_def = minetest.registered_entities[spawn_def.name]
if mob_type == "passive" and passive_timer > 0 then return false end if mob_def and mob_def.spawn_class == "passive" then
if passive_timer < 0 then passive_timer = PASSIVE_INTERVAL end if passive_timer > 0 then
return false
else
passive_timer = PASSIVE_INTERVAL
end
end
return true return true
end end
@ -463,6 +468,7 @@ if mobs_spawn then
local timer = 0 local timer = 0
minetest.register_globalstep(function(dtime) minetest.register_globalstep(function(dtime)
passive_timer = passive_timer - dtime
timer = timer + dtime timer = timer + dtime
if timer < 10 then return end if timer < 10 then return end
timer = 0 timer = 0