|
|
@ -1,19 +1,27 @@ |
|
|
|
local Tinkr, Bastion = ... |
|
|
|
local Tinkr, Bastion = ... |
|
|
|
|
|
|
|
|
|
|
|
-- Create a new Unit class |
|
|
|
-- Create a new Unit class |
|
|
|
|
|
|
|
---@class Unit |
|
|
|
local Unit = { |
|
|
|
local Unit = { |
|
|
|
cache = nil, |
|
|
|
cache = nil, |
|
|
|
|
|
|
|
---@type AuraTable |
|
|
|
aura_table = nil, |
|
|
|
aura_table = nil, |
|
|
|
|
|
|
|
---@type Unit |
|
|
|
unit = nil, |
|
|
|
unit = nil, |
|
|
|
last_shadow_techniques = 0, |
|
|
|
last_shadow_techniques = 0, |
|
|
|
swings_since_sht = 0, |
|
|
|
swings_since_sht = 0, |
|
|
|
last_off_attack = 0, |
|
|
|
last_off_attack = 0, |
|
|
|
last_main_attack = 0, |
|
|
|
last_main_attack = 0, |
|
|
|
|
|
|
|
last_combat_time = 0, |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function Unit:__index(k) |
|
|
|
function Unit:__index(k) |
|
|
|
local response = Bastion.ClassMagic:Resolve(Unit, k) |
|
|
|
local response = Bastion.ClassMagic:Resolve(Unit, k) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if k == 'unit' then |
|
|
|
|
|
|
|
return rawget(self, k) |
|
|
|
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
if response == nil then |
|
|
|
if response == nil then |
|
|
|
response = rawget(self, k) |
|
|
|
response = rawget(self, k) |
|
|
|
end |
|
|
|
end |
|
|
@ -25,9 +33,14 @@ function Unit:__index(k) |
|
|
|
return response |
|
|
|
return response |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
-- Equals |
|
|
|
|
|
|
|
function Unit:__eq(other) |
|
|
|
|
|
|
|
return UnitIsUnit(self:GetOMToken(), other.unit) |
|
|
|
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- tostring |
|
|
|
-- tostring |
|
|
|
function Unit:__tostring() |
|
|
|
function Unit:__tostring() |
|
|
|
return "Bastion.__Unit(" .. tostring(self.unit) .. ")" .. " - " .. (self:GetName() or '') |
|
|
|
return "Bastion.__Unit(" .. tostring(self:GetOMToken()) .. ")" .. " - " .. (self:GetName() or '') |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Constructor |
|
|
|
-- Constructor |
|
|
@ -42,37 +55,37 @@ end |
|
|
|
|
|
|
|
|
|
|
|
-- Check if the unit is valid |
|
|
|
-- Check if the unit is valid |
|
|
|
function Unit:IsValid() |
|
|
|
function Unit:IsValid() |
|
|
|
return self.unit ~= nil and self:Exists() |
|
|
|
return self:GetOMToken() ~= nil and self:Exists() |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Check if the unit exists |
|
|
|
-- Check if the unit exists |
|
|
|
function Unit:Exists() |
|
|
|
function Unit:Exists() |
|
|
|
return Object(self.unit) |
|
|
|
return Object(self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the units token |
|
|
|
-- Get the units token |
|
|
|
function Unit:Token() |
|
|
|
function Unit:Token() |
|
|
|
return self.unit |
|
|
|
return self:GetOMToken() |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the units name |
|
|
|
-- Get the units name |
|
|
|
function Unit:GetName() |
|
|
|
function Unit:GetName() |
|
|
|
return UnitName(self.unit) |
|
|
|
return UnitName(self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the units GUID |
|
|
|
-- Get the units GUID |
|
|
|
function Unit:GetGUID() |
|
|
|
function Unit:GetGUID() |
|
|
|
return ObjectGUID(self.unit) |
|
|
|
return ObjectGUID(self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the units health |
|
|
|
-- Get the units health |
|
|
|
function Unit:GetHealth() |
|
|
|
function Unit:GetHealth() |
|
|
|
return UnitHealth(self.unit) |
|
|
|
return UnitHealth(self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the units max health |
|
|
|
-- Get the units max health |
|
|
|
function Unit:GetMaxHealth() |
|
|
|
function Unit:GetMaxHealth() |
|
|
|
return UnitHealthMax(self.unit) |
|
|
|
return UnitHealthMax(self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the units health percentage |
|
|
|
-- Get the units health percentage |
|
|
@ -86,19 +99,19 @@ end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the units power type |
|
|
|
-- Get the units power type |
|
|
|
function Unit:GetPowerType() |
|
|
|
function Unit:GetPowerType() |
|
|
|
return UnitPowerType(self.unit) |
|
|
|
return UnitPowerType(self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the units power |
|
|
|
-- Get the units power |
|
|
|
function Unit:GetPower(powerType) |
|
|
|
function Unit:GetPower(powerType) |
|
|
|
local powerType = powerType or self:GetPowerType() |
|
|
|
local powerType = powerType or self:GetPowerType() |
|
|
|
return UnitPower(self.unit, powerType) |
|
|
|
return UnitPower(self:GetOMToken(), powerType) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the units max power |
|
|
|
-- Get the units max power |
|
|
|
function Unit:GetMaxPower(powerType) |
|
|
|
function Unit:GetMaxPower(powerType) |
|
|
|
local powerType = powerType or self:GetPowerType() |
|
|
|
local powerType = powerType or self:GetPowerType() |
|
|
|
return UnitPowerMax(self.unit, powerType) |
|
|
|
return UnitPowerMax(self:GetOMToken(), powerType) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the units power percentage |
|
|
|
-- Get the units power percentage |
|
|
@ -115,7 +128,7 @@ end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the units position |
|
|
|
-- Get the units position |
|
|
|
function Unit:GetPosition() |
|
|
|
function Unit:GetPosition() |
|
|
|
local x, y, z = ObjectPosition(self.unit) |
|
|
|
local x, y, z = ObjectPosition(self:GetOMToken()) |
|
|
|
return Bastion.Vector3:New(x, y, z) |
|
|
|
return Bastion.Vector3:New(x, y, z) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
@ -129,37 +142,37 @@ end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit dead |
|
|
|
-- Is the unit dead |
|
|
|
function Unit:IsDead() |
|
|
|
function Unit:IsDead() |
|
|
|
return UnitIsDeadOrGhost(self.unit) |
|
|
|
return UnitIsDeadOrGhost(self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit alive |
|
|
|
-- Is the unit alive |
|
|
|
function Unit:IsAlive() |
|
|
|
function Unit:IsAlive() |
|
|
|
return not UnitIsDeadOrGhost(self.unit) |
|
|
|
return not UnitIsDeadOrGhost(self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit a pet |
|
|
|
-- Is the unit a pet |
|
|
|
function Unit:IsPet() |
|
|
|
function Unit:IsPet() |
|
|
|
return UnitIsUnit(self.unit, "pet") |
|
|
|
return UnitIsUnit(self:GetOMToken(), "pet") |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit a friendly unit |
|
|
|
-- Is the unit a friendly unit |
|
|
|
function Unit:IsFriendly() |
|
|
|
function Unit:IsFriendly() |
|
|
|
return UnitIsFriend("player", self.unit) |
|
|
|
return UnitIsFriend("player", self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- IsEnemy |
|
|
|
-- IsEnemy |
|
|
|
function Unit:IsEnemy() |
|
|
|
function Unit:IsEnemy() |
|
|
|
return UnitCanAttack("player", self.unit) |
|
|
|
return UnitCanAttack("player", self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit a hostile unit |
|
|
|
-- Is the unit a hostile unit |
|
|
|
function Unit:IsHostile() |
|
|
|
function Unit:IsHostile() |
|
|
|
return UnitCanAttack(self.unit, 'player') |
|
|
|
return UnitCanAttack(self:GetOMToken(), 'player') |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit a boss |
|
|
|
-- Is the unit a boss |
|
|
|
function Unit:IsBoss() |
|
|
|
function Unit:IsBoss() |
|
|
|
if UnitClassification(self.unit) == "worldboss" then |
|
|
|
if UnitClassification(self:GetOMToken()) == "worldboss" then |
|
|
|
return true |
|
|
|
return true |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
@ -174,77 +187,80 @@ function Unit:IsBoss() |
|
|
|
return false |
|
|
|
return false |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function Unit:GetOMToken() |
|
|
|
|
|
|
|
if not self.unit then |
|
|
|
|
|
|
|
return "none" |
|
|
|
|
|
|
|
end |
|
|
|
|
|
|
|
return self.unit:unit() |
|
|
|
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit a target |
|
|
|
-- Is the unit a target |
|
|
|
function Unit:IsTarget() |
|
|
|
function Unit:IsTarget() |
|
|
|
return UnitIsUnit(self.unit, "target") |
|
|
|
return UnitIsUnit(self:GetOMToken(), "target") |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit a focus |
|
|
|
-- Is the unit a focus |
|
|
|
function Unit:IsFocus() |
|
|
|
function Unit:IsFocus() |
|
|
|
return UnitIsUnit(self.unit, "focus") |
|
|
|
return UnitIsUnit(self:GetOMToken(), "focus") |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit a mouseover |
|
|
|
-- Is the unit a mouseover |
|
|
|
function Unit:IsMouseover() |
|
|
|
function Unit:IsMouseover() |
|
|
|
return UnitIsUnit(self.unit, "mouseover") |
|
|
|
return UnitIsUnit(self:GetOMToken(), "mouseover") |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit a tank |
|
|
|
-- Is the unit a tank |
|
|
|
function Unit:IsTank() |
|
|
|
function Unit:IsTank() |
|
|
|
return UnitGroupRolesAssigned(self.unit) == "TANK" |
|
|
|
return UnitGroupRolesAssigned(self:GetOMToken()) == "TANK" |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit a healer |
|
|
|
-- Is the unit a healer |
|
|
|
function Unit:IsHealer() |
|
|
|
function Unit:IsHealer() |
|
|
|
return UnitGroupRolesAssigned(self.unit) == "HEALER" |
|
|
|
return UnitGroupRolesAssigned(self:GetOMToken()) == "HEALER" |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit a damage dealer |
|
|
|
-- Is the unit a damage dealer |
|
|
|
function Unit:IsDamage() |
|
|
|
function Unit:IsDamage() |
|
|
|
return UnitGroupRolesAssigned(self.unit) == "DAMAGER" |
|
|
|
return UnitGroupRolesAssigned(self:GetOMToken()) == "DAMAGER" |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit a player |
|
|
|
-- Is the unit a player |
|
|
|
function Unit:IsPlayer() |
|
|
|
function Unit:IsPlayer() |
|
|
|
return UnitIsPlayer(self.unit) |
|
|
|
return UnitIsPlayer(self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit a player controlled unit |
|
|
|
-- Is the unit a player controlled unit |
|
|
|
function Unit:IsPCU() |
|
|
|
function Unit:IsPCU() |
|
|
|
return UnitPlayerControlled(self.unit) |
|
|
|
return UnitPlayerControlled(self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get if the unit is affecting combat |
|
|
|
-- Get if the unit is affecting combat |
|
|
|
function Unit:IsAffectingCombat() |
|
|
|
function Unit:IsAffectingCombat() |
|
|
|
return UnitAffectingCombat('player', self.unit) |
|
|
|
return UnitAffectingCombat(self:GetOMToken()) |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit indoors |
|
|
|
|
|
|
|
function Unit:IsIndoors() |
|
|
|
|
|
|
|
return IsIndoors() |
|
|
|
|
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the units class id |
|
|
|
-- Get the units class id |
|
|
|
function Unit:GetClass() |
|
|
|
function Unit:GetClass() |
|
|
|
local locale, class, classID = UnitClass(self.unit) |
|
|
|
local locale, class, classID = UnitClass(self:GetOMToken()) |
|
|
|
return Bastion.Class:New(locale, class, classID) |
|
|
|
return Bastion.Class:New(locale, class, classID) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the units auras |
|
|
|
-- Get the units auras |
|
|
|
|
|
|
|
---@return AuraTable |
|
|
|
function Unit:GetAuras() |
|
|
|
function Unit:GetAuras() |
|
|
|
return self.aura_table |
|
|
|
return self.aura_table |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get the raw unit |
|
|
|
-- Get the raw unit |
|
|
|
function Unit:GetRawUnit() |
|
|
|
function Unit:GetRawUnit() |
|
|
|
return self.unit |
|
|
|
return self:GetOMToken() |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
local isClassicWow = select(4, GetBuildInfo()) < 40000 |
|
|
|
local isClassicWow = select(4, GetBuildInfo()) < 40000 |
|
|
|
|
|
|
|
|
|
|
|
-- Check if two units are in melee |
|
|
|
-- Check if two units are in melee |
|
|
|
-- function Unit:InMelee(unit) |
|
|
|
-- function Unit:InMelee(unit) |
|
|
|
-- return UnitInMelee(self.unit, unit.unit) |
|
|
|
-- return UnitInMelee(self:GetOMToken(), unit.unit) |
|
|
|
-- end |
|
|
|
-- end |
|
|
|
|
|
|
|
|
|
|
|
local losFlag = bit.bor(0x1, 0x10, 0x100000) |
|
|
|
local losFlag = bit.bor(0x1, 0x10, 0x100000) |
|
|
@ -266,8 +282,8 @@ function Unit:CanSee(unit) |
|
|
|
-- return false |
|
|
|
-- return false |
|
|
|
-- end |
|
|
|
-- end |
|
|
|
-- end |
|
|
|
-- end |
|
|
|
local ax, ay, az = ObjectPosition(self.unit) |
|
|
|
local ax, ay, az = ObjectPosition(self:GetOMToken()) |
|
|
|
local ah = ObjectHeight(self.unit) |
|
|
|
local ah = ObjectHeight(self:GetOMToken()) |
|
|
|
local attx, atty, attz = GetUnitAttachmentPosition(unit.unit, 34) |
|
|
|
local attx, atty, attz = GetUnitAttachmentPosition(unit.unit, 34) |
|
|
|
|
|
|
|
|
|
|
|
if (ax == 0 and ay == 0 and az == 0) or (attx == 0 and atty == 0 and attz == 0) then |
|
|
|
if (ax == 0 and ay == 0 and az == 0) or (attx == 0 and atty == 0 and attz == 0) then |
|
|
@ -288,7 +304,7 @@ end |
|
|
|
|
|
|
|
|
|
|
|
-- Check if the unit is casting a spell |
|
|
|
-- Check if the unit is casting a spell |
|
|
|
function Unit:IsCasting() |
|
|
|
function Unit:IsCasting() |
|
|
|
return UnitCastingInfo(self.unit) ~= nil |
|
|
|
return UnitCastingInfo(self:GetOMToken()) ~= nil |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get Casting or channeling spell |
|
|
|
-- Get Casting or channeling spell |
|
|
@ -297,7 +313,8 @@ function Unit:GetCastingOrChannelingSpell() |
|
|
|
.unit) |
|
|
|
.unit) |
|
|
|
|
|
|
|
|
|
|
|
if not name then |
|
|
|
if not name then |
|
|
|
name, text, texture, startTimeMS, endTimeMS, isTradeSkill, notInterruptible, spellId = UnitChannelInfo(self.unit) |
|
|
|
name, text, texture, startTimeMS, endTimeMS, isTradeSkill, notInterruptible, spellId = UnitChannelInfo(self.unit |
|
|
|
|
|
|
|
:unit()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
if name then |
|
|
|
if name then |
|
|
@ -309,7 +326,7 @@ end |
|
|
|
|
|
|
|
|
|
|
|
-- Check if the unit is channeling a spell |
|
|
|
-- Check if the unit is channeling a spell |
|
|
|
function Unit:IsChanneling() |
|
|
|
function Unit:IsChanneling() |
|
|
|
return UnitChannelInfo(self.unit) ~= 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 |
|
|
@ -319,7 +336,7 @@ end |
|
|
|
|
|
|
|
|
|
|
|
-- Check if the unit can attack the target |
|
|
|
-- Check if the unit can attack the target |
|
|
|
function Unit:CanAttack(unit) |
|
|
|
function Unit:CanAttack(unit) |
|
|
|
return UnitCanAttack(self.unit, unit.unit) |
|
|
|
return UnitCanAttack(self:GetOMToken(), unit.unit) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
function Unit:GetChannelOrCastPercentComplete() |
|
|
|
function Unit:GetChannelOrCastPercentComplete() |
|
|
@ -327,7 +344,8 @@ function Unit:GetChannelOrCastPercentComplete() |
|
|
|
.unit) |
|
|
|
.unit) |
|
|
|
|
|
|
|
|
|
|
|
if not name then |
|
|
|
if not name then |
|
|
|
name, text, texture, startTimeMS, endTimeMS, isTradeSkill, notInterruptible, spellId = UnitChannelInfo(self.unit) |
|
|
|
name, text, texture, startTimeMS, endTimeMS, isTradeSkill, notInterruptible, spellId = UnitChannelInfo(self.unit |
|
|
|
|
|
|
|
:unit()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
if name and startTimeMS and endTimeMS then |
|
|
|
if name and startTimeMS and endTimeMS then |
|
|
@ -345,7 +363,8 @@ function Unit:IsInterruptible() |
|
|
|
.unit) |
|
|
|
.unit) |
|
|
|
|
|
|
|
|
|
|
|
if not name then |
|
|
|
if not name then |
|
|
|
name, text, texture, startTimeMS, endTimeMS, isTradeSkill, notInterruptible, spellId = UnitChannelInfo(self.unit) |
|
|
|
name, text, texture, startTimeMS, endTimeMS, isTradeSkill, notInterruptible, spellId = UnitChannelInfo(self.unit |
|
|
|
|
|
|
|
:unit()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
if name then |
|
|
|
if name then |
|
|
@ -382,7 +401,7 @@ function Unit:GetEnemies(range) |
|
|
|
|
|
|
|
|
|
|
|
Bastion.UnitManager:EnumEnemies(function(unit) |
|
|
|
Bastion.UnitManager:EnumEnemies(function(unit) |
|
|
|
if not self:IsUnit(unit) and unit:GetDistance(self) <= range and unit:IsAlive() and self:CanSee(unit) and |
|
|
|
if not self:IsUnit(unit) and unit:GetDistance(self) <= range and unit:IsAlive() and self:CanSee(unit) and |
|
|
|
unit:IsEnemy() and unit:IsAffectingCombat() then |
|
|
|
unit:IsEnemy() then |
|
|
|
count = count + 1 |
|
|
|
count = count + 1 |
|
|
|
end |
|
|
|
end |
|
|
|
end) |
|
|
|
end) |
|
|
@ -402,7 +421,7 @@ function Unit:GetMeleeAttackers() |
|
|
|
|
|
|
|
|
|
|
|
Bastion.UnitManager:EnumEnemies(function(unit) |
|
|
|
Bastion.UnitManager:EnumEnemies(function(unit) |
|
|
|
if not self:IsUnit(unit) and unit:IsAlive() and self:CanSee(unit) and |
|
|
|
if not self:IsUnit(unit) and unit:IsAlive() and self:CanSee(unit) and |
|
|
|
self:InMelee(unit) and unit:IsEnemy() and unit:IsAffectingCombat() then |
|
|
|
self:InMelee(unit) and unit:IsEnemy() and unit:InCombatOdds() > 80 then |
|
|
|
count = count + 1 |
|
|
|
count = count + 1 |
|
|
|
end |
|
|
|
end |
|
|
|
end) |
|
|
|
end) |
|
|
@ -426,19 +445,19 @@ end |
|
|
|
|
|
|
|
|
|
|
|
-- Is moving |
|
|
|
-- Is moving |
|
|
|
function Unit:IsMoving() |
|
|
|
function Unit:IsMoving() |
|
|
|
return GetUnitSpeed(self.unit) > 0 |
|
|
|
return GetUnitSpeed(self:GetOMToken()) > 0 |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
function Unit:IsMovingAtAll() |
|
|
|
function Unit:IsMovingAtAll() |
|
|
|
return ObjectMovementFlag(self.unit) ~= 0 |
|
|
|
return ObjectMovementFlag(self:GetOMToken()) ~= 0 |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
function Unit:GetComboPoints() |
|
|
|
function Unit:GetComboPoints() |
|
|
|
return UnitPower(self.unit, 4) |
|
|
|
return UnitPower(self:GetOMToken(), 4) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
function Unit:GetComboPointsMax() |
|
|
|
function Unit:GetComboPointsMax() |
|
|
|
return UnitPowerMax(self.unit, 4) |
|
|
|
return UnitPowerMax(self:GetOMToken(), 4) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get combopoints deficit |
|
|
|
-- Get combopoints deficit |
|
|
@ -448,19 +467,20 @@ end |
|
|
|
|
|
|
|
|
|
|
|
-- IsUnit |
|
|
|
-- IsUnit |
|
|
|
function Unit:IsUnit(unit) |
|
|
|
function Unit:IsUnit(unit) |
|
|
|
return UnitIsUnit(self.unit, unit.unit) |
|
|
|
return UnitIsUnit(self:GetOMToken(), unit and unit:GetOMToken() or 'none') |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- IsTanking |
|
|
|
-- IsTanking |
|
|
|
function Unit:IsTanking(unit) |
|
|
|
function Unit:IsTanking(unit) |
|
|
|
local isTanking, status, threatpct, rawthreatpct, threatvalue = UnitDetailedThreatSituation(self.unit, unit.unit) |
|
|
|
local isTanking, status, threatpct, rawthreatpct, threatvalue = UnitDetailedThreatSituation(self:GetOMToken(), |
|
|
|
|
|
|
|
unit.unit) |
|
|
|
return isTanking |
|
|
|
return isTanking |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- IsFacing |
|
|
|
-- IsFacing |
|
|
|
function Unit:IsFacing(unit) |
|
|
|
function Unit:IsFacing(unit) |
|
|
|
local rot = ObjectRotation(self.unit) |
|
|
|
local rot = ObjectRotation(self:GetOMToken()) |
|
|
|
local x, y, z = ObjectPosition(self.unit) |
|
|
|
local x, y, z = ObjectPosition(self:GetOMToken()) |
|
|
|
local x2, y2, z2 = ObjectPosition(unit.unit) |
|
|
|
local x2, y2, z2 = ObjectPosition(unit.unit) |
|
|
|
|
|
|
|
|
|
|
|
if not x or not x2 then |
|
|
|
if not x or not x2 then |
|
|
@ -481,7 +501,7 @@ end |
|
|
|
function Unit:IsBehind(unit) |
|
|
|
function Unit:IsBehind(unit) |
|
|
|
local rot = ObjectRotation(unit.unit) |
|
|
|
local rot = ObjectRotation(unit.unit) |
|
|
|
local x, y, z = ObjectPosition(unit.unit) |
|
|
|
local x, y, z = ObjectPosition(unit.unit) |
|
|
|
local x2, y2, z2 = ObjectPosition(self.unit) |
|
|
|
local x2, y2, z2 = ObjectPosition(self:GetOMToken()) |
|
|
|
|
|
|
|
|
|
|
|
if not x or not x2 then |
|
|
|
if not x or not x2 then |
|
|
|
return false |
|
|
|
return false |
|
|
@ -513,7 +533,7 @@ end |
|
|
|
|
|
|
|
|
|
|
|
-- InMelee |
|
|
|
-- InMelee |
|
|
|
function Unit:InMelee(unit) |
|
|
|
function Unit:InMelee(unit) |
|
|
|
local x, y, z = ObjectPosition(self.unit) |
|
|
|
local x, y, z = ObjectPosition(self:GetOMToken()) |
|
|
|
local x2, y2, z2 = ObjectPosition(unit.unit) |
|
|
|
local x2, y2, z2 = ObjectPosition(unit.unit) |
|
|
|
|
|
|
|
|
|
|
|
if not x or not x2 then |
|
|
|
if not x or not x2 then |
|
|
@ -521,7 +541,7 @@ function Unit:InMelee(unit) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
local dist = math.sqrt((x - x2) ^ 2 + (y - y2) ^ 2 + (z - z2) ^ 2) |
|
|
|
local dist = math.sqrt((x - x2) ^ 2 + (y - y2) ^ 2 + (z - z2) ^ 2) |
|
|
|
local maxDist = math.max((ObjectCombatReach(self.unit) + 1.3333) + ObjectCombatReach(unit.unit), 5.0) |
|
|
|
local maxDist = math.max((ObjectCombatReach(self:GetOMToken()) + 1.3333) + ObjectCombatReach(unit.unit), 5.0) |
|
|
|
maxDist = maxDist + 1.0 + self:GetMeleeBoost() |
|
|
|
maxDist = maxDist + 1.0 + self:GetMeleeBoost() |
|
|
|
|
|
|
|
|
|
|
|
return dist <= maxDist |
|
|
|
return dist <= maxDist |
|
|
@ -529,12 +549,12 @@ end |
|
|
|
|
|
|
|
|
|
|
|
-- Get object id |
|
|
|
-- Get object id |
|
|
|
function Unit:GetID() |
|
|
|
function Unit:GetID() |
|
|
|
return ObjectID(self.unit) |
|
|
|
return ObjectID(self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- In party |
|
|
|
-- In party |
|
|
|
function Unit:IsInParty() |
|
|
|
function Unit:IsInParty() |
|
|
|
return UnitInParty(self.unit) |
|
|
|
return UnitInParty(self:GetOMToken()) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Linear regression between time and percent to something |
|
|
|
-- Linear regression between time and percent to something |
|
|
@ -623,17 +643,20 @@ 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 |
|
|
|
function Unit:GetCombatTime() |
|
|
|
function Unit:GetCombatTime() |
|
|
|
if self:IsAffectingCombat() then |
|
|
|
return GetTime() - self.last_combat_time |
|
|
|
self.last_combat_time = GetTime() |
|
|
|
end |
|
|
|
elseif not self:IsAffectingCombat() and self.last_combat_time then |
|
|
|
|
|
|
|
self.last_combat_time = nil |
|
|
|
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if not self.last_combat_time then |
|
|
|
function Unit:SetLastCombatTime(time) |
|
|
|
return 0 |
|
|
|
self.last_combat_time = time |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
return GetTime() - self.last_combat_time |
|
|
|
-- 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% |
|
|
|
|
|
|
|
function Unit:InCombatOdds() |
|
|
|
|
|
|
|
local time = self:GetCombatTime() |
|
|
|
|
|
|
|
local percent = 1 - (time / 60) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return percent * 100 |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get units gcd time |
|
|
|
-- Get units gcd time |
|
|
@ -656,7 +679,7 @@ More than 50% Haste will drop a spell below 1 second |
|
|
|
|
|
|
|
|
|
|
|
]] |
|
|
|
]] |
|
|
|
function Unit:GetMaxGCD() |
|
|
|
function Unit:GetMaxGCD() |
|
|
|
local haste = UnitSpellHaste(self.unit) |
|
|
|
local haste = UnitSpellHaste(self:GetOMToken()) |
|
|
|
if haste > 50 then |
|
|
|
if haste > 50 then |
|
|
|
haste = 50 |
|
|
|
haste = 50 |
|
|
|
end |
|
|
|
end |
|
|
@ -674,12 +697,12 @@ function Unit:IsStealthed() |
|
|
|
local Sepsis = Bastion.SpellBook:GetSpell(328305) |
|
|
|
local Sepsis = Bastion.SpellBook:GetSpell(328305) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return self:GetAuras():FindAny(Stealth) or self:GetAuras():FindAny(ShadowDance) |
|
|
|
return self:GetAuras():FindAny(Stealth) or self:GetAuras():FindAny(ShadowDance) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
-- Get unit swing timers |
|
|
|
-- Get unit swing timers |
|
|
|
function Unit:GetSwingTimers() |
|
|
|
function Unit:GetSwingTimers() |
|
|
|
local main_speed, off_speed = UnitAttackSpeed(self.unit) |
|
|
|
local main_speed, off_speed = UnitAttackSpeed(self:GetOMToken()) |
|
|
|
local main_speed = main_speed or 2 |
|
|
|
local main_speed = main_speed or 2 |
|
|
|
local off_speed = off_speed or 2 |
|
|
|
local off_speed = off_speed or 2 |
|
|
|
|
|
|
|
|
|
|
@ -833,4 +856,9 @@ function Unit:GetTimeToShurikenTornado(n) |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
-- Is the unit indoors |
|
|
|
|
|
|
|
function Unit:IsIndoors() |
|
|
|
|
|
|
|
return IsIndoors() |
|
|
|
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
return Unit |
|
|
|
return Unit |