From 87728d0e6881b454b7de1aaa99c097c62fab0ebf Mon Sep 17 00:00:00 2001 From: Tercio Jose Date: Fri, 5 Feb 2021 14:21:23 -0300 Subject: [PATCH] Backend improvements --- boot.lua | 84 ++--------------------------------- core/gears.lua | 26 ++++++----- core/network.lua | 2 - core/parser.lua | 7 ++- frames/window_statistics.lua | 4 ++ functions/mythicdungeon.lua | 11 +++++ functions/profiles.lua | 11 ++++- functions/spellcache.lua | 2 + images/icon_astral_shift.tga | Bin 0 -> 12332 bytes 9 files changed, 50 insertions(+), 97 deletions(-) create mode 100644 images/icon_astral_shift.tga diff --git a/boot.lua b/boot.lua index 1e64055ef..3b9a2c2bb 100644 --- a/boot.lua +++ b/boot.lua @@ -4,8 +4,8 @@ _ = nil _detalhes = LibStub("AceAddon-3.0"):NewAddon("_detalhes", "AceTimer-3.0", "AceComm-3.0", "AceSerializer-3.0", "NickTag-1.0") - _detalhes.build_counter = 8192 - _detalhes.alpha_build_counter = 8192 --if this is higher than the regular counter, use it instead + _detalhes.build_counter = 8203 + _detalhes.alpha_build_counter = 8203 --if this is higher than the regular counter, use it instead _detalhes.dont_open_news = true _detalhes.game_version = "v9.0.2" _detalhes.userversion = "v9.0.2." .. _detalhes.build_counter @@ -152,87 +152,11 @@ do {Name = "Report What is Shown In the Window", Desc = "Report the current data shown in the window, the number 1 is the window number, replace it to report another window.", MacroText = "/script Details:FastReportWindow(1)"}, } - --> quais raides devem ser guardadas no hist�rico - _detalhes.InstancesToStoreData = { --> mapIDs - [2070] = true, --Battle for Dazaralor (BFA) GetInstanceInfo - [1148] = true, --Uldir (BFA) uiMapID - [1861] = true, --Uldir (BFA) from GetInstanceInfo - [2164] = true, --Eternal Palace - - [2217] = true, --8.3 - + --> current instances of the exp (need to maintain) + _detalhes.InstancesToStoreData = { --mapId [2296] = true, --castle narnia } - --must fail in map and encounter id to not store data - _detalhes.EncountersToStoreData = { --> encounterIDs - --CLEU - [2144] = 1, --Taloc - Taloc - [2141] = 2, --MOTHER - MOTHER - [2128] = 3, --Fetid Devourer - Fetid Devourer - [2136] = 4, --Zek'voz - Zek'voz, Herald of N'zoth - [2134] = 5, --Vectis - Vectis - [2145] = 6, --Zul - Zul, Reborn - [2135] = 7, --Mythrax the Unraveler - Mythrax the Unraveler - [2122] = 8, --G'huun - G'huun - - [2265] = 1, --Champion of the Light - [2263] = 2, --Grong, the Jungle Lord - [2266] = 3, --Jadefire Masters - [2271] = 4, --Opulence - [2268] = 5, --Conclave of the Chosen - [2272] = 6, --King Rastakhan - [2276] = 7, --High Tinker Mekkatorque - [2280] = 8, --Stormwall Blockade - [2281] = 9, --Lady Jaina Proudmoore - - [2269] = 1, --The Restless Cabal - [2273] = 2, --Uu'nat, Harbinger of the Void - - [2298] = 1, --Abyssal Commander Sivara - [2289] = 2, --Blackwater Behemoth - [2305] = 3, --Radiance of Azshara - [2304] = 4, --Lady Ashvane - [2303] = 5, --Orgozoa - [2311] = 6, --The Queen's Court - [2293] = 7, --Za'qul, Harbinger of Ny'alotha - [2299] = 8, --Queen Azshara - - --EJID - [2168] = 1, --Taloc - [2167] = 2, --MOTHER - [2146] = 3, --Fetid Devourer - [2169] = 4, --Zek'voz, Herald of N'zoth - [2166] = 5, --Vectis - [2195] = 6, --Zul, Reborn - [2194] = 7, --Mythrax the Unraveler - [2147] = 8, --G'huun - - [2333] = 1, --Champion of the Light - [2325] = 2, --Grong, the Jungle Lord - [2341] = 3, --Jadefire Masters - [2342] = 4, --Opulence - [2330] = 5, --Conclave of the Chosen - [2335] = 6, --King Rastakhan - [2334] = 7, --High Tinker Mekkatorque - [2337] = 8, --Stormwall Blockade - [2343] = 9, --Lady Jaina Proudmoore - - [2328] = 1, --The Restless Cabal - [2332] = 2, --Uu'nat, Harbinger of the Void - - [2352] = 1, --Abyssal Commander Sivara - [2347] = 2, --Blackwater Behemoth - [2353] = 3, --Radiance of Azshara - [2354] = 4, --Lady Ashvane - [2351] = 5, --Orgozoa - [2359] = 6, --The Queen's Court - [2349] = 7, --Za'qul, Harbinger of Ny'alotha - [2361] = 8, --Queen Azshara - - - } - --> armazena os escudos - Shields information for absorbs _detalhes.escudos = {} --> armazena as fun��es dos frames - Frames functions diff --git a/core/gears.lua b/core/gears.lua index 56185da3a..ed6d4cbe3 100644 --- a/core/gears.lua +++ b/core/gears.lua @@ -19,7 +19,7 @@ if (DetailsFramework.IsClassicWow()) then LibGroupInSpecT = false end -local storageDebug = true --remember to turn this to false! +local storageDebug = false --remember to turn this to false! local store_instances = _detalhes.InstancesToStoreData function _detalhes:UpdateGears() @@ -1034,7 +1034,8 @@ function _detalhes.storage:GetIDsToGuildSync() end local IDs = {} - + local myGuildName = GetGuildInfo("player") + --build the encounter ID list for diff, diffTable in pairs (db or {}) do if (type (diffTable) == "table") then @@ -1042,7 +1043,9 @@ function _detalhes.storage:GetIDsToGuildSync() if (encounter_is_current_tier (encounterID)) then for index, encounter in ipairs (encounterTable) do if (encounter.servertime) then - tinsert (IDs, encounter.servertime) + if (myGuildName == encounter.guild) then + tinsert (IDs, encounter.servertime) + end end end end @@ -1514,7 +1517,7 @@ function Details.Database.StoreWipe(combat) local bossCLEUID = combat.boss_info and combat.boss_info.id - if (not store_instances [mapID] and not _detalhes.EncountersToStoreData [bossCLEUID]) then + if (not store_instances [mapID]) then if (_detalhes.debug) then print ("|cFFFFFF00Details! Storage|r: instance not allowed.") end @@ -1585,7 +1588,7 @@ function Details.Database.StoreEncounter(combat) local bossCLEUID = combat.boss_info and combat.boss_info.id - if (not store_instances [mapID] and not _detalhes.EncountersToStoreData [bossCLEUID]) then + if (not store_instances [mapID]) then if (_detalhes.debug) then print ("|cFFFFFF00Details! Storage|r: instance not allowed.") end @@ -1668,25 +1671,24 @@ function Details.Database.StoreEncounter(combat) end - --> check for heroic and mythic - if (storageDebug or (diff == 15 or diff == 16 or diff == 17)) then --test on raid finder: ' or diff == 17' -- normal mode: diff == 14 or + if (storageDebug or (diff == 15 or diff == 16 or diff == 14)) then --test on raid finder: ' or diff == 17' -- normal mode: diff == 14 or --> check the guild name local match = 0 - local guildName = select (1, GetGuildInfo ("player")) - local raid_size = GetNumGroupMembers() or 0 + local guildName = GetGuildInfo ("player") + local raidSize = GetNumGroupMembers() or 0 if (not storageDebug) then if (guildName) then - for i = 1, raid_size do - local gName = select (1, GetGuildInfo ("raid" .. i)) or "" + for i = 1, raidSize do + local gName = GetGuildInfo("raid" .. i) or "" if (gName == guildName) then match = match + 1 end end - if (match < raid_size * 0.75 and not storageDebug) then + if (match < raidSize * 0.75 and not storageDebug) then if (_detalhes.debug) then print ("|cFFFFFF00Details! Storage|r: can't save the encounter, need at least 75% of players be from your guild.") end diff --git a/core/network.lua b/core/network.lua index 0511b22cf..f3342c133 100644 --- a/core/network.lua +++ b/core/network.lua @@ -758,8 +758,6 @@ if not IsInGuild() then return end --> fix from Tim@WoWInterface _detalhes:SendCommMessage (DETAILS_PREFIX_NETWORK, _detalhes:Serialize (type, _UnitName ("player"), _GetRealmName(), _detalhes.realversion, ...), "GUILD") end - - ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- --> cloud diff --git a/core/parser.lua b/core/parser.lua index cf32858bc..5750ebf93 100755 --- a/core/parser.lua +++ b/core/parser.lua @@ -4522,6 +4522,11 @@ local SPELL_POWER_PAIN = SPELL_POWER_PAIN or (PowerEnum and PowerEnum.Pain) or 1 end local encounterID, encounterName, difficultyID, raidSize = _select (1, ...) + local zoneName, _, _, _, _, _, _, zoneMapID = _GetInstanceInfo() + + if (_detalhes.InstancesToStoreData[zoneMapID]) then + Details.current_exp_raid_encounters[encounterID] = true + end if (not _detalhes.WhoAggroTimer and _detalhes.announce_firsthit.enabled) then _detalhes.WhoAggroTimer = C_Timer.NewTimer (0.5, who_aggro) @@ -4540,8 +4545,6 @@ local SPELL_POWER_PAIN = SPELL_POWER_PAIN or (PowerEnum and PowerEnum.Pain) or 1 local dbm_mod, dbm_time = _detalhes.encounter_table.DBM_Mod, _detalhes.encounter_table.DBM_ModTime _table_wipe (_detalhes.encounter_table) - local zoneName, _, _, _, _, _, _, zoneMapID = _GetInstanceInfo() - --print (encounterID, encounterName, difficultyID, raidSize) _detalhes.encounter_table.phase = 1 diff --git a/frames/window_statistics.lua b/frames/window_statistics.lua index d611a6b14..7179a7414 100644 --- a/frames/window_statistics.lua +++ b/frames/window_statistics.lua @@ -238,6 +238,10 @@ function Details:OpenRaidHistoryWindow (_raid, _boss, _difficulty, _role, _guild --received one encounter table elseif (guildSyncID == "A") then + if (not f.RequestedAmount) then + --if the receiving player reloads, f.RequestedAmount is nil + return + end f.DownloadedAmount = (f.DownloadedAmount or 0) + 1 --size = 1 byte per characters in the string diff --git a/functions/mythicdungeon.lua b/functions/mythicdungeon.lua index 5f2e413be..c99474adc 100644 --- a/functions/mythicdungeon.lua +++ b/functions/mythicdungeon.lua @@ -689,16 +689,27 @@ function DetailsMythicPlusFrame.OnChallengeModeStart() if (difficulty == 8 and DetailsMythicPlusFrame.LastTimer and DetailsMythicPlusFrame.LastTimer+2 > GetTime()) then --> start the dungeon on Details! DetailsMythicPlusFrame.MythicDungeonStarted() + --print("D! mythic dungeon started!") else + + --print("D! mythic dungeon was already started!") --> from zone changed local mythicLevel = C_ChallengeMode.GetActiveKeystoneInfo() local zoneName, _, _, _, _, _, _, currentZoneID = GetInstanceInfo() + + --print("Details.MythicPlus.Started", Details.MythicPlus.Started) + --print("Details.MythicPlus.DungeonID", Details.MythicPlus.DungeonID) + --print("currentZoneID", currentZoneID) + --print("Details.MythicPlus.Level", Details.MythicPlus.Level) + --print("mythicLevel", mythicLevel) if (not Details.MythicPlus.Started and Details.MythicPlus.DungeonID == currentZoneID and Details.MythicPlus.Level == mythicLevel) then Details.MythicPlus.Started = true Details.MythicPlus.EndedAt = nil _detalhes.mythic_dungeon_currentsaved.started = true DetailsMythicPlusFrame.IsDoingMythicDungeon = true + + --print("D! mythic dungeon was NOT already started! debug 2") end end end diff --git a/functions/profiles.lua b/functions/profiles.lua index 680eb2062..a90c16585 100644 --- a/functions/profiles.lua +++ b/functions/profiles.lua @@ -1246,6 +1246,7 @@ local default_global_data = { ["13"] = false, ["14"] = false, }, + current_exp_raid_encounters = {}, --> death log show_totalhitdamage_on_overkill = false, @@ -1473,10 +1474,10 @@ function _detalhes:RestoreState_CurrentMythicDungeonRun() local savedTable = _detalhes.mythic_dungeon_currentsaved local mythicLevel = C_ChallengeMode.GetActiveKeystoneInfo() local zoneName, _, _, _, _, _, _, currentZoneID = GetInstanceInfo() - local mapID = C_Map.GetBestMapForUnit ("player") if (not mapID) then + --print("D! no mapID to restored mythic dungeon state.") return end @@ -1503,16 +1504,24 @@ function _detalhes:RestoreState_CurrentMythicDungeonRun() _detalhes.MythicPlus.PreviousBossKilledAt = savedTable.previous_boss_killed_at _detalhes.MythicPlus.IsRestoredState = true DetailsMythicPlusFrame.IsDoingMythicDungeon = true + + print("D! (debug) mythic dungeon state restored.") C_Timer.After (2, function() _detalhes:SendEvent ("COMBAT_MYTHICDUNGEON_START") end) return + else + print("D! (debug) mythic level isn't equal.", mythicLevel, savedTable.level) end + else + print("D! (debug) zone name or zone Id isn't the same:", zoneName, savedTable.dungeon_name, currentZoneID, savedTable.dungeon_zone_id) end --> mythic run is over savedTable.started = false + else + --print("D! savedTable.stated isn't true.") end end diff --git a/functions/spellcache.lua b/functions/spellcache.lua index 25dfd047d..829e72dc2 100644 --- a/functions/spellcache.lua +++ b/functions/spellcache.lua @@ -112,6 +112,8 @@ do [339538] = {name = GetSpellInfo (224266) .. " (Templar's Vindication)"}, -- + [108271] = {name = GetSpellInfo (108271), icon = "Interface\\Addons\\Details\\images\\icon_astral_shift"}, -- + --> shadowlands trinkets [345020] = {name = GetSpellInfo (345020) .. " (Trinket)"}, diff --git a/images/icon_astral_shift.tga b/images/icon_astral_shift.tga new file mode 100644 index 0000000000000000000000000000000000000000..5f5cf95086addfa09c6245db807b18478d482d65 GIT binary patch literal 12332 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 JHhe$l{{S