diff --git a/.gitignore b/.gitignore index 87e8f31..8cc8bf7 100644 --- a/.gitignore +++ b/.gitignore @@ -7,7 +7,11 @@ DS_Store ## ignore all files in scripts scripts/* +!scripts/Libraries +scripts/Libraries/* !scripts/.gitkeep +!scripts/ExampleModule.lua +!scripts/Libraries/ExampleLibrary.lua ## ignore vscode settings .vscode/* diff --git a/scripts/ExampleModule.lua b/scripts/ExampleModule.lua new file mode 100644 index 0000000..e659bb7 --- /dev/null +++ b/scripts/ExampleModule.lua @@ -0,0 +1,17 @@ +local Tinkr, Bastion = ... +local ExampleModule = Bastion.Module:New('ExampleModule') +local Player = Bastion.UnitManager:Get('player') + +local FlashHeal = Bastion.SpellBook:GetSpell(2061) + +local AdvancedMath = Bastion:GetLibrary('AdvancedMath') + +print(AdvancedMath:Add(1, 2)) + +ExampleModule:Sync(function() + if Player:GetHP() <= 50 then + FlashHeal:Cast(Player) + end +end) + +Bastion:Register(ExampleModule) diff --git a/scripts/Libraries/ExampleLibrary.lua b/scripts/Libraries/ExampleLibrary.lua new file mode 100644 index 0000000..15a4a36 --- /dev/null +++ b/scripts/Libraries/ExampleLibrary.lua @@ -0,0 +1,14 @@ +local Tinkr, Bastion = ... + +local ExampleModule = Bastion.Module:New('ExampleModule') +local Player = Bastion.UnitManager:Get('player') + +local AdvancedMath = {} + +AdvancedMath.__index = AdvancedMath + +function AdvancedMath:Add(a, b) + return a + b +end + +Bastion:RegisterLibrary('AdvancedMath', AdvancedMath) diff --git a/src/_bastion.lua b/src/_bastion.lua index b64c986..64910fe 100644 --- a/src/_bastion.lua +++ b/src/_bastion.lua @@ -7,7 +7,7 @@ local Bastion = { Bastion.__index = Bastion function Bastion.require(class) - return Tinkr:require("scripts/bastion/src/" .. class .. "/" .. class, Bastion) + return require("scripts/bastion/src/" .. class .. "/" .. class, Bastion) end ---@type ClassMagic @@ -61,7 +61,8 @@ Bastion.CombatTimer = Bastion.Timer:New('combat') Bastion.MythicPlusUtils = Bastion.require("MythicPlusUtils"):New() ---@type NotificationsList Bastion.Notifications = Bastion.NotificationsList:New() -Bastion.modules = {} +local LIBRARIES = {} +local MODULES = {} Bastion.Enabled = false Bastion.EventManager:RegisterWoWEvent('UNIT_AURA', function(unit, auras) @@ -89,7 +90,7 @@ end) local pguid = UnitGUID("player") local missed = {} Bastion.EventManager:RegisterWoWEvent("COMBAT_LOG_EVENT_UNFILTERED", function() - local args = { CombatLogGetCurrentEventInfo() } + local args = {CombatLogGetCurrentEventInfo()} local subEvent = args[2] local sourceGUID = args[4] @@ -131,6 +132,16 @@ Bastion.EventManager:RegisterWoWEvent("COMBAT_LOG_EVENT_UNFILTERED", function() end end end) + +function Bastion:RegisterLibrary(name, payload) + LIBRARIES[name] = payload + -- Bastion:Print("Registered Library", name) +end + +function Bastion:GetLibrary(name) + return LIBRARIES[name] +end + Bastion.Ticker = C_Timer.NewTicker(0.1, function() if not Bastion.CombatTimer:IsRunning() and UnitAffectingCombat("player") then Bastion.CombatTimer:Start() @@ -140,29 +151,29 @@ Bastion.Ticker = C_Timer.NewTicker(0.1, function() if Bastion.Enabled then Bastion.ObjectManager:Refresh() - for i = 1, #Bastion.modules do - Bastion.modules[i]:Tick() + for i = 1, #MODULES do + MODULES[i]:Tick() end end end) function Bastion:Register(module) - table.insert(Bastion.modules, module) + table.insert(MODULES, module) Bastion:Print("Registered", module) end -- Find a module by name function Bastion:FindModule(name) - for i = 1, #Bastion.modules do - if Bastion.modules[i].name == name then - return Bastion.modules[i] + for i = 1, #MODULES do + if MODULES[i].name == name then + return MODULES[i] end end return nil end function Bastion:Print(...) - local args = { ... } + local args = {...} local str = "|cFFDF362D[Bastion]|r |cFFFFFFFF" for i = 1, #args do str = str .. tostring(args[i]) .. " " @@ -174,7 +185,7 @@ function Bastion:Debug(...) if not Bastion.DebugMode then return end - local args = { ... } + local args = {...} local str = "|cFFDF6520[Bastion]|r |cFFFFFFFF" for i = 1, #args do str = str .. tostring(args[i]) .. " " @@ -207,7 +218,9 @@ Command:Register('dumpspells', 'Dump spells to a file', function() while true do local spellName, spellSubName = GetSpellBookItemName(i, BOOKTYPE_SPELL) if not spellName then - do break end + do + break + end end -- use spellName and spellSubName here @@ -261,14 +274,17 @@ Command:Register('missed', 'Dump the list of immune kidney shot spells', functio end end) -local files = ListFiles("scripts/bastion/scripts") - -for i = 1, #files do - local file = files[i] - if file:sub(-4) == ".lua" or file:sub(-5) == '.luac' then +local function Load(dir) + local files = ListFiles(dir) - Tinkr:require("scripts/bastion/scripts/" .. file:sub(1, -5), Bastion) + for i = 1, #files do + local file = files[i] + if file:sub(-4) == ".lua" or file:sub(-5) == '.luac' then + require(dir .. file:sub(1, -5), Bastion) + end end end - +Load("scripts/bastion/scripts/Libraries/") +Load("scripts/bastion/scripts/Modules/") +Load("scripts/bastion/scripts/")