Put in checks to prevent repeatedly applying the same FOV modifier.
Added short circuit to remove_modifier if the modifier is not currently applied.
This commit is contained in:
parent
36f661743e
commit
4f3f59f4bc
@ -74,6 +74,9 @@ function mcl_fovapi.apply_modifier(player, modifier_name)
|
||||
if mcl_fovapi.registered_modifiers[modifier_name] == nil then
|
||||
return
|
||||
end
|
||||
if mcl_fovapi.applied_modifiers[player][modifier_name] and mcl_fovapi.applied_modifiers[player][modifier_name] == true then
|
||||
return
|
||||
end
|
||||
|
||||
local modifier = mcl_fovapi.registered_modifiers[modifier_name]
|
||||
if modifier.on_start ~= nil then
|
||||
@ -110,6 +113,8 @@ function mcl_fovapi.remove_modifier(player, modifier_name)
|
||||
return
|
||||
end
|
||||
|
||||
if mcl_fovapi.applied_modifiers[player][modifier_name] == nil then return end
|
||||
|
||||
if DEBUG then
|
||||
local name = player:get_player_name()
|
||||
minetest.log("FOV::Player: " .. name .. " modifier: " .. modifier_name .. "removed.")
|
||||
|
Loading…
Reference in New Issue
Block a user