|
|
@ -4,6 +4,7 @@ local Tinkr = ... |
|
|
|
---@class Bastion |
|
|
|
---@class Bastion |
|
|
|
local Bastion = { |
|
|
|
local Bastion = { |
|
|
|
DebugMode = false, |
|
|
|
DebugMode = false, |
|
|
|
|
|
|
|
Globals = {}, |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
local TinkrScriptsBase = "scripts" |
|
|
|
local TinkrScriptsBase = "scripts" |
|
|
@ -59,7 +60,7 @@ end |
|
|
|
--- 0 = Failed, 1 = Success, 2 = Already Loaded |
|
|
|
--- 0 = Failed, 1 = Success, 2 = Already Loaded |
|
|
|
---@param filePath string | { filePath: string, reloadable: boolean } |
|
|
|
---@param filePath string | { filePath: string, reloadable: boolean } |
|
|
|
---@param ... any |
|
|
|
---@param ... any |
|
|
|
---@return 0|1|2, ... |
|
|
|
---@return 0|1|2, table |
|
|
|
function Bastion:Require(filePath, ...) |
|
|
|
function Bastion:Require(filePath, ...) |
|
|
|
local loadedFile = { |
|
|
|
local loadedFile = { |
|
|
|
originalPath = type(filePath) == "table" and filePath.filePath or tostring(filePath), |
|
|
|
originalPath = type(filePath) == "table" and filePath.filePath or tostring(filePath), |
|
|
@ -70,19 +71,12 @@ function Bastion:Require(filePath, ...) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
local filePathModifier = loadedFile.originalPath:sub(1, 1) |
|
|
|
local filePathModifier = loadedFile.originalPath:sub(1, 1) |
|
|
|
|
|
|
|
local base = filePathModifier == "@" and BastionScriptsBase or filePathModifier == "~" and BastionBase |
|
|
|
if filePathModifier == "@" then |
|
|
|
if base then |
|
|
|
-- If require starts with an @ then we require from the scripts/bastion/scripts folder |
|
|
|
loadedFile.newPath = string.format("%s%s", base, loadedFile.originalPath:sub(2)) |
|
|
|
loadedFile.newPath = string.format("%s%s", BastionScriptsBase, loadedFile.originalPath:sub(2)) |
|
|
|
|
|
|
|
loadedFile.loadedPath = loadedFile.newPath |
|
|
|
|
|
|
|
elseif filePathModifier == "~" then |
|
|
|
|
|
|
|
-- If file path starts with a ~ then we require from the scripts/bastion folder |
|
|
|
|
|
|
|
loadedFile.newPath = string.format("%s%s", BastionBase, loadedFile.originalPath:sub(2)) |
|
|
|
|
|
|
|
loadedFile.loadedPath = loadedFile.newPath |
|
|
|
loadedFile.loadedPath = loadedFile.newPath |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
loadedFile.loadedPath = loadedFile.newPath |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
local found = false |
|
|
|
local found = false |
|
|
|
-- Check if file path has a .lua or .luac extension. If not, try to add one and check if the file exists |
|
|
|
-- Check if file path has a .lua or .luac extension. If not, try to add one and check if the file exists |
|
|
|
loadedFile.loadedPath, found = CheckFileExtensions(loadedFile.newPath, { "lua", "luac" }) |
|
|
|
loadedFile.loadedPath, found = CheckFileExtensions(loadedFile.newPath, { "lua", "luac" }) |
|
|
@ -152,57 +146,46 @@ local function LoadThird() |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
---@generic V : string |
|
|
|
local bastionFiles = { |
|
|
|
---@param class `V` |
|
|
|
"~/src/ClassMagic/ClassMagic", |
|
|
|
---@return V ... |
|
|
|
"~/src/List/List", |
|
|
|
function Bastion.require(class) |
|
|
|
"~/src/Util/Util", |
|
|
|
---@cast class string |
|
|
|
"~/src/Library/Library", |
|
|
|
local newClass = class:gsub("Bastion%.", "") |
|
|
|
"~/src/Notification/Notification", |
|
|
|
-- return require("scripts/bastion/src/" .. class .. "/" .. class, Bastion) |
|
|
|
"~/src/NotificationList/NotificationList", |
|
|
|
local success, result = Bastion:Require("~/src/" .. newClass .. "/" .. newClass) |
|
|
|
"~/src/Vector3/Vector3", |
|
|
|
if success == 0 then |
|
|
|
"~/src/Sequencer/Sequencer", |
|
|
|
Log("Bastion.require - Failed to load " .. class .. ": " .. result) |
|
|
|
"~/src/Command/Command", |
|
|
|
end |
|
|
|
"~/src/Cache/Cache", |
|
|
|
return SafeUnpack(result) |
|
|
|
"~/src/Cacheable/Cacheable", |
|
|
|
end |
|
|
|
"~/src/Refreshable/Refreshable", |
|
|
|
|
|
|
|
"~/src/Unit/Unit", |
|
|
|
Bastion.Globals = {} |
|
|
|
"~/src/Aura/Aura", |
|
|
|
|
|
|
|
"~/src/APLTrait/APLTrait", |
|
|
|
Bastion.ClassMagic = Bastion.require("Bastion.ClassMagic") |
|
|
|
"~/src/APLActor/APLActor", |
|
|
|
Bastion.List = Bastion.require("Bastion.List") |
|
|
|
"~/src/APL/APL", |
|
|
|
Bastion.Library = Bastion.require("Bastion.Library") |
|
|
|
"~/src/Module/Module", |
|
|
|
Bastion.Notification = Bastion.require("Bastion.Notification") |
|
|
|
"~/src/UnitManager/UnitManager", |
|
|
|
Bastion.NotificationList = Bastion.require("Bastion.NotificationList") |
|
|
|
"~/src/ObjectManager/ObjectManager", |
|
|
|
Bastion.Vector3 = Bastion.require("Bastion.Vector3") |
|
|
|
"~/src/EventManager/EventManager", |
|
|
|
Bastion.Sequencer = Bastion.require("Bastion.Sequencer") |
|
|
|
"~/src/Spell/Spell", |
|
|
|
Bastion.Command = Bastion.require("Bastion.Command") |
|
|
|
"~/src/SpellBook/SpellBook", |
|
|
|
Bastion.Cache = Bastion.require("Bastion.Cache") |
|
|
|
"~/src/Item/Item", |
|
|
|
Bastion.Cacheable = Bastion.require("Bastion.Cacheable") |
|
|
|
"~/src/ItemBook/ItemBook", |
|
|
|
Bastion.Refreshable = Bastion.require("Bastion.Refreshable") |
|
|
|
"~/src/AuraTable/AuraTable", |
|
|
|
Bastion.Unit = Bastion.require("Bastion.Unit") |
|
|
|
"~/src/Class/Class", |
|
|
|
Bastion.Aura = Bastion.require("Bastion.Aura") |
|
|
|
"~/src/Timer/Timer", |
|
|
|
Bastion.APLTrait = Bastion.require("Bastion.APLTrait") |
|
|
|
"~/src/MythicPlusUtils/MythicPlusUtils", |
|
|
|
Bastion.APLActor = Bastion.require("Bastion.APLActor") |
|
|
|
"~/src/Config/Config", |
|
|
|
Bastion.APL = Bastion.require("Bastion.APL") |
|
|
|
"~/src/TimeToDie/TimeToDie", |
|
|
|
Bastion.Module = Bastion.require("Bastion.Module") |
|
|
|
} |
|
|
|
Bastion.UnitManager = Bastion.require("Bastion.UnitManager"):New() |
|
|
|
|
|
|
|
Bastion.ObjectManager = Bastion.require("Bastion.ObjectManager"):New() |
|
|
|
for i = 1, #bastionFiles do |
|
|
|
Bastion.EventManager = Bastion.require("Bastion.EventManager") |
|
|
|
Bastion:Require(bastionFiles[i]) |
|
|
|
Bastion.Globals.EventManager = Bastion.EventManager:New() |
|
|
|
end |
|
|
|
Bastion.Spell = Bastion.require("Bastion.Spell") |
|
|
|
|
|
|
|
Bastion.SpellBook = Bastion.require("Bastion.SpellBook") |
|
|
|
Bastion.Globals.CombatTimer = Bastion.Timer:New("combat") |
|
|
|
Bastion.Globals.SpellBook = Bastion.SpellBook:New() |
|
|
|
Bastion.Globals.Notifications = Bastion.NotificationList:New() |
|
|
|
Bastion.Item = Bastion.require("Bastion.Item") |
|
|
|
|
|
|
|
Bastion.ItemBook = Bastion.require("Bastion.ItemBook") |
|
|
|
|
|
|
|
Bastion.Globals.ItemBook = Bastion.ItemBook:New() |
|
|
|
|
|
|
|
Bastion.AuraTable = Bastion.require("Bastion.AuraTable") |
|
|
|
|
|
|
|
Bastion.Class = Bastion.require("Bastion.Class") |
|
|
|
|
|
|
|
Bastion.Timer = Bastion.require("Bastion.Timer") |
|
|
|
|
|
|
|
Bastion.CombatTimer = Bastion.Timer:New("combat") |
|
|
|
|
|
|
|
Bastion.MythicPlusUtils = Bastion.require("Bastion.MythicPlusUtils"):New() |
|
|
|
|
|
|
|
Bastion.Notifications = Bastion.NotificationList:New() |
|
|
|
|
|
|
|
Bastion.Config = Bastion.require("Bastion.Config") |
|
|
|
|
|
|
|
Bastion.TimeToDie = Bastion.require("Bastion.TimeToDie") |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
---@param unitTarget UnitId |
|
|
|
---@param unitTarget UnitId |
|
|
|
Bastion.Globals.EventManager:RegisterWoWEvent("UNIT_HEALTH", function(unitTarget) |
|
|
|
Bastion.Globals.EventManager:RegisterWoWEvent("UNIT_HEALTH", function(unitTarget) |
|
|
@ -210,27 +193,6 @@ Bastion.Globals.EventManager:RegisterWoWEvent("UNIT_HEALTH", function(unitTarget |
|
|
|
end) |
|
|
|
end) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
---@enum (key) CompareThisTable |
|
|
|
|
|
|
|
local compareThisTable = { |
|
|
|
|
|
|
|
[">"] = function(A, B) return A > B end, |
|
|
|
|
|
|
|
["<"] = function(A, B) return A < B end, |
|
|
|
|
|
|
|
[">="] = function(A, B) return A >= B end, |
|
|
|
|
|
|
|
["<="] = function(A, B) return A <= B end, |
|
|
|
|
|
|
|
["=="] = function(A, B) return A == B end, |
|
|
|
|
|
|
|
["min"] = function(A, B) return A < B end, |
|
|
|
|
|
|
|
["max"] = function(A, B) return A > B end, |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Bastion.Utils = { |
|
|
|
|
|
|
|
---@generic A |
|
|
|
|
|
|
|
---@param operator CompareThisTable |
|
|
|
|
|
|
|
---@param a A |
|
|
|
|
|
|
|
---@param b A |
|
|
|
|
|
|
|
CompareThis = function(operator, a, b) |
|
|
|
|
|
|
|
return compareThisTable[operator](a, b) |
|
|
|
|
|
|
|
end |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
---@type table<string, Bastion.Library> |
|
|
|
---@type table<string, Bastion.Library> |
|
|
|
local LIBRARIES = {} |
|
|
|
local LIBRARIES = {} |
|
|
|
|
|
|
|
|
|
|
@ -290,17 +252,6 @@ Bastion.Globals.EventManager:RegisterWoWEvent("COMBAT_LOG_EVENT_UNFILTERED", fun |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
-- if sourceGUID == pguid then |
|
|
|
|
|
|
|
-- local args = { CombatLogGetCurrentEventInfo() } |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
-- for i = 1, #args do |
|
|
|
|
|
|
|
-- Log(tostring(args[i])) |
|
|
|
|
|
|
|
-- end |
|
|
|
|
|
|
|
-- end |
|
|
|
|
|
|
|
--Bastion.UnitManager:SetCombatTime(sourceGUID) |
|
|
|
|
|
|
|
--Bastion.UnitManager:SetCombatTime(destGUID) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
local u = Bastion.UnitManager[sourceGUID] |
|
|
|
local u = Bastion.UnitManager[sourceGUID] |
|
|
|
local u2 = Bastion.UnitManager[destGUID] |
|
|
|
local u2 = Bastion.UnitManager[destGUID] |
|
|
|
|
|
|
|
|
|
|
@ -339,10 +290,10 @@ Bastion.Ticker = C_Timer.NewTicker(0.1, function() |
|
|
|
Bastion.Now = GetTime() |
|
|
|
Bastion.Now = GetTime() |
|
|
|
Bastion.Tick = GetGameTick() |
|
|
|
Bastion.Tick = GetGameTick() |
|
|
|
|
|
|
|
|
|
|
|
if not Bastion.CombatTimer:IsRunning() and UnitAffectingCombat("player") then |
|
|
|
if not Bastion.Globals.CombatTimer:IsRunning() and UnitAffectingCombat("player") then |
|
|
|
Bastion.CombatTimer:Start() |
|
|
|
Bastion.Globals.CombatTimer:Start() |
|
|
|
elseif Bastion.CombatTimer:IsRunning() and not UnitAffectingCombat("player") then |
|
|
|
elseif Bastion.Globals.CombatTimer:IsRunning() and not UnitAffectingCombat("player") then |
|
|
|
Bastion.CombatTimer:Reset() |
|
|
|
Bastion.Globals.CombatTimer:Reset() |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
if Bastion.Enabled then |
|
|
|
if Bastion.Enabled then |
|
|
|