Finish emmy lua docs

pull/4/head
4n0n 2 years ago
parent ca82648393
commit 2418c147e9
  1. 2
      src/ItemBook/ItemBook.lua
  2. 35
      src/List/List.lua
  3. 12
      src/Module/Module.lua
  4. 6
      src/MythicPlusUtils/MythicPlusUtils.lua
  5. 15
      src/NotificationsList/NotificationsList.lua
  6. 10
      src/ObjectManager/ObjectManager.lua
  7. 10
      src/Refreshable/Refreshable.lua
  8. 65
      src/Spell/Spell.lua
  9. 6
      src/Timer/Timer.lua
  10. 102
      src/Unit/Unit.lua
  11. 23
      src/UnitManager/UnitManager.lua
  12. 50
      src/Vector3/Vector3.lua

@ -6,6 +6,7 @@ local ItemBook = {}
ItemBook.__index = ItemBook ItemBook.__index = ItemBook
-- Constructor -- Constructor
---@return ItemBook
function ItemBook:New() function ItemBook:New()
local self = setmetatable({}, ItemBook) local self = setmetatable({}, ItemBook)
self.items = {} self.items = {}
@ -13,6 +14,7 @@ function ItemBook:New()
end end
-- Get a spell from the ItemBook -- Get a spell from the ItemBook
---@param id number
---@return Item ---@return Item
function ItemBook:GetItem(id) function ItemBook:GetItem(id)
if self.items[id] == nil then if self.items[id] == nil then

