@ -6,18 +6,17 @@ local DiesalTools = LibStub:NewLibrary(MAJOR, MINOR)
if not DiesalTools then
if not DiesalTools then
return
return
end -- No Upgrade needed.
end
-- ~~| Libraries |~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-- ~~| Lua Upvalues |~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
local type , select , pairs , tonumber , tostring = type , select , pairs , tonumber , tostring
local type , select , pairs , tonumber , tostring = type , select , pairs , tonumber , tostring
local table_concat = table.concat
local table_concat = table.concat
local setmetatable , getmetatable , next = setmetatable , getmetatable , next
local setmetatable , getmetatable , next = setmetatable , getmetatable , next
local sub , format , lower , upper , gsub = string.sub , string.format , string.lower , string.upper , string.gsub
local sub , format , lower , upper , gsub = string.sub , string.format , string.lower , string.upper , string.gsub
local floor , ceil , abs , modf = math.floor , math.ceil , math.abs , math.modf
local floor , ceil , abs , modf = math.floor , math.ceil , math.abs , math.modf
-- ~~| WoW Upvalues |~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
local CreateFrame , UIParent , GetCursorPosition = CreateFrame , UIParent , GetCursorPosition
local CreateFrame , UIParent , GetCursorPosition = CreateFrame , UIParent , GetCursorPosition
local GetScreenWidth , GetScreenHeight = GetScreenWidth , GetScreenHeight
local GetScreenWidth , GetScreenHeight = GetScreenWidth , GetScreenHeight
-- ~~| Locals |~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
local escapeSequences = {
local escapeSequences = {
[ " \a " ] = " \\ a " , -- Bell
[ " \a " ] = " \\ a " , -- Bell
[ " \b " ] = " \\ b " , -- Backspace
[ " \b " ] = " \\ b " , -- Backspace
@ -30,6 +29,7 @@ local escapeSequences = {
[ ' " ' ] = ' \\ " ' , -- Quotation mark
[ ' " ' ] = ' \\ " ' , -- Quotation mark
[ " | " ] = " || " ,
[ " | " ] = " || " ,
}
}
local lua_keywords = {
local lua_keywords = {
[ " and " ] = true ,
[ " and " ] = true ,
[ " break " ] = true ,
[ " break " ] = true ,
@ -72,7 +72,6 @@ local formattedArgs = {}
---@param level number
---@param level number
local function GetCaller ( level )
local function GetCaller ( level )
-- ADDON:LogMessage(debugstack(10,2, 0))
for trace in debugstack ( level , 2 , 0 ) : gmatch ( " (.-) \n " ) do
for trace in debugstack ( level , 2 , 0 ) : gmatch ( " (.-) \n " ) do
-- Blizzard Sandbox
-- Blizzard Sandbox
local match , _ , file , line = trace : find ( " ^.* \\ (.-):(%d+) " )
local match , _ , file , line = trace : find ( " ^.* \\ (.-):(%d+) " )
@ -92,12 +91,14 @@ local function GetCaller(level)
end
end
return format ( " %s[%sUnknown Caller%s]|r " , colors.orange , colors.red , colors.orange )
return format ( " %s[%sUnknown Caller%s]|r " , colors.orange , colors.red , colors.orange )
end
end
---@param number number
---@param number number
---@param base? number
---@param base? number
local function round ( number , base )
local function round ( number , base )
base = base or 1
base = base or 1
return floor ( ( number + base / 2 ) / base ) * base
return floor ( ( number + base / 2 ) / base ) * base
end
end
---@param color string | number | table
---@param color string | number | table
---@param g? number
---@param g? number
---@param b? number
---@param b? number
@ -117,9 +118,10 @@ local function getRGBColorValues(color, g, b)
end
end
end
end
---@param value string | number[]
function DiesalTools . GetColor ( value )
function DiesalTools . GetColor ( value )
if not value then
if not value then
return
return nil
end
end
if type ( value ) == " table " and # value >= 3 then
if type ( value ) == " table " and # value >= 3 then
@ -132,8 +134,11 @@ end
-- ~~| API |~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-- ~~| API |~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
function DiesalTools . Stack ( )
function DiesalTools . Stack ( )
print ( " |r------------------------------| Stack Trace |------------------------------- " )
local stack = debugstack ( 1 , 12 , 0 )
local stack = debugstack ( 1 , 12 , 0 )
if not stack then
return
end
print ( " |r--------------------------------| Stack Trace |--------------------------------- " )
for trace in stack : gmatch ( " (.-) \n " ) do
for trace in stack : gmatch ( " (.-) \n " ) do
local match , _ , file , line , func = trace : find ( " ^.* \\ (.-):(%d+).-`(.*)'$ " )
local match , _ , file , line , func = trace : find ( " ^.* \\ (.-):(%d+).-`(.*)'$ " )
if match then
if match then
@ -143,14 +148,11 @@ function DiesalTools.Stack()
print ( " |r-------------------------------------------------------------------------------- " )
print ( " |r-------------------------------------------------------------------------------- " )
end
end
--[[ copy = TableCopy(src, dest, metatable)
---@generic S
@ Arguments :
---@param src S
dest Table to copy to
---@param dest? table
src Table to copy
---@param metatable? boolean
metatable if true copies the metatable as well ( boolean )
---@return S
@ Returns :
table copy of table
--]]
function DiesalTools . TableCopy ( src , dest , metatable )
function DiesalTools . TableCopy ( src , dest , metatable )
if type ( src ) == " table " then
if type ( src ) == " table " then
if not dest then
if not dest then