Update Full Recharge time.

main
ck 1 year ago
parent d69fd5d46a
commit 6fd60c6a4f
  1. 2
      src/Cache/Cache.lua
  2. 10
      src/Cacheable/Cacheable.lua
  3. 7
      src/Spell/Spell.lua
  4. 7
      src/UnitManager/UnitManager.lua
  5. 35
      src/_bastion.lua

@ -19,7 +19,7 @@ function Cache:Set(key, value, duration)
self.cache[key] = {
value = value,
duration = duration,
time = GetTime()
time = GetTime(),
}
end

@ -1,11 +1,10 @@
---@types Tinkr, Bastion
---@type Tinkr, Bastion
local Tinkr, Bastion = ...
-- Define a Cacheable class
---@class Cacheable<V>: { value: V, cache: Cache, callback?: fun(): V }
---@class Cacheable
---@field cache? Cache
---@field callback? fun():any
---@field value any
local Cacheable = {
cache = nil,
callback = nil,
@ -41,9 +40,8 @@ end
-- Create
---@generic V : Cacheable, V
---@param value V
---@param value `V`
---@param cb fun(): V
---@return V
function Cacheable:New(value, cb)
local self = setmetatable({}, Cacheable)

@ -127,11 +127,8 @@ function Spell:GetFullRechargeTime()
return 0
end
if charges == 0 then
return start + duration - GetTime()
end
return chargeStart + chargeDuration - GetTime()
local totalChargeTime = ((maxCharges - charges) * chargeDuration) - ((chargeStart + chargeDuration) - GetTime())
return totalChargeTime
end
-- Return the castable function

@ -5,7 +5,7 @@ local ObjectManager = Tinkr.Util.ObjectManager
local Unit = Bastion.Unit
---@class CacheableUnit : Cacheable, Unit
---@class CacheableUnit<U> : Cacheable<U>
-- Create a new UnitManager class
---@class UnitManager : { [UnitId]: Unit }
@ -122,16 +122,14 @@ end
-- Create a custom unit and cache it for .5 seconds
---@param token string
---@param cb fun(): Unit
---@return CacheableUnit
---@return Cacheable<Unit>
function UnitManager:CreateCustomUnit(token, cb)
local unit = cb()
---@type CacheableUnit
local cachedUnit = Bastion.Cacheable:New(unit, cb)
if unit == nil then
error("UnitManager:CreateCustomUnit - Invalid unit: " .. token)
end
if self.customUnits[token] == nil then
self.customUnits[token] = {
unit = cachedUnit,
@ -140,7 +138,6 @@ function UnitManager:CreateCustomUnit(token, cb)
end
self.cache:Set(token, cachedUnit, 0.5)
return cachedUnit
end

@ -82,7 +82,9 @@ local function LoadThird()
end
end
---@return any ...
---@generic V
---@param class `V`
---@return V ...
function Bastion.require(class)
-- return require("scripts/bastion/src/" .. class .. "/" .. class, Bastion)
return Bastion:Require("~/src/" .. class .. "/" .. class)
@ -90,62 +92,37 @@ end
Bastion.Globals = {}
---@type ClassMagic
Bastion.ClassMagic = Bastion.require("ClassMagic")
---@type List
Bastion.List = Bastion.require("List")
---@type Library
Bastion.Library = Bastion.require("Library")
---@type NotificationsList, Notification
Bastion.NotificationsList, Bastion.Notification = Bastion.require("NotificationsList")
---@type Vector3
Bastion.Vector3 = Bastion.require("Vector3")
---@type Sequencer
Bastion.Sequencer = Bastion.require("Sequencer")
---@type Command
Bastion.Command = Bastion.require("Command")
---@type Cache
Bastion.Cache = Bastion.require("Cache")
---@type Cacheable
Bastion.Cacheable = Bastion.require("Cacheable")
---@type Refreshable
Bastion.Refreshable = Bastion.require("Refreshable")
---@type Unit
Bastion.Unit = Bastion.require("Unit")
---@type Aura
Bastion.Aura = Bastion.require("Aura")
---@type APL, APLActor, APLTrait
Bastion.APL, Bastion.APLActor, Bastion.APLTrait = Bastion.require("APL")
---@type Module
Bastion.Module = Bastion.require("Module")
---@type UnitManager
Bastion.UnitManager = Bastion.require("UnitManager"):New()
---@type ObjectManager
Bastion.ObjectManager = Bastion.require("ObjectManager"):New()
---@type EventManager
Bastion.EventManager = Bastion.require("EventManager")
Bastion.Globals.EventManager = Bastion.EventManager:New()
---@type Spell
Bastion.Spell = Bastion.require("Spell")
---@type SpellBook
Bastion.SpellBook = Bastion.require("SpellBook")
Bastion.Globals.SpellBook = Bastion.SpellBook:New()
---@type Item
Bastion.Item = Bastion.require("Item")
---@type ItemBook
Bastion.ItemBook = Bastion.require("ItemBook")
Bastion.Globals.ItemBook = Bastion.ItemBook:New()
---@type AuraTable
Bastion.AuraTable = Bastion.require("AuraTable")
---@type Class
Bastion.Class = Bastion.require("Class")
---@type Timer
Bastion.Timer = Bastion.require("Timer")
---@type Timer
Bastion.CombatTimer = Bastion.Timer:New("combat")
---@type MythicPlusUtils
Bastion.MythicPlusUtils = Bastion.require("MythicPlusUtils"):New()
---@type NotificationsList
Bastion.Notifications = Bastion.NotificationsList:New()
local LIBRARIES = {}
@ -317,11 +294,7 @@ Command:Register("dumpspells", "Dump spells to a file", function()
if spellID then
spellName = spellName:gsub("[%W%s]", "")
WriteFile(
"bastion-" .. UnitClass("player") .. "-" .. rand .. ".lua",
"local " .. spellName .. " = Bastion.Globals.SpellBook:GetSpell(" .. spellID .. ")\n",
true
)
WriteFile("bastion-" .. UnitClass("player") .. "-" .. rand .. ".lua", "local " .. spellName .. " = Bastion.Globals.SpellBook:GetSpell(" .. spellID .. ")\n", true)
end
i = i + 1
end

Loading…
Cancel
Save