From 1bdf96e5caab00d45fdb51251dca4108b84a06dd Mon Sep 17 00:00:00 2001 From: LyLo Date: Tue, 22 Aug 2023 22:30:21 -0400 Subject: [PATCH 1/2] Fix APL If we don't check for else it will always cast even if the condition results in false --- src/APL/APL.lua | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/APL/APL.lua b/src/APL/APL.lua index 49f0659..6de3bc3 100644 --- a/src/APL/APL.lua +++ b/src/APL/APL.lua @@ -109,21 +109,21 @@ function APLActor:Execute() -- print("Bastion: APL:Execute: Condition for spell " .. self:GetActor().spell:GetName()) self:GetActor().spell:CastableIf(self:GetActor().castableFunc):OnCast(self:GetActor().onCastFunc):Cast( self:GetActor().target, self:GetActor().condition) + else + -- print("Bastion: APL:Execute: No condition for spell " .. self:GetActor().spell:GetName()) + self:GetActor().spell:CastableIf(self:GetActor().castableFunc):OnCast(self:GetActor().onCastFunc):Cast( + self:GetActor().target) end - - -- print("Bastion: APL:Execute: No condition for spell " .. self:GetActor().spell:GetName()) - self:GetActor().spell:CastableIf(self:GetActor().castableFunc):OnCast(self:GetActor().onCastFunc):Cast( - self:GetActor().target) end if self:GetActor().item then if self:GetActor().condition then -- print("Bastion: APL:Execute: Condition for spell " .. self:GetActor().spell:GetName()) self:GetActor().item:UsableIf(self:GetActor().usableFunc):Use(self:GetActor().target, self:GetActor().condition) + else + -- print("Bastion: APL:Execute: No condition for spell " .. self:GetActor().spell:GetName()) + self:GetActor().item:UsableIf(self:GetActor().usableFunc):Use(self:GetActor().target) end - - -- print("Bastion: APL:Execute: No condition for spell " .. self:GetActor().spell:GetName()) - self:GetActor().item:UsableIf(self:GetActor().usableFunc):Use(self:GetActor().target) end if self:GetActor().action then -- print("Bastion: APL:Execute: Executing action " .. self:GetActor().action) @@ -209,7 +209,7 @@ end -- Add a spell to the APL ---@param spell Spell ----@param condition? fun(...):boolean +---@param condition? string|fun(...):boolean ---@return APLActor function APL:AddSpell(spell, condition) local castableFunc = spell.CastableIfFunc From a84930cef2a604777caab16b7d3fa8b86e92b6b3 Mon Sep 17 00:00:00 2001 From: LyLo Date: Tue, 22 Aug 2023 22:30:49 -0400 Subject: [PATCH 2/2] Change Spell:Cast add possibility to use functions as argument for condition --- src/Spell/Spell.lua | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/src/Spell/Spell.lua b/src/Spell/Spell.lua index 1cdc0a8..f4a5e19 100644 --- a/src/Spell/Spell.lua +++ b/src/Spell/Spell.lua @@ -161,11 +161,15 @@ end -- Cast the spell ---@param unit Unit ----@param condition string +---@param condition string|function ---@return boolean function Spell:Cast(unit, condition) - if condition and not self:EvaluateCondition(condition) then - return false + if condition then + if type(condition) == "string" and not self:EvaluateCondition(condition) then + return false + elseif type(condition) == "function" and not condition(self) then + return false + end end if not self:Castable() then