Compare commits

...

3 Commits

Author SHA1 Message Date
8b24793e82 effect:onBirth refactor 2026-05-02 02:31:39 +03:00
c7a41676c2 refactor __eq in effect 2026-05-02 02:03:51 +03:00
aac6e5e8f4 refactor effectdata 2026-05-02 02:00:33 +03:00
2 changed files with 22 additions and 28 deletions

View File

@ -9,8 +9,10 @@ local easing = require "lib.utils.easing"
--- ---
--- Наносит `intensity` урона перед началом каждого хода. --- Наносит `intensity` урона перед началом каждого хода.
local bleeding = effect.new({ local bleeding = effect.new({
tag = "bleeding", tag = "bleeding"
afterBirth = function(owner, intensity) })
function bleeding:afterBirth(owner, intensity)
local light = require "lib/character/character".spawn("Bleeding Light Effect") local light = require "lib/character/character".spawn("Bleeding Light Effect")
light:addBehavior { light:addBehavior {
Tree.behaviors.light.new { color = Vec3 { 1, 0., 0. }, intensity = 4 }, Tree.behaviors.light.new { color = Vec3 { 1, 0., 0. }, intensity = 4 },
@ -22,8 +24,7 @@ local bleeding = effect.new({
light:die() light:die()
return task.fromValue() return task.fromValue()
end) }) end) })
end end
})
function bleeding:beforeTurn(owner, intensity) function bleeding:beforeTurn(owner, intensity)
local stats = owner:has(Tree.behaviors.stats) local stats = owner:has(Tree.behaviors.stats)

View File

@ -19,7 +19,7 @@ effect.__index = effect
--- @alias EffectStatementFunc fun(owner: Character, intensity: integer): Task<nil>, boolean --- @alias EffectStatementFunc fun(owner: Character, intensity: integer): Task<nil>, boolean
--- @alias EffectDamageFunc fun(owner: Character, intensity: integer, damage: integer): Task<nil>, integer --- @alias EffectDamageFunc fun(owner: Character, intensity: integer, damage: integer): Task<nil>, integer
--- @alias EffectRegenFunc fun(owner: Character, intensity: integer, amountHp: integer): Task<nil>, integer --- @alias EffectRegenFunc fun(owner: Character, intensity: integer, amountHp: integer): Task<nil>, integer
--- @alias EffectData { tag: string, [string]: EffectFunc|EffectStatementFunc|EffectDamageFunc|EffectRegenFunc } --- @alias EffectData { tag: string }
--- Срабатывает перед применением эффекта --- Срабатывает перед применением эффекта
--- ---
@ -131,12 +131,12 @@ function effect:onBirth(owner, stacks, intensity)
if not effects then return end if not effects then return end
-- проверяем на наличие такого же эффекта -- проверяем на наличие такого же эффекта
if effects.effectsProperties[self.tag] then if effects.effectsProperties[self.tag] then
for i, ef in ipairs(effects.effectsPriority) do local i = 1
if ef == self.tag then while i < #effects.effectsPriority and effects.effectsPriority[i] ~= self.tag do
table.remove(effects.effectsProperties, i) i = i + 1
effects.effectsProperties[#effects.effectsProperties + 1] = ef
end
end end
local ef = table.remove(effects.effectsPriority, i)
effects.effectsPriority[#effects.effectsPriority + 1] = ef
else else
effects.effectsPriority[#effects.effectsPriority + 1] = self.tag effects.effectsPriority[#effects.effectsPriority + 1] = self.tag
end end
@ -161,16 +161,9 @@ end
--- @return Effect --- @return Effect
local function new(data) local function new(data)
local newEffect = setmetatable({ local newEffect = setmetatable({
tag = data.tag tag = data.tag,
}, effect) }, effect)
--- дип сравнение эффектов
--- @param other Effect
--- @return boolean
function newEffect:__eq(other)
return utils.deepComparison(self, other)
end
return newEffect return newEffect
end end