"Refactor Bastion.Bootstrap() function to improve spell dumping logic"

main
CiscOH Bellic 5 months ago
parent e63a7e1900
commit 61f8c2789a
  1. 76
      src/_bastion.lua

@ -251,41 +251,61 @@ function Bastion.Bootstrap()
end end
end) end)
Command:Register('dumpspells', 'Dump spells to a file', function() Command:Register('dumpspells', 'Dump spells to a file', function()
local i = 1
local rand = math.random(100000, 999999) local rand = math.random(100000, 999999)
local BOOKTYPE_SPELL = BOOKTYPE_SPELL or (Enum.SpellBookSpellBank.Player and Enum.SpellBookSpellBank.Player or 'spell')
while true do
local spellName, spellSubName
if C_SpellBook.GetSpellBookItemName then if C_SpellBook.GetNumSpellBookSkillLines then
spellName, spellSubName = C_SpellBook.GetSpellBookItemName(i, BOOKTYPE_SPELL) for i = 1, C_SpellBook.GetNumSpellBookSkillLines() do
else local skillLineInfo = C_SpellBook.GetSpellBookSkillLineInfo(i)
spellName, spellSubName = GetSpellBookItemName(i, BOOKTYPE_SPELL) local offset, numSlots = skillLineInfo.itemIndexOffset, skillLineInfo.numSpellBookItems
for j = offset+1, offset+numSlots do
local name, subName = C_SpellBook.GetSpellBookItemName(j, Enum.SpellBookSpellBank.Player)
local spellID = select(2,C_SpellBook.GetSpellBookItemType(j, Enum.SpellBookSpellBank.Player))
if spellID then
spellName = name:gsub("[%W%s]", "")
WriteFile('bastion-' .. UnitClass('player') .. '-' .. rand ..
'.lua',
"local " .. spellName ..
" = Bastion.Globals.SpellBook:GetSpell(" ..
spellID .. ")\n", true)
end
end
end end
end
if not spellName then do break end end if C_SpellBook.GetSpellBookSkillLineInfo then
for _, i in pairs{GetProfessions()} do
-- use spellName and spellSubName here local skillLineInfo = C_SpellBook.GetSpellBookSkillLineInfo(i)
local spellID local offset, numSlots = skillLineInfo.itemIndexOffset, skillLineInfo.numSpellBookItems
Bastion.Globals.Log:Log(59, { offset = offset, numSlots = numSlots}, logCat)
if C_Spell.GetSpellInfo then local name, subName = C_SpellBook.GetSpellBookItemName(j, Enum.SpellBookSpellBank.Player)
local info = C_Spell.GetSpellInfo(spellName) local spellID = select(2,C_SpellBook.GetSpellBookItemType(j, Enum.SpellBookSpellBank.Player))
spellID = info.spellID if spellID then
else spellName = name:gsub("[%W%s]", "")
spellID = select(7, GetSpellInfo(spellName)) WriteFile('bastion-' .. UnitClass('player') .. '-' .. rand ..
'.lua',
"local " .. spellName ..
" = Bastion.Globals.SpellBook:GetSpell(" ..
spellID .. ")\n", true)
end end
end end
end
if spellID then local numSpells, petToken = C_SpellBook.HasPetSpells() -- nil if pet does not have spellbook, 'petToken' will usually be "PET"
spellName = spellName:gsub("[%W%s]", "") if petToken then
WriteFile('bastion-' .. UnitClass('player') .. '-' .. rand .. for i=1, numSpells do
'.lua', local petSpellName, petSubType = C_SpellBook.GetSpellBookItemName(i, Enum.SpellBookSpellBank.Pet)
"local " .. spellName .. local spellID = select(2,C_SpellBook.GetSpellBookItemType(i, Enum.SpellBookSpellBank.Pet))
" = Bastion.Globals.SpellBook:GetSpell(" .. if spellID then
spellID .. ")\n", true) spellName = petSpellName:gsub("[%W%s]", "")
WriteFile('bastion-' .. UnitClass('player') .. '-' .. rand ..
'.lua',
"local " .. spellName ..
" = Bastion.Globals.SpellBook:GetSpell(" ..
spellID .. ")\n", true)
end
end end
i = i + 1
end end
end) end)
Command:Register('module', 'Toggle a module on/off', function(args) Command:Register('module', 'Toggle a module on/off', function(args)

Loading…
Cancel
Save