Relintais-Enemy-Kooldown-Tr.../Rect.lua
Relintai 091c575586 -Found, and implemented a fix for the combatlog stuck bug.
-Empty string as the type i spells.lua is a bad idea, just spent an hour tracking down a bug because of that.
--(it errors in the sorters), added a type everywhere, and also documented it.
2016-05-07 23:43:59 +02:00

395 lines
9.6 KiB
Lua

--"Globals"
local aceDB = LibStub("AceDB-3.0");
local aceCDialog = LibStub("AceConfigDialog-3.0");
local aceConfig = LibStub("AceConfig-3.0");
local libSharedMedia = LibStub("LibSharedMedia-3.0");
local libDRData = LibStub('DRData-1.0');
Rect.CombatlogFixTimerData = {
["lasttick"] = 0,
["timesinceclear"] = 0
}
Rect.MovableFrames = nil
Rect.targets = {
["target"] = nil,
["focus"] = nil,
["self"] = nil
}
Rect.cds = {}
Rect.drs = {}
Rect.frames = {
["target"] = {},
["focus"] = {},
["targetdr"] = {},
["focusdr"] = {},
["selfdr"] = {}
}
Rect.defaults = {
profile = {
enabled = true,
locked = true,
debugLevel = 0,
spellCastDebug = false,
spellAuraDebug = false,
allCDebug = false,
selfCDRegister = false,
specdetection = false,
petcdguessing = true,
target = {
enabled = true,
size = 27,
xPos = 350,
yPos = 350,
growOrder = tostring(2),
sortOrder = tostring(5),
colorframeenabled = true,
colorframesize = 4
},
focus = {
enabled = true,
size = 27,
xPos = 380,
yPos = 380,
growOrder = tostring(2),
sortOrder = tostring(5),
colorframeenabled = true,
colorframesize = 4
},
targetdr = {
enabled = true,
size = 27,
xPos = 380,
yPos = 380,
growOrder = tostring(2),
sortOrder = tostring(5),
drnumsize = 14,
drnumposition = tostring(1)
},
focusdr = {
enabled = true,
size = 27,
xPos = 380,
yPos = 380,
growOrder = tostring(2),
sortOrder = tostring(5),
drnumsize = 14,
drnumposition = tostring(1)
},
selfdr = {
enabled = true,
size = 27,
xPos = 380,
yPos = 380,
growOrder = tostring(2),
sortOrder = tostring(5),
drnumsize = 14,
drnumposition = tostring(1)
},
color = {
gapcloser = {
a = 1,
b = 0,
g = 0.8117647058823529,
r = 1,
},
anticc = {
a = 1,
b = 0.796078431372549,
g = 1,
r = 0,
},
disarm = {
a = 1,
b = 0.9647058823529412,
g = 1,
r = 0,
},
defensive = {
a = 1,
b = 0.08627450980392157,
g = 1,
r = 0.2,
},
nuke = {
a = 1,
b = 0,
g = 0,
r = 1,
},
shield = {
a = 1,
b = 0.3333333333333333,
g = 1,
r = 0.8901960784313725,
},
potion = {
a = 1,
b = 0.6313725490196078,
g = 0.7372549019607844,
r = 1,
},
cdreset = {
a = 1,
b = 1,
g = 0,
r = 0.6274509803921569,
},
silence = {
a = 1,
b = 1,
g = 0.03529411764705882,
r = 0.1882352941176471,
},
stun = {
a = 1,
b = 1,
g = 0.07450980392156863,
r = 0.9137254901960784,
},
uncategorized = {
a = 1,
b = 1,
g = 0.9058823529411765,
r = 0.9607843137254902,
},
cc = {
a = 1,
b = 0.3686274509803922,
g = 0.3568627450980392,
r = 0.3764705882352941,
},
},
cdtypesortorder = {
enabled = true,
silence = 1,
gapcloser = 2,
defensive = 6,
potion = 12,
nuke = 7,
anticc = 5,
cc = 4,
stun = 3,
disarm = 9,
cdreset = 10,
shield = 5,
uncategorized = 13
}
}
}
function Rect:Reset()
Rect.cds = {}
Rect.drs = {}
Rect.target = {unitGUID = -1, timers = {}}
Rect.focus = {unitGUID = -1, timers = {}}
Rect:HideSelfDRFrames();
end
function Rect:OnInitialize()
self.db = aceDB:New("RectDB", self.defaults);
self.db.RegisterCallback(self, "OnProfileChanged", function() self:ApplySettings() end);
self.db.RegisterCallback(self, "OnProfileCopied", function() self:ApplySettings() end);
self.db.RegisterCallback(self, "OnProfileReset", function() self:ApplySettings() end);
aceConfig:RegisterOptionsTable("Rect", self:GetRectOptions());
aceCDialog:AddToBlizOptions("Rect");
self:RegisterChatCommand("Rect", "ChatCommand");
end
function Rect:OnEnable()
self:Reset()
self:RegisterEvent("PLAYER_ENTERING_WORLD");
self:RegisterEvent("ZONE_CHANGED_NEW_AREA");
self:RegisterEvent("COMBAT_LOG_EVENT_UNFILTERED");
self:RegisterEvent("PLAYER_TARGET_CHANGED");
self:RegisterEvent("PLAYER_FOCUS_CHANGED");
self:CreateFrames("target");
self:CreateFrames("focus");
self:CreateDRFrames("targetdr");
self:CreateDRFrames("focusdr");
self:CreateDRFrames("selfdr");
self:ApplySettings();
self.targets["self"] = UnitGUID("player");
--cause, and basic fix from:
--from http://www.arenajunkies.com/topic/125096-combat-log-error-screwing-up-your-addons-supposed-fix/
local f = CreateFrame("Frame", nil, UIParent);
f:SetScript("OnUpdate", function() self:CombatLogClearFix() end);
end
function Rect:CombatLogClearFix()
--delta is in seconds
local delta = GetTime() - Rect.CombatlogFixTimerData["lasttick"];
--this will happen on the first run, this is here, becouse on the first test,
--the first clear on load just bugged the addon, until the second clear
if delta > 30 then
return;
end
local tslc = Rect.CombatlogFixTimerData["timesinceclear"] + delta;
--30 seconds should be enough
if tslc >= 30 then
CombatLogClearEntries();
tslc = 0;
end
Rect.CombatlogFixTimerData["timesinceclear"] = tslc;
Rect.CombatlogFixTimerData["lasttick"] = GetTime();
end
function Rect:OnDisable()
self:UnregisterEvent("PLAYER_ENTERING_WORLD");
self:UnregisterEvent("ZONE_CHANGED_NEW_AREA");
self:UnregisterEvent("COMBAT_LOG_EVENT_UNFILTERED");
self:UnregisterEvent("PLAYER_TARGET_CHANGED");
self:UnregisterEvent("PLAYER_FOCUS_CHANGED");
self.Reset();
end
function Rect:ChatCommand(input)
if not input or input:trim() == "" then
aceCDialog:Open("Rect");
else
LibStub("AceConfigCmd-3.0").HandleCommand(Rect, "Rect", "Rect", input);
end
end
local COMBATLOG_OBJECT_TYPE_PLAYER = COMBATLOG_OBJECT_TYPE_PLAYER
local COMBATLOG_OBJECT_REACTION_HOSTILE = COMBATLOG_OBJECT_REACTION_HOSTILE
local COMBATLOG_OBJECT_CONTROL_PLAYER = COMBATLOG_OBJECT_CONTROL_PLAYER
function Rect:COMBAT_LOG_EVENT_UNFILTERED(_, timestamp, eventType, srcGUID, srcName, srcFlags,
dstGUID, dstName, dstFlags, spellID, spellName, spellSchool,
detail1, detail2, detail3)
local db = Rect.db.profile;
if not db["enabled"] then return end;
--debugAll
if db["allCDebug"] then
self:Print("eventType: " .. eventType .. " id: " .. spellID .. " spellName: " .. spellName);
end
--debugAura
if db["spellAuraDebug"] then
if eventType == "SPELL_AURA_APPLIED" or eventType == "SPELL_AURA_REMOVED" or eventType == "SPELL_AURA_APPLIED_DOSE" or
eventType == "SPELL_AURA_REMOVED_DOSE" or eventType == "SPELL_AURA_REFRESH" or eventType == "SPELL_AURA_BROKEN" or
eventType == "SPELL_AURA_BROKEN_SPELL" then
self:Print("eventType: " .. eventType .. " id: " .. spellID .. " spellName: " .. spellName);
end
end
if eventType == "SPELL_CAST_SUCCESS" or eventType == "SPELL_AURA_APPLIED" then
--debug spell
if db["spellCastDebug"] and eventType == "SPELL_CAST_SUCCESS" then
self:Print("id: " .. spellID .. " spellName: " .. spellName);
end
if Rect.spells[spellID] then
Rect:AddCd(srcGUID, spellID);
end
end
--DR stuff
if( eventType == "SPELL_AURA_APPLIED" ) then
if(detail1 == "DEBUFF" and libDRData:GetSpellCategory(spellID)) then
local isPlayer = (bit.band(dstFlags, COMBATLOG_OBJECT_TYPE_PLAYER) == COMBATLOG_OBJECT_TYPE_PLAYER or bit.band(dstFlags, COMBATLOG_OBJECT_CONTROL_PLAYER) == COMBATLOG_OBJECT_CONTROL_PLAYER)
if (not isPlayer and not libDRData:IsPVE(drCat)) then
return
end
local drCat = libDRData:GetSpellCategory(spellID);
Rect:DRDebuffGained(spellID, dstGUID, isPlayer);
end
-- Enemy had a debuff refreshed before it faded, so fade + gain it quickly
elseif(eventType == "SPELL_AURA_REFRESH" ) then
if(detail1 == "DEBUFF" and libDRData:GetSpellCategory(spellID)) then
local isPlayer = (bit.band(dstFlags, COMBATLOG_OBJECT_TYPE_PLAYER) == COMBATLOG_OBJECT_TYPE_PLAYER or bit.band(dstFlags, COMBATLOG_OBJECT_CONTROL_PLAYER) == COMBATLOG_OBJECT_CONTROL_PLAYER)
if (not isPlayer and not libDRData:IsPVE(drCat)) then
return
end
Rect:DRDebuffFaded(spellID, dstGUID, isPlayer);
Rect:DRDebuffGained(spellID, dstGUID, isPlayer);
end
-- Buff or debuff faded from an enemy
elseif(eventType == "SPELL_AURA_REMOVED" ) then
if(detail1 == "DEBUFF" and libDRData:GetSpellCategory(spellID)) then
local isPlayer = (bit.band(dstFlags, COMBATLOG_OBJECT_TYPE_PLAYER) == COMBATLOG_OBJECT_TYPE_PLAYER or bit.band(dstFlags, COMBATLOG_OBJECT_CONTROL_PLAYER) == COMBATLOG_OBJECT_CONTROL_PLAYER)
if (not isPlayer and not libDRData:IsPVE(drCat)) then
return
end
Rect:DRDebuffFaded(spellID, dstGUID, isPlayer);
end
end
end
function Rect:PLAYER_TARGET_CHANGED()
local unitGUID = UnitGUID("target");
self.targets["target"] = unitGUID;
self:ReassignCds("target");
self:ReassignDRs("targetdr");
end
function Rect:PLAYER_FOCUS_CHANGED()
local unitGUID = UnitGUID("focus");
self.targets["focus"] = unitGUID;
self:ReassignCds("focus");
self:ReassignDRs("focusdr");
end
function Rect:PLAYER_ENTERING_WORLD()
--DB cleanup
local t = GetTime();
for k, v in pairs(Rect.cds) do
for i, j in pairs(v) do
if not (i == "spec") then
if j[2] < t then
--self:Print(Rect.cds[k][i][4]);
Rect.cds[k][i] = nil;
end
end
end
end
Rect.drs = {}
end
function Rect:ZONE_CHANGED_NEW_AREA()
local type = select(2, IsInInstance())
-- If we are entering an arena
if (type == "arena") then
self:Reset();
end
end
function Rect:ApplySettings()
local db = Rect.db.profile;
Rect:MoveTimersStop("target");
Rect:MoveTimersStop("focus");
Rect:ReassignCds("target");
Rect:ReassignCds("focus");
Rect:MoveDRTimersStop("targetdr");
Rect:MoveDRTimersStop("focusdr");
Rect:MoveDRTimersStop("selfdr");
Rect:ReassignDRs("targetdr");
Rect:ReassignDRs("focusdr");
Rect:ReassignDRs("selfdr");
if not db["locked"] then self:ShowMovableFrames() end;
end