diff options
author | chai <chaifix@163.com> | 2021-11-15 13:53:59 +0800 |
---|---|---|
committer | chai <chaifix@163.com> | 2021-11-15 13:53:59 +0800 |
commit | 942a030afd348ab2e02eac8054b43e3c3a72ea48 (patch) | |
tree | a13459f39a3d2f1b533fbd1b5ab523d7a621f673 /Data/BuiltIn/Libraries/lua-addons/addons/SpellCheck/SpellCheck.lua | |
parent | e307051a56a54c27f10438fd2025edf61d0dfeed (diff) |
*rename
Diffstat (limited to 'Data/BuiltIn/Libraries/lua-addons/addons/SpellCheck/SpellCheck.lua')
-rw-r--r-- | Data/BuiltIn/Libraries/lua-addons/addons/SpellCheck/SpellCheck.lua | 117 |
1 files changed, 117 insertions, 0 deletions
diff --git a/Data/BuiltIn/Libraries/lua-addons/addons/SpellCheck/SpellCheck.lua b/Data/BuiltIn/Libraries/lua-addons/addons/SpellCheck/SpellCheck.lua new file mode 100644 index 0000000..0d77066 --- /dev/null +++ b/Data/BuiltIn/Libraries/lua-addons/addons/SpellCheck/SpellCheck.lua @@ -0,0 +1,117 @@ +--Copyright © 2015, Damien Dennehy +--All rights reserved. + +--Redistribution and use in source and binary forms, with or without +--modification, are permitted provided that the following conditions are met: + +-- * Redistributions of source code must retain the above copyright +-- notice, this list of conditions and the following disclaimer. +-- * Redistributions in binary form must reproduce the above copyright +-- notice, this list of conditions and the following disclaimer in the +-- documentation and/or other materials provided with the distribution. +-- * Neither the name of SpellCheck nor the +-- names of its contributors may be used to endorse or promote products +-- derived from this software without specific prior written permission. + +--THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND +--ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +--WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +--DISCLAIMED. IN NO EVENT SHALL DAMIEN DENNEHY BE LIABLE FOR ANY +--DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES +--(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +--LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND +--ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +--(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS +--SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +_addon.name = 'SpellCheck' +_addon.author = 'Zubis' +_addon.version = '1.0.2' +_addon.command = 'SpellCheck' + +require('sets') +require('tables') +res = require('resources') + +require('SpellExceptions') + +--Declare valid spell types +spell_type = {whm='WhiteMagic',blm='BlackMagic',smn='SummonerPact',nin='Ninjutsu',brd='BardSong',blu='BlueMagic',geo='Geomancy',tru='Trust'} + +--Declare friendly name of spell types for chat output +display_spell_type = {whm='White Magic',blm='Black Magic',smn='Summoner',nin='Ninjutsu',brd='Bard',blu='Blue Magic',geo='Geomancy',tru='Trust'} + +--Register the base //SpellCheck command +windower.register_event('addon command',function (command, ...) + command = command and command:lower() or 'help' + if command == 'help' or command == 'h' or command == '?' then + display_help() + elseif spell_type[command] == nil then + display_error(command) + else + display_spell_count(command) + end +end) + +--Display a basic help section +function display_help() + windower.add_to_chat(7, _addon.name .. ' v.' .. _addon.version) + windower.add_to_chat(7, 'Usage: //spellcheck whm | blm | smn | nin | brd | blu | geo | tru') + windower.add_to_chat(7, 'Sample: //spellcheck whm') +end + +--Display error based on invalid selection +function display_error(command) + windower.add_to_chat(7, _addon.name .. ' v.' .. _addon.version) + windower.add_to_chat(7, 'Error: ' .. command .. ' is not a valid option.') + windower.add_to_chat(7, 'Usage: //spellcheck whm | blm | smn | nin | brd | blu | geo | tru') +end + +--Get spells +function display_spell_count(command) + + missing_spells_len = 0 + missing_spell_names = {} + + --Get all, current and missing spells + all_spells = res.spells:type(spell_type[command]):keyset() + current_spells = T(windower.ffxi.get_spells()):filter(boolean._true):keyset() + + missing_spells = all_spells - current_spells + current_spells = all_spells * current_spells + + --Add missing spells to table for sorting + for spell in missing_spells:it() do + --Trust and spells must be processed separately + if command == 'tru' then + --Only include non Unity trusts + if not res.spells[spell].name:endswith('(UC)') then + missing_spells_len = missing_spells_len + 1 + table.insert(missing_spell_names, res.spells[spell].name) + end + else + --Add to missing spell list only if it's a valid spell + --And it's not in the spell exception list + if not table.empty(res.spells[spell].levels) and spell_exceptions[res.spells[spell].id] == nil then + missing_spells_len = missing_spells_len + 1 + table.insert(missing_spell_names, res.spells[spell].name) + end + end + end + + --Sort missing spells by name + table.sort(missing_spell_names) + + --If there are missing spells, display that they are about to be listed + if missing_spells_len > 0 then + windower.add_to_chat(7, 'SpellCheck: Listing missing ' .. display_spell_type[command] .. ' spells...') + end + + --List all missing spell names + for i, spell in ipairs(missing_spell_names) do + windower.add_to_chat(7, ' - Missing \'' .. spell .. '\'') + end + + --Display summary + windower.add_to_chat(7, 'SpellCheck: You are missing ' .. missing_spells_len .. ' ' .. display_spell_type[command] .. ' spells.') +end |