@ -22,32 +22,42 @@ local List = {
} }
List.__index = List List.__index = List
---@param from table | nil
---@return List
function List:New(from) function List:New(from)
local self = setmetatable({}, List) local self = setmetatable({}, List)
self._list = from or {} self._list = from or {}
return self return self
end end
---@param value any
---@return nil
function List:push(value) function List:push(value)
table.insert(self._list, value) table.insert(self._list, value)
end end
---@return any
function List:pop() function List:pop()
return table.remove(self._list) return table.remove(self._list)
end end
---@return any
function List:peek() function List:peek()
return self._list[#self._list] return self._list[#self._list]
end end
---@return number
function List:count() function List:count()
return #self._list return #self._list
end end
---@return nil
function List:clear() function List:clear()
self._list = {} self._list = {}
end end
---@param value any
---@return boolean
function List:contains(value) function List:contains(value)
for _, v in ipairs(self._list) do for _, v in ipairs(self._list) do
if v == value then if v == value then
@ -57,6 +67,8 @@ function List:contains(value)
return false return false
end end
---@param value any
---@return boolean
function List:remove(value) function List:remove(value)
for i, v in ipairs(self._list) do for i, v in ipairs(self._list) do
if v == value then if v == value then
@ -67,6 +79,8 @@ function List:remove(value)
return false return false
end end
---@param callback fun(value: any): boolean
---@return nil
function List:each(callback) function List:each(callback)
for _, v in ipairs(self._list) do for _, v in ipairs(self._list) do
if callback(v) then if callback(v) then
@ -75,6 +89,8 @@ function List:each(callback)
end end
end end
---@param callback fun(value: any): boolean
---@return boolean
function List:map(callback) function List:map(callback)
local newList = List.new() local newList = List.new()
for _, v in ipairs(self._list) do for _, v in ipairs(self._list) do
@ -83,6 +99,8 @@ function List:map(callback)
return newList return newList
end end
---@param callback fun(value: any): boolean
---@return boolean
function List:filter(callback) function List:filter(callback)
local newList = List.new() local newList = List.new()
for _, v in ipairs(self._list) do for _, v in ipairs(self._list) do
@ -93,6 +111,9 @@ function List:filter(callback)
return newList return newList
end end
---@param callback fun(value: any): boolean
---@param initialValue any
---@return boolean
function List:reduce(callback, initialValue) function List:reduce(callback, initialValue)
local result = initialValue local result = initialValue
for _, v in ipairs(self._list) do for _, v in ipairs(self._list) do
@ -101,6 +122,8 @@ function List:reduce(callback, initialValue)
return result return result
end end
---@param callback fun(value: any): boolean
---@return boolean | nil
function List:find(callback) function List:find(callback)
for _, v in ipairs(self._list) do for _, v in ipairs(self._list) do
if callback(v) then if callback(v) then
@ -110,6 +133,8 @@ function List:find(callback)
return nil return nil
end end
---@param callback fun(value: any): boolean
---@return number | nil
function List:findIndex(callback) function List:findIndex(callback)
for i, v in ipairs(self._list) do for i, v in ipairs(self._list) do
if callback(v) then if callback(v) then
@ -119,10 +144,13 @@ function List:findIndex(callback)
return nil return nil
end end
---@param callback fun(value: any): boolean
---@return nil
function List:sort(callback) function List:sort(callback)
table.sort(self._list, callback) table.sort(self._list, callback)
end end
---@return List
function List:reverse() function List:reverse()
local newList = List.new() local newList = List.new()
for i = #self._list, 1, -1 do for i = #self._list, 1, -1 do
@ -131,6 +159,7 @@ function List:reverse()
return newList return newList
end end
---@return List
function List:clone() function List:clone()
local newList = List.new() local newList = List.new()
for _, v in ipairs(self._list) do for _, v in ipairs(self._list) do
@ -139,6 +168,8 @@ function List:clone()
return newList return newList
end end
---@param list List
---@return List
function List:concat(list) function List:concat(list)
local newList = List.new() local newList = List.new()
for _, v in ipairs(self._list) do for _, v in ipairs(self._list) do
@ -150,6 +181,8 @@ function List:concat(list)
return newList return newList
end end
---@param separator string
---@return string
function List:join(separator) function List:join(separator)
local result = "" local result = ""
for i, v in ipairs(self._list) do for i, v in ipairs(self._list) do
@ -161,10 +194,12 @@ function List:join(separator)
return result return result
end end
---@return string
function List:toString() function List:toString()
return self:join(", ") return self:join(", ")
end end
---@return string
function List:__tostring() function List:__tostring()
return self:toString() return self:toString()
end end

@ -5,10 +5,14 @@ local Module = {}
Module.__index = Module Module.__index = Module
-- __tostring -- __tostring
---@return string
function Module:__tostring() function Module:__tostring()
return "Bastion.__Module(" .. self.name .. ")" return "Bastion.__Module(" .. self.name .. ")"
end end
-- Constructor
---@param name string
---@return Module
function Module:New(name) function Module:New(name)
local module = {} local module = {}
setmetatable(module, Module) setmetatable(module, Module)
@ -21,16 +25,19 @@ function Module:New(name)
end end
-- Enable the module -- Enable the module
---@return nil
function Module:Enable() function Module:Enable()
self.enabled = true self.enabled = true
end end
-- Disable the module -- Disable the module
---@return nil
function Module:Disable() function Module:Disable()
self.enabled = false self.enabled = false
end end
-- Toggle the module -- Toggle the module
---@return nil
function Module:Toggle() function Module:Toggle()
if self.enabled then if self.enabled then
self:Disable() self:Disable()
@ -40,11 +47,15 @@ function Module:Toggle()
end end
-- Add a function to the sync list -- Add a function to the sync list
---@param func function
---@return nil
function Module:Sync(func) function Module:Sync(func)
table.insert(self.synced, func) table.insert(self.synced, func)
end end
-- Remove a function from the sync list -- Remove a function from the sync list
---@param func function
---@return nil
function Module:Unsync(func) function Module:Unsync(func)
for i = 1, #self.synced do for i = 1, #self.synced do
if self.synced[i] == func then if self.synced[i] == func then
@ -55,6 +66,7 @@ function Module:Unsync(func)
end end
-- Sync -- Sync
---@return nil
function Module:Tick() function Module:Tick()
if self.enabled then if self.enabled then
for i = 1, #self.synced do for i = 1, #self.synced do

@ -12,6 +12,7 @@ local MythicPlusUtils = {
MythicPlusUtils.__index = MythicPlusUtils MythicPlusUtils.__index = MythicPlusUtils
---@return MythicPlusUtils
function MythicPlusUtils:New() function MythicPlusUtils:New()
local self = setmetatable({}, MythicPlusUtils) local self = setmetatable({}, MythicPlusUtils)
@ -148,14 +149,19 @@ function MythicPlusUtils:New()
return self return self
end end
---@return nil
function MythicPlusUtils:ToggleDebuffLogging() function MythicPlusUtils:ToggleDebuffLogging()
self.debuffLogging = not self.debuffLogging self.debuffLogging = not self.debuffLogging
end end
---@return nil
function MythicPlusUtils:ToggleCastLogging() function MythicPlusUtils:ToggleCastLogging()
self.castLogging = not self.castLogging self.castLogging = not self.castLogging
end end
---@param unit Unit
---@param percent number
---@return boolean
function MythicPlusUtils:CastingCriticalKick(unit, percent) function MythicPlusUtils:CastingCriticalKick(unit, percent)
local castingSpell = unit:GetCastingOrChannelingSpell() local castingSpell = unit:GetCastingOrChannelingSpell()

@ -7,6 +7,7 @@ local NotificationsList = {
NotificationsList.__index = NotificationsList NotificationsList.__index = NotificationsList
-- Constructor -- Constructor
---@return NotificationsList
function NotificationsList:New() function NotificationsList:New()
local self = setmetatable({}, NotificationsList) local self = setmetatable({}, NotificationsList)
@ -36,6 +37,11 @@ local Notification = {
Notification.__index = Notification Notification.__index = Notification
-- Constructor -- Constructor
---@param list NotificationsList
---@param icon string
---@param text string
---@param duration number
---@return Notification
function Notification:New(list, icon, text, duration) function Notification:New(list, icon, text, duration)
local self = setmetatable({}, Notification) local self = setmetatable({}, Notification)
@ -70,6 +76,7 @@ function Notification:New(list, icon, text, duration)
end end
-- Remove notification -- Remove notification
---@return nil
function Notification:Remove() function Notification:Remove()
-- Fade out the notification frame and remove it after the fade -- Fade out the notification frame and remove it after the fade
UIFrameFadeOut(self.frame, 0.2, 1, 0) UIFrameFadeOut(self.frame, 0.2, 1, 0)
@ -83,6 +90,10 @@ function Notification:Remove()
end end
-- Add a notification to the list -- Add a notification to the list
---@param icon string
---@param text string
---@param duration number
---@return nil
function NotificationsList:AddNotification(icon, text, duration) function NotificationsList:AddNotification(icon, text, duration)
-- Create a new notification -- Create a new notification
local notification = Notification:New(self, icon, text, duration) local notification = Notification:New(self, icon, text, duration)
@ -96,6 +107,7 @@ function NotificationsList:AddNotification(icon, text, duration)
end end
-- Update the notifications -- Update the notifications
---@return nil
function NotificationsList:Update() function NotificationsList:Update()
-- Loop through the notifications -- Loop through the notifications
for i, notification in ipairs(self.notifications) do for i, notification in ipairs(self.notifications) do
@ -105,6 +117,8 @@ function NotificationsList:Update()
end end
-- Remove a notification from the list -- Remove a notification from the list
---@param notification Notification
---@return nil
function NotificationsList:RemoveNotification(notification) function NotificationsList:RemoveNotification(notification)
-- Loop through the notifications -- Loop through the notifications
for i, v in ipairs(self.notifications) do for i, v in ipairs(self.notifications) do
@ -119,6 +133,7 @@ function NotificationsList:RemoveNotification(notification)
end end
-- Remove all notifications from the list -- Remove all notifications from the list
---@return nil
function NotificationsList:RemoveAllNotifications() function NotificationsList:RemoveAllNotifications()
-- Loop through the notifications -- Loop through the notifications
for i, v in ipairs(self.notifications) do for i, v in ipairs(self.notifications) do

@ -18,6 +18,9 @@ function ObjectManager:New()
end end
-- Register a custom list with a callback -- Register a custom list with a callback
---@param name string
---@param cb function
---@return List
function ObjectManager:RegisterList(name, cb) function ObjectManager:RegisterList(name, cb)
if self._lists[name] then if self._lists[name] then
return false return false
@ -32,6 +35,7 @@ function ObjectManager:RegisterList(name, cb)
end end
-- reset custom lists -- reset custom lists
---@return nil
function ObjectManager:ResetLists() function ObjectManager:ResetLists()
for _, list in pairs(self._lists) do for _, list in pairs(self._lists) do
list.list:clear() list.list:clear()
@ -39,6 +43,8 @@ function ObjectManager:ResetLists()
end end
-- Refresh custom lists -- Refresh custom lists
---@param object table
---@return nil
function ObjectManager:EnumLists(object) function ObjectManager:EnumLists(object)
for _, list in pairs(self._lists) do for _, list in pairs(self._lists) do
local r = list.cb(object) local r = list.cb(object)
@ -49,10 +55,14 @@ function ObjectManager:EnumLists(object)
end end
-- Get a list -- Get a list
---@param name string
---@return List
function ObjectManager:GetList(name) function ObjectManager:GetList(name)
return self._lists[name].list return self._lists[name].list
end end
-- Refresh all lists
---@return nil
function ObjectManager:Refresh() function ObjectManager:Refresh()
self.enemies:clear() self.enemies:clear()
self.friends:clear() self.friends:clear()

@ -22,11 +22,15 @@ function Refreshable:__index(k)
end end
-- When the object is accessed return the value -- When the object is accessed return the value
---@return string
function Refreshable:__tostring() function Refreshable:__tostring()
return "Bastion.__Refreshable(" .. tostring(rawget(self, 'value')) .. ")" return "Bastion.__Refreshable(" .. tostring(rawget(self, 'value')) .. ")"
end end
-- Create -- Create
---@param value any
---@param cb function
---@return Refreshable
function Refreshable:New(value, cb) function Refreshable:New(value, cb)
local self = setmetatable({}, Refreshable) local self = setmetatable({}, Refreshable)
@ -40,6 +44,7 @@ function Refreshable:New(value, cb)
end end
-- Try to update the value -- Try to update the value
---@return nil
function Refreshable:TryUpdate() function Refreshable:TryUpdate()
if self.cache:IsCached("value") then if self.cache:IsCached("value") then
self.value = self.callback() self.value = self.callback()
@ -47,16 +52,21 @@ function Refreshable:TryUpdate()
end end
-- Update the value -- Update the value
---@return nil
function Refreshable:Update() function Refreshable:Update()
self.value = self.callback() self.value = self.callback()
end end
-- Set a new value -- Set a new value
---@param value any
---@return nil
function Refreshable:Set(value) function Refreshable:Set(value)
self.value = value self.value = value
end end
-- Set a new callback -- Set a new callback
---@param cb function
---@return nil
function Refreshable:SetCallback(cb) function Refreshable:SetCallback(cb)
self.callback = cb self.callback = cb
end end

@ -32,16 +32,21 @@ function Spell:__index(k)
end end
-- Equals -- Equals
---@param other Spell
---@return boolean
function Spell:__eq(other) function Spell:__eq(other)
return self:GetID() == other:GetID() return self:GetID() == other:GetID()
end end
-- tostring -- tostring
---@return string
function Spell:__tostring() function Spell:__tostring()
return "Bastion.__Spell(" .. self:GetID() .. ")" .. " - " .. self:GetName() return "Bastion.__Spell(" .. self:GetID() .. ")" .. " - " .. self:GetName()
end end
-- Constructor -- Constructor
---@param id number
---@return Spell
function Spell:New(id) function Spell:New(id)
local self = setmetatable({}, Spell) local self = setmetatable({}, Spell)
@ -51,59 +56,72 @@ function Spell:New(id)
end end
-- Get the spells id -- Get the spells id
---@return number
function Spell:GetID() function Spell:GetID()
return self.spellID return self.spellID
end end
-- Add post cast func -- Add post cast func
---@param func fun(self:Spell) ---@param func fun(self:Spell)
---@return Spell
function Spell:PostCast(func) function Spell:PostCast(func)
self.PostCastFunc = func self.PostCastFunc = func
return self return self
end end
-- Get the spells name -- Get the spells name
---@return string
function Spell:GetName() function Spell:GetName()
return GetSpellInfo(self:GetID()) return GetSpellInfo(self:GetID())
end end
-- Get the spells icon -- Get the spells icon
---@return number
function Spell:GetIcon() function Spell:GetIcon()
return select(3, GetSpellInfo(self:GetID())) return select(3, GetSpellInfo(self:GetID()))
end end
-- Get the spells cooldown -- Get the spells cooldown
---@return number
function Spell:GetCooldown() function Spell:GetCooldown()
return select(2, GetSpellCooldown(self:GetID())) return select(2, GetSpellCooldown(self:GetID()))
end end
-- Return the castable function -- Return the castable function
---@return fun(self:Spell):boolean
function Spell:GetCastableFunction() function Spell:GetCastableFunction()
return self.CastableIfFunc return self.CastableIfFunc
end end
-- Return the precast function -- Return the precast function
---@return fun(self:Spell)
function Spell:GetPreCastFunction() function Spell:GetPreCastFunction()
return self.PreCastFunc return self.PreCastFunc
end end
-- Get the on cast func -- Get the on cast func
---@return fun(self:Spell)
function Spell:GetOnCastFunction() function Spell:GetOnCastFunction()
return self.OnCastFunc return self.OnCastFunc
end end
-- Get the spells cooldown remaining -- Get the spells cooldown remaining
---@return number
function Spell:GetCooldownRemaining() function Spell:GetCooldownRemaining()
local start, duration = GetSpellCooldown(self:GetID()) local start, duration = GetSpellCooldown(self:GetID())
return start + duration - GetTime() return start + duration - GetTime()
end end
-- On cooldown -- On cooldown
---@return boolean
function Spell:OnCooldown() function Spell:OnCooldown()
return self:GetCooldownRemaining() > 0 return self:GetCooldownRemaining() > 0
end end
-- Cast the spell -- Cast the spell
---@param unit Unit
---@param condition string
---@return boolean
function Spell:Cast(unit, condition) function Spell:Cast(unit, condition)
if condition and not self:EvaluateCondition(condition) then if condition and not self:EvaluateCondition(condition) then
return false return false
@ -140,14 +158,18 @@ function Spell:Cast(unit, condition)
if self:GetOnCastFunction() then if self:GetOnCastFunction() then
self:GetOnCastFunction()(self) self:GetOnCastFunction()(self)
end end
return true
end end
-- Get post cast func -- Get post cast func
---@return fun(self:Spell)
function Spell:GetPostCastFunction() function Spell:GetPostCastFunction()
return self.PostCastFunc return self.PostCastFunc
end end
-- Check if the spell is known -- Check if the spell is known
---@return boolean
function Spell:IsKnown() function Spell:IsKnown()
local isKnown = IsSpellKnown(self:GetID()) local isKnown = IsSpellKnown(self:GetID())
local isPlayerSpell = IsPlayerSpell(self:GetID()) local isPlayerSpell = IsPlayerSpell(self:GetID())
@ -155,22 +177,26 @@ function Spell:IsKnown()
end end
-- Check if the spell is on cooldown -- Check if the spell is on cooldown
---@return boolean
function Spell:IsOnCooldown() function Spell:IsOnCooldown()
return select(2, GetSpellCooldown(self:GetID())) > 0 return select(2, GetSpellCooldown(self:GetID())) > 0
end end
-- Check if the spell is usable -- Check if the spell is usable
---@return boolean
function Spell:IsUsable() function Spell:IsUsable()
local usable, noMana = IsUsableSpell(self:GetID()) local usable, noMana = IsUsableSpell(self:GetID())
return usable or usableExcludes[self:GetID()] return usable or usableExcludes[self:GetID()]
end end
-- Check if the spell is castable -- Check if the spell is castable
---@return boolean
function Spell:IsKnownAndUsable() function Spell:IsKnownAndUsable()
return self:IsKnown() and not self:IsOnCooldown() and self:IsUsable() return self:IsKnown() and not self:IsOnCooldown() and self:IsUsable()
end end
-- Check if the spell is castable -- Check if the spell is castable
---@return boolean
function Spell:Castable() function Spell:Castable()
if self:GetCastableFunction() then if self:GetCastableFunction() then
return self:GetCastableFunction()(self) return self:GetCastableFunction()(self)
@ -181,6 +207,7 @@ end
-- Set a script to check if the spell is castable -- Set a script to check if the spell is castable
---@param func fun(spell:Spell):boolean ---@param func fun(spell:Spell):boolean
---@return Spell
function Spell:CastableIf(func) function Spell:CastableIf(func)
self.CastableIfFunc = func self.CastableIfFunc = func
return self return self
@ -188,6 +215,7 @@ end
-- Set a script to run before the spell has been cast -- Set a script to run before the spell has been cast
---@param func fun(spell:Spell) ---@param func fun(spell:Spell)
---@return Spell
function Spell:PreCast(func) function Spell:PreCast(func)
self.PreCastFunc = func self.PreCastFunc = func
return self return self
@ -195,17 +223,23 @@ end
-- Set a script to run after the spell has been cast -- Set a script to run after the spell has been cast
---@param func fun(spell:Spell) ---@param func fun(spell:Spell)
---@return Spell
function Spell:OnCast(func) function Spell:OnCast(func)
self.OnCastFunc = func self.OnCastFunc = func
return self return self
end end
-- Get was looking -- Get was looking
---@return boolean
function Spell:GetWasLooking() function Spell:GetWasLooking()
return self.wasLooking return self.wasLooking
end end
-- Click the spell -- Click the spell
---@param x number
---@param y number
---@param z number
---@return boolean
function Spell:Click(x, y, z) function Spell:Click(x, y, z)
if type(x) == 'table' then if type(x) == 'table' then
x, y, z = x.x, x.y, x.z x, y, z = x.x, x.y, x.z
@ -222,6 +256,8 @@ function Spell:Click(x, y, z)
end end
-- Check if the spell is castable and cast it -- Check if the spell is castable and cast it
---@param unit Unit
---@return boolean
function Spell:Call(unit) function Spell:Call(unit)
if self:Castable() then if self:Castable() then
self:Cast(unit) self:Cast(unit)
@ -230,11 +266,15 @@ function Spell:Call(unit)
return false return false
end end
-- Check if the spell is castable and cast it
---@return boolean
function Spell:HasRange() function Spell:HasRange()
return SpellHasRange(self:GetName()) return SpellHasRange(self:GetName())
end end
-- Check if the spell is in range of the unit -- Check if the spell is in range of the unit
---@param unit Unit
---@return boolean
function Spell:IsInRange(unit) function Spell:IsInRange(unit)
local hasRange = self:HasRange() local hasRange = self:HasRange()
local inRange = IsSpellInRange(self:GetName(), unit:GetOMToken()) local inRange = IsSpellInRange(self:GetName(), unit:GetOMToken())
@ -251,11 +291,13 @@ function Spell:IsInRange(unit)
end end
-- Get the last cast time -- Get the last cast time
---@return number
function Spell:GetLastCastTime() function Spell:GetLastCastTime()
return self.lastCastAt return self.lastCastAt
end end
-- Get time since last cast -- Get time since last cast
---@return number
function Spell:GetTimeSinceLastCast() function Spell:GetTimeSinceLastCast()
if not self:GetLastCastTime() then if not self:GetLastCastTime() then
return math.huge return math.huge
@ -264,10 +306,13 @@ function Spell:GetTimeSinceLastCast()
end end
-- Get the spells charges -- Get the spells charges
---@return number
function Spell:GetCharges() function Spell:GetCharges()
return GetSpellCharges(self:GetID()) return GetSpellCharges(self:GetID())
end end
-- Get the spells charges
---@return number
function Spell:GetChargesFractional() function Spell:GetChargesFractional()
local charges, maxCharges, start, duration = GetSpellCharges(self:GetID()) local charges, maxCharges, start, duration = GetSpellCharges(self:GetID())
@ -288,12 +333,16 @@ function Spell:GetChargesFractional()
end end
-- Get the spells charges remaining -- Get the spells charges remaining
---@return number
function Spell:GetChargesRemaining() function Spell:GetChargesRemaining()
local charges, maxCharges, start, duration = GetSpellCharges(self:GetID()) local charges, maxCharges, start, duration = GetSpellCharges(self:GetID())
return charges return charges
end end
-- Create a condition for the spell -- Create a condition for the spell
---@param name string
---@param func fun(self:Spell):boolean
---@return Spell
function Spell:Condition(name, func) function Spell:Condition(name, func)
self.conditions[name] = { self.conditions[name] = {
func = func func = func
@ -302,6 +351,8 @@ function Spell:Condition(name, func)
end end
-- Get a condition for the spell -- Get a condition for the spell
---@param name string
---@return function | nil
function Spell:GetCondition(name) function Spell:GetCondition(name)
local condition = self.conditions[name] local condition = self.conditions[name]
if condition then if condition then
@ -312,6 +363,8 @@ function Spell:GetCondition(name)
end end
-- Evaluate a condition for the spell -- Evaluate a condition for the spell
---@param name string
---@return boolean
function Spell:EvaluateCondition(name) function Spell:EvaluateCondition(name)
local condition = self:GetCondition(name) local condition = self:GetCondition(name)
if condition then if condition then
@ -322,6 +375,8 @@ function Spell:EvaluateCondition(name)
end end
-- Check if the spell has a condition -- Check if the spell has a condition
---@param name string
---@return boolean
function Spell:HasCondition(name) function Spell:HasCondition(name)
local condition = self:GetCondition(name) local condition = self:GetCondition(name)
if condition then if condition then
@ -332,17 +387,21 @@ function Spell:HasCondition(name)
end end
-- Set the spells target -- Set the spells target
---@param unit Unit
---@return Spell
function Spell:SetTarget(unit) function Spell:SetTarget(unit)
self.target = unit self.target = unit
return self return self
end end
-- Get the spells target -- Get the spells target
---@return Unit
function Spell:GetTarget() function Spell:GetTarget()
return self.target return self.target
end end
-- IsMagicDispel -- IsMagicDispel
---@return boolean
function Spell:IsMagicDispel() function Spell:IsMagicDispel()
return ({ return ({
[88423] = true [88423] = true
@ -350,6 +409,7 @@ function Spell:IsMagicDispel()
end end
-- IsCurseDispel -- IsCurseDispel
---@return boolean
function Spell:IsCurseDispel() function Spell:IsCurseDispel()
return ({ return ({
[88423] = true [88423] = true
@ -357,6 +417,7 @@ function Spell:IsCurseDispel()
end end
-- IsPoisonDispel -- IsPoisonDispel
---@return boolean
function Spell:IsPoisonDispel() function Spell:IsPoisonDispel()
return ({ return ({
[88423] = true [88423] = true
@ -364,12 +425,16 @@ function Spell:IsPoisonDispel()
end end
-- IsDiseaseDispel -- IsDiseaseDispel
---@return boolean
function Spell:IsDiseaseDispel() function Spell:IsDiseaseDispel()
return ({ return ({
})[self:GetID()] })[self:GetID()]
end end
-- IsSpell
---@param spell Spell
---@return boolean
function Spell:IsSpell(spell) function Spell:IsSpell(spell)
return self:GetID() == spell:GetID() return self:GetID() == spell:GetID()
end end

@ -9,6 +9,8 @@ local Timer = {
Timer.__index = Timer Timer.__index = Timer
-- Constructor -- Constructor
---@param type string
---@return Timer
function Timer:New(type) function Timer:New(type)
local self = setmetatable({}, Timer) local self = setmetatable({}, Timer)
self.startTime = nil self.startTime = nil
@ -17,11 +19,13 @@ function Timer:New(type)
end end
-- Start the timer -- Start the timer
---@return nil
function Timer:Start() function Timer:Start()
self.startTime = GetTime() self.startTime = GetTime()
end end
-- Get the time since the timer was started -- Get the time since the timer was started
---@return number
function Timer:GetTime() function Timer:GetTime()
if not self:IsRunning() then if not self:IsRunning() then
return 0 return 0
@ -30,11 +34,13 @@ function Timer:GetTime()
end end
-- Check if the timer is running -- Check if the timer is running
---@return boolean
function Timer:IsRunning() function Timer:IsRunning()
return self.startTime ~= nil return self.startTime ~= nil
end end
-- Reset the timer -- Reset the timer
---@return nil
function Timer:Reset() function Timer:Reset()
self.startTime = nil self.startTime = nil
end end

@ -34,16 +34,21 @@ function Unit:__index(k)
end end
-- Equals -- Equals
---@param other Unit
---@return boolean
function Unit:__eq(other) function Unit:__eq(other)
return UnitIsUnit(self:GetOMToken(), other.unit) return UnitIsUnit(self:GetOMToken(), other.unit)
end end
-- tostring -- tostring
---@return string
function Unit:__tostring() function Unit:__tostring()
return "Bastion.__Unit(" .. tostring(self:GetOMToken()) .. ")" .. " - " .. (self:GetName() or '') return "Bastion.__Unit(" .. tostring(self:GetOMToken()) .. ")" .. " - " .. (self:GetName() or '')
end end
-- Constructor -- Constructor
---@param unit string
---@return Unit
function Unit:New(unit) function Unit:New(unit)
local self = setmetatable({}, Unit) local self = setmetatable({}, Unit)
self.unit = unit self.unit = unit
@ -54,85 +59,107 @@ function Unit:New(unit)
end end
-- Check if the unit is valid -- Check if the unit is valid
---@return boolean
function Unit:IsValid() function Unit:IsValid()
return self:GetOMToken() ~= nil and self:Exists() return self:GetOMToken() ~= nil and self:Exists()
end end
-- Check if the unit exists -- Check if the unit exists
---@return boolean
function Unit:Exists() function Unit:Exists()
return Object(self:GetOMToken()) return Object(self:GetOMToken())
end end
-- Get the units token -- Get the units token
---@return string
function Unit:Token() function Unit:Token()
return self:GetOMToken() return self:GetOMToken()
end end
-- Get the units name -- Get the units name
---@return string
function Unit:GetName() function Unit:GetName()
return UnitName(self:GetOMToken()) return UnitName(self:GetOMToken())
end end
-- Get the units GUID -- Get the units GUID
---@return string
function Unit:GetGUID() function Unit:GetGUID()
return ObjectGUID(self:GetOMToken()) return ObjectGUID(self:GetOMToken())
end end
-- Get the units health -- Get the units health
---@return number
function Unit:GetHealth() function Unit:GetHealth()
return UnitHealth(self:GetOMToken()) return UnitHealth(self:GetOMToken())
end end
-- Get the units max health -- Get the units max health
---@return number
function Unit:GetMaxHealth() function Unit:GetMaxHealth()
return UnitHealthMax(self:GetOMToken()) return UnitHealthMax(self:GetOMToken())
end end
-- Get the units health percentage -- Get the units health percentage
---@return number
function Unit:GetHP() function Unit:GetHP()
return self:GetHealth() / self:GetMaxHealth() * 100 return self:GetHealth() / self:GetMaxHealth() * 100
end end
-- Get the units health deficit
---@return number
function Unit:GetHealthPercent() function Unit:GetHealthPercent()
return self:GetHP() return self:GetHP()
end end
-- Get the units power type -- Get the units power type
---@return number
function Unit:GetPowerType() function Unit:GetPowerType()
return UnitPowerType(self:GetOMToken()) return UnitPowerType(self:GetOMToken())
end end
-- Get the units power -- Get the units power
---@param powerType number | nil
---@return number
function Unit:GetPower(powerType) function Unit:GetPower(powerType)
local powerType = powerType or self:GetPowerType() local powerType = powerType or self:GetPowerType()
return UnitPower(self:GetOMToken(), powerType) return UnitPower(self:GetOMToken(), powerType)
end end
-- Get the units max power -- Get the units max power
---@param powerType number | nil
---@return number
function Unit:GetMaxPower(powerType) function Unit:GetMaxPower(powerType)
local powerType = powerType or self:GetPowerType() local powerType = powerType or self:GetPowerType()
return UnitPowerMax(self:GetOMToken(), powerType) return UnitPowerMax(self:GetOMToken(), powerType)
end end
-- Get the units power percentage -- Get the units power percentage
---@param powerType number | nil
---@return number
function Unit:GetPP(powerType) function Unit:GetPP(powerType)
local powerType = powerType or self:GetPowerType() local powerType = powerType or self:GetPowerType()
return self:GetPower(powerType) / self:GetMaxPower(powerType) * 100 return self:GetPower(powerType) / self:GetMaxPower(powerType) * 100
end end
-- Get the units power deficit -- Get the units power deficit
---@param powerType number | nil
---@return number
function Unit:GetPowerDeficit(powerType) function Unit:GetPowerDeficit(powerType)
local powerType = powerType or self:GetPowerType() local powerType = powerType or self:GetPowerType()
return self:GetMaxPower(powerType) - self:GetPower(powerType) return self:GetMaxPower(powerType) - self:GetPower(powerType)
end end
-- Get the units position -- Get the units position
---@return Vector3
function Unit:GetPosition() function Unit:GetPosition()
local x, y, z = ObjectPosition(self:GetOMToken()) local x, y, z = ObjectPosition(self:GetOMToken())
return Bastion.Vector3:New(x, y, z) return Bastion.Vector3:New(x, y, z)
end end
-- Get the units distance from another unit -- Get the units distance from another unit
---@param unit Unit
---@return number
function Unit:GetDistance(unit) function Unit:GetDistance(unit)
local pself = self:GetPosition() local pself = self:GetPosition()
local punit = unit:GetPosition() local punit = unit:GetPosition()
@ -141,36 +168,43 @@ function Unit:GetDistance(unit)
end end
-- Is the unit dead -- Is the unit dead
---@return boolean
function Unit:IsDead() function Unit:IsDead()
return UnitIsDeadOrGhost(self:GetOMToken()) return UnitIsDeadOrGhost(self:GetOMToken())
end end
-- Is the unit alive -- Is the unit alive
---@return boolean
function Unit:IsAlive() function Unit:IsAlive()
return not UnitIsDeadOrGhost(self:GetOMToken()) return not UnitIsDeadOrGhost(self:GetOMToken())
end end
-- Is the unit a pet -- Is the unit a pet
---@return boolean
function Unit:IsPet() function Unit:IsPet()
return UnitIsUnit(self:GetOMToken(), "pet") return UnitIsUnit(self:GetOMToken(), "pet")
end end
-- Is the unit a friendly unit -- Is the unit a friendly unit
---@return boolean
function Unit:IsFriendly() function Unit:IsFriendly()
return UnitIsFriend("player", self:GetOMToken()) return UnitIsFriend("player", self:GetOMToken())
end end
-- IsEnemy -- IsEnemy
---@return boolean
function Unit:IsEnemy() function Unit:IsEnemy()
return UnitCanAttack("player", self:GetOMToken()) return UnitCanAttack("player", self:GetOMToken())
end end
-- Is the unit a hostile unit -- Is the unit a hostile unit
---@return boolean
function Unit:IsHostile() function Unit:IsHostile()
return UnitCanAttack(self:GetOMToken(), 'player') return UnitCanAttack(self:GetOMToken(), 'player')
end end
-- Is the unit a boss -- Is the unit a boss
---@return boolean
function Unit:IsBoss() function Unit:IsBoss()
if UnitClassification(self:GetOMToken()) == "worldboss" then if UnitClassification(self:GetOMToken()) == "worldboss" then
return true return true
@ -187,6 +221,7 @@ function Unit:IsBoss()
return false return false
end end
---@return string
function Unit:GetOMToken() function Unit:GetOMToken()
if not self.unit then if not self.unit then
return "none" return "none"
@ -195,51 +230,61 @@ function Unit:GetOMToken()
end end
-- Is the unit a target -- Is the unit a target
---@return boolean
function Unit:IsTarget() function Unit:IsTarget()
return UnitIsUnit(self:GetOMToken(), "target") return UnitIsUnit(self:GetOMToken(), "target")
end end
-- Is the unit a focus -- Is the unit a focus
---@return boolean
function Unit:IsFocus() function Unit:IsFocus()
return UnitIsUnit(self:GetOMToken(), "focus") return UnitIsUnit(self:GetOMToken(), "focus")
end end
-- Is the unit a mouseover -- Is the unit a mouseover
---@return boolean
function Unit:IsMouseover() function Unit:IsMouseover()
return UnitIsUnit(self:GetOMToken(), "mouseover") return UnitIsUnit(self:GetOMToken(), "mouseover")
end end
-- Is the unit a tank -- Is the unit a tank
---@return boolean
function Unit:IsTank() function Unit:IsTank()
return UnitGroupRolesAssigned(self:GetOMToken()) == "TANK" return UnitGroupRolesAssigned(self:GetOMToken()) == "TANK"
end end
-- Is the unit a healer -- Is the unit a healer
---@return boolean
function Unit:IsHealer() function Unit:IsHealer()
return UnitGroupRolesAssigned(self:GetOMToken()) == "HEALER" return UnitGroupRolesAssigned(self:GetOMToken()) == "HEALER"
end end
-- Is the unit a damage dealer -- Is the unit a damage dealer
---@return boolean
function Unit:IsDamage() function Unit:IsDamage()
return UnitGroupRolesAssigned(self:GetOMToken()) == "DAMAGER" return UnitGroupRolesAssigned(self:GetOMToken()) == "DAMAGER"
end end
-- Is the unit a player -- Is the unit a player
---@return boolean
function Unit:IsPlayer() function Unit:IsPlayer()
return UnitIsPlayer(self:GetOMToken()) return UnitIsPlayer(self:GetOMToken())
end end
-- Is the unit a player controlled unit -- Is the unit a player controlled unit
---@return boolean
function Unit:IsPCU() function Unit:IsPCU()
return UnitPlayerControlled(self:GetOMToken()) return UnitPlayerControlled(self:GetOMToken())
end end
-- Get if the unit is affecting combat -- Get if the unit is affecting combat
---@return boolean
function Unit:IsAffectingCombat() function Unit:IsAffectingCombat()
return UnitAffectingCombat(self:GetOMToken()) return UnitAffectingCombat(self:GetOMToken())
end end
-- Get the units class id -- Get the units class id
---@return Class
function Unit:GetClass() function Unit:GetClass()
local locale, class, classID = UnitClass(self:GetOMToken()) local locale, class, classID = UnitClass(self:GetOMToken())
return Bastion.Class:New(locale, class, classID) return Bastion.Class:New(locale, class, classID)
@ -252,6 +297,7 @@ function Unit:GetAuras()
end end
-- Get the raw unit -- Get the raw unit
---@return string
function Unit:GetRawUnit() function Unit:GetRawUnit()
return self:GetOMToken() return self:GetOMToken()
end end
@ -266,6 +312,8 @@ local isClassicWow = select(4, GetBuildInfo()) < 40000
local losFlag = bit.bor(0x1, 0x10, 0x100000) local losFlag = bit.bor(0x1, 0x10, 0x100000)
-- Check if the unit can see another unit -- Check if the unit can see another unit
---@param unit Unit
---@return boolean
function Unit:CanSee(unit) function Unit:CanSee(unit)
-- mechagon smoke cloud -- mechagon smoke cloud
-- local mechagonID = 2097 -- local mechagonID = 2097
@ -311,11 +359,13 @@ function Unit:CanSee(unit)
end end
-- Check if the unit is casting a spell -- Check if the unit is casting a spell
---@return boolean
function Unit:IsCasting() function Unit:IsCasting()
return UnitCastingInfo(self:GetOMToken()) ~= nil return UnitCastingInfo(self:GetOMToken()) ~= nil
end end
-- Get Casting or channeling spell -- Get Casting or channeling spell
---@return Spell | nil
function Unit:GetCastingOrChannelingSpell() function Unit:GetCastingOrChannelingSpell()
local name, text, texture, startTimeMS, endTimeMS, isTradeSkill, castID, notInterruptible, spellId = UnitCastingInfo(self local name, text, texture, startTimeMS, endTimeMS, isTradeSkill, castID, notInterruptible, spellId = UnitCastingInfo(self
.unit) .unit)
@ -333,20 +383,25 @@ function Unit:GetCastingOrChannelingSpell()
end end
-- Check if the unit is channeling a spell -- Check if the unit is channeling a spell
---@return boolean
function Unit:IsChanneling() function Unit:IsChanneling()
return UnitChannelInfo(self:GetOMToken()) ~= nil return UnitChannelInfo(self:GetOMToken()) ~= nil
end end
-- Check if the unit is casting or channeling a spell -- Check if the unit is casting or channeling a spell
---@return boolean
function Unit:IsCastingOrChanneling() function Unit:IsCastingOrChanneling()
return self:IsCasting() or self:IsChanneling() return self:IsCasting() or self:IsChanneling()
end end
-- Check if the unit can attack the target -- Check if the unit can attack the target
---@param unit Unit
---@return boolean
function Unit:CanAttack(unit) function Unit:CanAttack(unit)
return UnitCanAttack(self:GetOMToken(), unit:GetOMToken()) return UnitCanAttack(self:GetOMToken(), unit:GetOMToken())
end end
---@return number
function Unit:GetChannelOrCastPercentComplete() function Unit:GetChannelOrCastPercentComplete()
local name, text, texture, startTimeMS, endTimeMS, isTradeSkill, castID, notInterruptible, spellId = UnitCastingInfo(self local name, text, texture, startTimeMS, endTimeMS, isTradeSkill, castID, notInterruptible, spellId = UnitCastingInfo(self
.unit) .unit)
@ -366,6 +421,8 @@ function Unit:GetChannelOrCastPercentComplete()
return 0 return 0
end end
-- Check if unit is interruptible
---@return boolean
function Unit:IsInterruptible() function Unit:IsInterruptible()
local name, text, texture, startTimeMS, endTimeMS, isTradeSkill, castID, notInterruptible, spellId = UnitCastingInfo(self local name, text, texture, startTimeMS, endTimeMS, isTradeSkill, castID, notInterruptible, spellId = UnitCastingInfo(self
.unit) .unit)
@ -383,6 +440,8 @@ function Unit:IsInterruptible()
end end
-- Check if unit is interruptible -- Check if unit is interruptible
---@param percent number
---@return boolean
function Unit:IsInterruptibleAt(percent) function Unit:IsInterruptibleAt(percent)
if not self:IsInterruptible() then if not self:IsInterruptible() then
return false return false
@ -399,6 +458,8 @@ function Unit:IsInterruptibleAt(percent)
end end
-- Get the number of enemies in a given range of the unit and cache the result for .5 seconds -- Get the number of enemies in a given range of the unit and cache the result for .5 seconds
---@param range number
---@return number
function Unit:GetEnemies(range) function Unit:GetEnemies(range)
local enemies = self.cache:Get("enemies_" .. range) local enemies = self.cache:Get("enemies_" .. range)
if enemies then if enemies then
@ -419,6 +480,7 @@ function Unit:GetEnemies(range)
end end
-- Get the number of melee attackers -- Get the number of melee attackers
---@return number
function Unit:GetMeleeAttackers() function Unit:GetMeleeAttackers()
local enemies = self.cache:Get("melee_attackers") local enemies = self.cache:Get("melee_attackers")
if enemies then if enemies then
@ -438,6 +500,9 @@ function Unit:GetMeleeAttackers()
return count return count
end end
---@param distance number
---@param percent number
---@return number
function Unit:GetPartyHPAround(distance, percent) function Unit:GetPartyHPAround(distance, percent)
local count = 0 local count = 0
@ -452,33 +517,43 @@ function Unit:GetPartyHPAround(distance, percent)
end end
-- Is moving -- Is moving
---@return boolean
function Unit:IsMoving() function Unit:IsMoving()
return GetUnitSpeed(self:GetOMToken()) > 0 return GetUnitSpeed(self:GetOMToken()) > 0
end end
-- Is moving at all
---@return boolean
function Unit:IsMovingAtAll() function Unit:IsMovingAtAll()
return ObjectMovementFlag(self:GetOMToken()) ~= 0 return ObjectMovementFlag(self:GetOMToken()) ~= 0
end end
---@return number
function Unit:GetComboPoints() function Unit:GetComboPoints()
return UnitPower(self:GetOMToken(), 4) return UnitPower(self:GetOMToken(), 4)
end end
---@return number
function Unit:GetComboPointsMax() function Unit:GetComboPointsMax()
return UnitPowerMax(self:GetOMToken(), 4) return UnitPowerMax(self:GetOMToken(), 4)
end end
-- Get combopoints deficit -- Get combopoints deficit
---@return number
function Unit:GetComboPointsDeficit() function Unit:GetComboPointsDeficit()
return self:GetComboPointsMax() - self:GetComboPoints() return self:GetComboPointsMax() - self:GetComboPoints()
end end
-- IsUnit -- IsUnit
---@param unit Unit
---@return boolean
function Unit:IsUnit(unit) function Unit:IsUnit(unit)
return UnitIsUnit(self:GetOMToken(), unit and unit:GetOMToken() or 'none') return UnitIsUnit(self:GetOMToken(), unit and unit:GetOMToken() or 'none')
end end
-- IsTanking -- IsTanking
---@param unit Unit
---@return boolean
function Unit:IsTanking(unit) function Unit:IsTanking(unit)
local isTanking, status, threatpct, rawthreatpct, threatvalue = UnitDetailedThreatSituation(self:GetOMToken(), local isTanking, status, threatpct, rawthreatpct, threatvalue = UnitDetailedThreatSituation(self:GetOMToken(),
unit:GetOMToken()) unit:GetOMToken())
@ -486,6 +561,8 @@ function Unit:IsTanking(unit)
end end
-- IsFacing -- IsFacing
---@param unit Unit
---@return boolean
function Unit:IsFacing(unit) function Unit:IsFacing(unit)
local rot = ObjectRotation(self:GetOMToken()) local rot = ObjectRotation(self:GetOMToken())
local x, y, z = ObjectPosition(self:GetOMToken()) local x, y, z = ObjectPosition(self:GetOMToken())
@ -506,6 +583,8 @@ function Unit:IsFacing(unit)
end end
-- IsBehind -- IsBehind
---@param unit Unit
---@return boolean
function Unit:IsBehind(unit) function Unit:IsBehind(unit)
local rot = ObjectRotation(unit:GetOMToken()) local rot = ObjectRotation(unit:GetOMToken())
local x, y, z = ObjectPosition(unit:GetOMToken()) local x, y, z = ObjectPosition(unit:GetOMToken())
@ -525,6 +604,7 @@ function Unit:IsBehind(unit)
return math.abs(angle) > 90 return math.abs(angle) > 90
end end
---@return number
function Unit:GetMeleeBoost() function Unit:GetMeleeBoost()
if IsPlayerSpell(196924) then if IsPlayerSpell(196924) then
return 3 return 3
@ -540,6 +620,8 @@ end
-- return ((myPos.x - targetPos.x) * (myPos.x - targetPos.x)) + ((myPos.y - targetPos.y) * (myPos.y - targetPos.y)) + ((myPos.z - targetPos.z) * (myPos.z - targetPos.z)) <= (float)(fMaxDist * fMaxDist); -- return ((myPos.x - targetPos.x) * (myPos.x - targetPos.x)) + ((myPos.y - targetPos.y) * (myPos.y - targetPos.y)) + ((myPos.z - targetPos.z) * (myPos.z - targetPos.z)) <= (float)(fMaxDist * fMaxDist);
-- InMelee -- InMelee
---@param unit Unit
---@return boolean
function Unit:InMelee(unit) function Unit:InMelee(unit)
local x, y, z = ObjectPosition(self:GetOMToken()) local x, y, z = ObjectPosition(self:GetOMToken())
local x2, y2, z2 = ObjectPosition(unit:GetOMToken()) local x2, y2, z2 = ObjectPosition(unit:GetOMToken())
@ -556,16 +638,21 @@ function Unit:InMelee(unit)
end end
-- Get object id -- Get object id
---@return number
function Unit:GetID() function Unit:GetID()
return ObjectID(self:GetOMToken()) return ObjectID(self:GetOMToken())
end end
-- In party -- In party
---@return boolean
function Unit:IsInParty() function Unit:IsInParty()
return UnitInParty(self:GetOMToken()) return UnitInParty(self:GetOMToken())
end end
-- Linear regression between time and percent to something -- Linear regression between time and percent to something
---@param time table
---@param percent table
---@return number, number
function Unit:LinearRegression(time, percent) function Unit:LinearRegression(time, percent)
local x = time local x = time
local y = percent local y = percent
@ -592,6 +679,8 @@ function Unit:LinearRegression(time, percent)
end end
-- Use linear regression to get the health percent at a given time in the future -- Use linear regression to get the health percent at a given time in the future
---@param time number
---@return number
function Unit:PredictHealth(time) function Unit:PredictHealth(time)
local x = {} local x = {}
local y = {} local y = {}
@ -613,6 +702,8 @@ function Unit:PredictHealth(time)
end end
-- Use linear regression to guess the time until a given health percent -- Use linear regression to guess the time until a given health percent
---@param percent number
---@return number
function Unit:PredictTime(percent) function Unit:PredictTime(percent)
local x = {} local x = {}
local y = {} local y = {}
@ -634,6 +725,7 @@ function Unit:PredictTime(percent)
end end
-- Time until death -- Time until death
---@return number
function Unit:TimeToDie() function Unit:TimeToDie()
if self:IsDead() then if self:IsDead() then
self.regression_history = {} self.regression_history = {}
@ -650,16 +742,21 @@ function Unit:TimeToDie()
end end
-- Set combat time if affecting combat and return the difference between now and the last time -- Set combat time if affecting combat and return the difference between now and the last time
---@return number
function Unit:GetCombatTime() function Unit:GetCombatTime()
return GetTime() - self.last_combat_time return GetTime() - self.last_combat_time
end end
-- Set last combat time
---@param time number
---@return nil
function Unit:SetLastCombatTime(time) function Unit:SetLastCombatTime(time)
self.last_combat_time = time self.last_combat_time = time
end end
-- Get combat odds (if the last combat time is less than 1 minute ago return 1 / time, else return 0) -- Get combat odds (if the last combat time is less than 1 minute ago return 1 / time, else return 0)
-- the closer to 0 the more likely the unit is to be in combat (0 = 100%) 60 = 0% -- the closer to 0 the more likely the unit is to be in combat (0 = 100%) 60 = 0%
---@return number
function Unit:InCombatOdds() function Unit:InCombatOdds()
local time = self:GetCombatTime() local time = self:GetCombatTime()
local percent = 1 - (time / 60) local percent = 1 - (time / 60)
@ -668,6 +765,7 @@ function Unit:InCombatOdds()
end end
-- Get units gcd time -- Get units gcd time
---@return number
function Unit:GetGCD() function Unit:GetGCD()
local start, duration = GetSpellCooldown(61304) local start, duration = GetSpellCooldown(61304)
if start == 0 then if start == 0 then
@ -686,6 +784,7 @@ The GCD won't drop below 1 second
More than 50% Haste will drop a spell below 1 second More than 50% Haste will drop a spell below 1 second
]] ]]
---@return number
function Unit:GetMaxGCD() function Unit:GetMaxGCD()
local haste = UnitSpellHaste(self:GetOMToken()) local haste = UnitSpellHaste(self:GetOMToken())
if haste > 50 then if haste > 50 then
@ -696,6 +795,7 @@ function Unit:GetMaxGCD()
end end
-- IsStealthed -- IsStealthed
---@return boolean
function Unit:IsStealthed() function Unit:IsStealthed()
local Stealth = Bastion.SpellBook:GetSpell(1784) local Stealth = Bastion.SpellBook:GetSpell(1784)
local Vanish = Bastion.SpellBook:GetSpell(1856) local Vanish = Bastion.SpellBook:GetSpell(1856)
@ -709,6 +809,7 @@ function Unit:IsStealthed()
end end
-- Get unit swing timers -- Get unit swing timers
---@return number, number
function Unit:GetSwingTimers() function Unit:GetSwingTimers()
local main_speed, off_speed = UnitAttackSpeed(self:GetOMToken()) local main_speed, off_speed = UnitAttackSpeed(self:GetOMToken())
local main_speed = main_speed or 2 local main_speed = main_speed or 2
@ -728,6 +829,7 @@ function Unit:GetSwingTimers()
return main_speed_remains, off_speed_remains return main_speed_remains, off_speed_remains
end end
---@return nil
function Unit:WatchForSwings() function Unit:WatchForSwings()
Bastion.EventManager:RegisterWoWEvent("COMBAT_LOG_EVENT_UNFILTERED", function() Bastion.EventManager:RegisterWoWEvent("COMBAT_LOG_EVENT_UNFILTERED", function()
local _, subtype, _, sourceGUID, sourceName, _, _, destGUID, destName, destFlags, _, spellID, spellName, _, amount, interrupt, a, b, c, d, offhand, multistrike = CombatLogGetCurrentEventInfo() local _, subtype, _, sourceGUID, sourceName, _, _, destGUID, destName, destFlags, _, spellID, spellName, _, amount, interrupt, a, b, c, d, offhand, multistrike = CombatLogGetCurrentEventInfo()

@ -99,6 +99,7 @@ function UnitManager:__index(k)
end end
-- Constructor -- Constructor
---@return UnitManager
function UnitManager:New() function UnitManager:New()
local self = setmetatable({}, UnitManager) local self = setmetatable({}, UnitManager)
self.units = {} self.units = {}
@ -112,6 +113,7 @@ function UnitManager:Validate(token)
end end
-- Get or create a unit -- Get or create a unit
---@param token string
---@return Unit ---@return Unit
function UnitManager:Get(token) function UnitManager:Get(token)
-- if not Validate(token) then -- if not Validate(token) then
@ -142,10 +144,16 @@ function UnitManager:Get(token)
end) end)
end end
-- Get a unit by guid
---@param guid string
---@return Unit
function UnitManager:GetObject(guid) function UnitManager:GetObject(guid)
return self.objects[guid] return self.objects[guid]
end end
-- Set a unit by guid
---@param unit Unit
---@return Unit
function UnitManager:SetObject(unit) function UnitManager:SetObject(unit)
self.objects[unit:GetGUID()] = unit self.objects[unit:GetGUID()] = unit
end end
@ -175,6 +183,8 @@ function UnitManager:CreateCustomUnit(token, cb)
end end
-- Enum Friends (party/raid members) -- Enum Friends (party/raid members)
---@param cb fun(unit: Unit):boolean
---@return nil
function UnitManager:EnumFriends(cb) function UnitManager:EnumFriends(cb)
Bastion.ObjectManager.friends:each(function(unit) Bastion.ObjectManager.friends:each(function(unit)
if cb(unit) then if cb(unit) then
@ -185,6 +195,7 @@ end
-- Enum Enemies (object manager) -- Enum Enemies (object manager)
---@param cb fun(unit: Unit):boolean ---@param cb fun(unit: Unit):boolean
---@return nil
function UnitManager:EnumEnemies(cb) function UnitManager:EnumEnemies(cb)
Bastion.ObjectManager.activeEnemies:each(function(unit) Bastion.ObjectManager.activeEnemies:each(function(unit)
if cb(unit) then if cb(unit) then
@ -194,6 +205,8 @@ function UnitManager:EnumEnemies(cb)
end end
-- Enum Units (object manager) -- Enum Units (object manager)
---@param cb fun(unit: Unit):boolean
---@return nil
function UnitManager:EnumUnits(cb) function UnitManager:EnumUnits(cb)
Bastion.ObjectManager.enemies:each(function(unit) Bastion.ObjectManager.enemies:each(function(unit)
if cb(unit) then if cb(unit) then
@ -203,6 +216,8 @@ function UnitManager:EnumUnits(cb)
end end
-- Get the number of friends with a buff (party/raid members) -- Get the number of friends with a buff (party/raid members)
---@param spell Spell
---@return number
function UnitManager:GetNumFriendsWithBuff(spell) function UnitManager:GetNumFriendsWithBuff(spell)
local count = 0 local count = 0
self:EnumFriends(function(unit) self:EnumFriends(function(unit)
@ -214,6 +229,7 @@ function UnitManager:GetNumFriendsWithBuff(spell)
end end
-- Get the number of friends alive (party/raid members) -- Get the number of friends alive (party/raid members)
---@return number
function UnitManager:GetNumFriendsAlive() function UnitManager:GetNumFriendsAlive()
local count = 0 local count = 0
self:EnumFriends(function(unit) self:EnumFriends(function(unit)
@ -225,7 +241,9 @@ function UnitManager:GetNumFriendsAlive()
end end
-- Get the friend with the most friends within a given radius (party/raid members) -- Get the friend with the most friends within a given radius (party/raid members)
-- Return unit, friends ---@param radius number
---@return Unit
---@return table
function UnitManager:GetFriendWithMostFriends(radius) function UnitManager:GetFriendWithMostFriends(radius)
local unit = nil local unit = nil
local count = 0 local count = 0
@ -254,6 +272,9 @@ function UnitManager:GetFriendWithMostFriends(radius)
end end
-- Find the centroid of the most dense area of friends (party/raid members) of a given radius within a given range -- Find the centroid of the most dense area of friends (party/raid members) of a given radius within a given range
---@param radius number
---@param range number
---@return Vector3 | nil
function UnitManager:FindFriendsCentroid(radius, range) function UnitManager:FindFriendsCentroid(radius, range)
local unit, friends = self:GetFriendWithMostFriends(radius) local unit, friends = self:GetFriendWithMostFriends(radius)
if unit == nil then if unit == nil then

@ -4,14 +4,19 @@
local Vector3 = {} local Vector3 = {}
Vector3.__index = Vector3 Vector3.__index = Vector3
---@return string
function Vector3:__tostring() function Vector3:__tostring()
return "Vector3(" .. self.x .. ", " .. self.y .. ", " .. self.z .. ")" return "Vector3(" .. self.x .. ", " .. self.y .. ", " .. self.z .. ")"
end end
---@param other Vector3
---@return Vector3
function Vector3:__add(other) function Vector3:__add(other)
return Vector3:New(self.x + other.x, self.y + other.y, self.z + other.z) return Vector3:New(self.x + other.x, self.y + other.y, self.z + other.z)
end end
---@param other Vector3
---@return Vector3
function Vector3:__sub(other) function Vector3:__sub(other)
if type(other) == "number" then if type(other) == "number" then
return Vector3:New(self.x - other, self.y - other, self.z - other) return Vector3:New(self.x - other, self.y - other, self.z - other)
@ -19,30 +24,42 @@ function Vector3:__sub(other)
return Vector3:New(self.x - other.x, self.y - other.y, self.z - other.z) return Vector3:New(self.x - other.x, self.y - other.y, self.z - other.z)
end end
---@param other number
---@return Vector3
function Vector3:__mul(other) function Vector3:__mul(other)
return Vector3:New(self.x * other, self.y * other, self.z * other) return Vector3:New(self.x * other, self.y * other, self.z * other)
end end
---@param other number
---@return Vector3
function Vector3:__div(other) function Vector3:__div(other)
return Vector3:New(self.x / other, self.y / other, self.z / other) return Vector3:New(self.x / other, self.y / other, self.z / other)
end end
---@param other Vector3
---@return boolean
function Vector3:__eq(other) function Vector3:__eq(other)
return self.x == other.x and self.y == other.y and self.z == other.z return self.x == other.x and self.y == other.y and self.z == other.z
end end
---@param other Vector3
---@return boolean
function Vector3:__lt(other) function Vector3:__lt(other)
return self.x < other.x and self.y < other.y and self.z < other.z return self.x < other.x and self.y < other.y and self.z < other.z
end end
---@param other Vector3
---@return boolean
function Vector3:__le(other) function Vector3:__le(other)
return self.x <= other.x and self.y <= other.y and self.z <= other.z return self.x <= other.x and self.y <= other.y and self.z <= other.z
end end
---@return Vector3
function Vector3:__unm() function Vector3:__unm()
return Vector3:New(-self.x, -self.y, -self.z) return Vector3:New(-self.x, -self.y, -self.z)
end end
---@return number
function Vector3:__len() function Vector3:__len()
return math.sqrt(self.x * self.x + self.y * self.y + self.z * self.z) return math.sqrt(self.x * self.x + self.y * self.y + self.z * self.z)
end end
@ -152,6 +169,10 @@ function Vector3:__newindex(k, v)
end end
end end
---@param x number
---@param y number
---@param z number
---@return Vector3
function Vector3:New(x, y, z) function Vector3:New(x, y, z)
if x == false then if x == false then
return Vector3:New(0, 0, 0) return Vector3:New(0, 0, 0)
@ -161,18 +182,26 @@ function Vector3:New(x, y, z)
return self return self
end end
---@param rhs Vector3
---@return number
function Vector3:Dot(rhs) function Vector3:Dot(rhs)
return self.x * rhs.x + self.y * rhs.y + self.z * rhs.z return self.x * rhs.x + self.y * rhs.y + self.z * rhs.z
end end
---@param rhs Vector3
---@return Vector3
function Vector3:Cross(rhs) function Vector3:Cross(rhs)
return Vector3:New(self.y * rhs.z - self.z * rhs.y, self.z * rhs.x - self.x * rhs.z, self.x * rhs.y - self.y * rhs.x) return Vector3:New(self.y * rhs.z - self.z * rhs.y, self.z * rhs.x - self.x * rhs.z, self.x * rhs.y - self.y * rhs.x)
end end
---@param b Vector3
---@return number
function Vector3:Distance(b) function Vector3:Distance(b)
return FastDistance(self.x, self.y, self.z, b.x, b.y, b.z) return FastDistance(self.x, self.y, self.z, b.x, b.y, b.z)
end end
---@param to Vector3
---@return number
function Vector3:Angle(to) function Vector3:Angle(to)
return math.acos(self:Dot(to) / return math.acos(self:Dot(to) /
( (
@ -180,6 +209,8 @@ function Vector3:Angle(to)
math.sqrt(to.x * to.x + to.y * to.y + to.z * to.z))) math.sqrt(to.x * to.x + to.y * to.y + to.z * to.z)))
end end
---@param maxLength number
---@return Vector3
function Vector3:ClampMagnitude(maxLength) function Vector3:ClampMagnitude(maxLength)
if self:Dot(self) > maxLength * maxLength then if self:Dot(self) > maxLength * maxLength then
return self.normalized * maxLength return self.normalized * maxLength
@ -189,15 +220,25 @@ function Vector3:ClampMagnitude(maxLength)
end end
-- Implement a clamp function -- Implement a clamp function
---@param x number
---@param min number
---@param max number
---@return number
local function clamp(x, min, max) local function clamp(x, min, max)
return x < min and min or (x > max and max or x) return x < min and min or (x > max and max or x)
end end
---@param b Vector3
---@param t number
---@return Vector3
function Vector3:Lerp(b, t) function Vector3:Lerp(b, t)
t = clamp(t, 0, 1) t = clamp(t, 0, 1)
return Vector3:New(self.x + (b.x - self.x) * t, self.y + (b.y - self.y) * t, self.z + (b.z - self.z) * t) return Vector3:New(self.x + (b.x - self.x) * t, self.y + (b.y - self.y) * t, self.z + (b.z - self.z) * t)
end end
---@param target Vector3
---@param maxDistanceDelta number
---@return Vector3
function Vector3:MoveTowards(target, maxDistanceDelta) function Vector3:MoveTowards(target, maxDistanceDelta)
local toVector = target - self local toVector = target - self
local distance = toVector.magnitude local distance = toVector.magnitude
@ -208,10 +249,14 @@ function Vector3:MoveTowards(target, maxDistanceDelta)
return self + toVector / distance * maxDistanceDelta return self + toVector / distance * maxDistanceDelta
end end
---@param b Vector3
---@return Vector3
function Vector3:Scale(b) function Vector3:Scale(b)
return Vector3:New(self.x * b.x, self.y * b.y, self.z * b.z) return Vector3:New(self.x * b.x, self.y * b.y, self.z * b.z)
end end
---@param onNormal Vector3
---@return Vector3
function Vector3:Project(onNormal) function Vector3:Project(onNormal)
local num = onNormal:Dot(onNormal) local num = onNormal:Dot(onNormal)
if num < 1.401298E-45 then if num < 1.401298E-45 then
@ -221,14 +266,19 @@ function Vector3:Project(onNormal)
return onNormal * self:Dot(onNormal) / num return onNormal * self:Dot(onNormal) / num
end end
---@param planeNormal Vector3
---@return Vector3
function Vector3:ProjectOnPlane(planeNormal) function Vector3:ProjectOnPlane(planeNormal)
return self - self:Project(planeNormal) return self - self:Project(planeNormal)
end end
---@param inDirection Vector3
---@return Vector3
function Vector3:Reflect(inNormal) function Vector3:Reflect(inNormal)
return -2 * inNormal:Dot(self) * inNormal + self return -2 * inNormal:Dot(self) * inNormal + self
end end
---@return Vector3
function Vector3:Normalize() function Vector3:Normalize()
local num = self:Dot(self) local num = self:Dot(self)
if num > 1E-05 then if num > 1E-05 then

Loading…
Cancel
Save