vanilla-wow-addons – Rev 1
?pathlinks?
local MAJOR_VERSION = "1.0"
local MINOR_VERSION = tonumber(string.sub("$Revision: 8892 $", 12, -3))
if AbacusLib and AbacusLib.versions[MAJOR_VERSION] and AbacusLib.versions[MAJOR_VERSION].minor >= MINOR_VERSION then
return
end
-------------IRIEL'S-STUB-CODE--------------
local stub = {};
-- Instance replacement method, replace contents of old with that of new
function stub:ReplaceInstance(old, new)
for k,v in pairs(old) do old[k]=nil; end
for k,v in pairs(new) do old[k]=v; end
end
-- Get a new copy of the stub
function stub:NewStub()
local newStub = {};
self:ReplaceInstance(newStub, self);
newStub.lastVersion = '';
newStub.versions = {};
return newStub;
end
-- Get instance version
function stub:GetInstance(version)
if (not version) then version = self.lastVersion; end
local versionData = self.versions[version];
if (not versionData) then
message("Cannot find library instance with version '"
.. version .. "'");
return;
end
return versionData.instance;
end
-- Register new instance
function stub:Register(newInstance)
local version,minor = newInstance:GetLibraryVersion();
self.lastVersion = version;
local versionData = self.versions[version];
if (not versionData) then
-- This one is new!
versionData = { instance = newInstance,
minor = minor,
old = {}
};
self.versions[version] = versionData;
newInstance:LibActivate(self);
return newInstance;
end
if (minor <= versionData.minor) then
-- This one is already obsolete
if (newInstance.LibDiscard) then
newInstance:LibDiscard();
end
return versionData.instance;
end
-- This is an update
local oldInstance = versionData.instance;
local oldList = versionData.old;
versionData.instance = newInstance;
versionData.minor = minor;
local skipCopy = newInstance:LibActivate(self, oldInstance, oldList);
table.insert(oldList, oldInstance);
if (not skipCopy) then
for i, old in ipairs(oldList) do
self:ReplaceInstance(old, newInstance);
end
end
return newInstance;
end
-- Bind stub to global scope if it's not already there
if (not AbacusLib) then
AbacusLib = stub:NewStub();
end
-- Nil stub for garbage collection
stub = nil;
-----------END-IRIEL'S-STUB-CODE------------
local function assert(condition, message)
if not condition then
local stack = debugstack()
local first = string.gsub(stack, "\n.*", "")
local file = string.gsub(first, "^(.*\\.*).lua:%d+: .*", "%1")
file = string.gsub(file, "([%(%)%.%*%+%-%[%]%?%^%$%%])", "%%%1")
if not message then
local _,_,second = string.find(stack, "\n(.-)\n")
message = "assertion failed! " .. second
end
message = "BabbleLib-Zone: " .. message
local i = 1
for s in string.gfind(stack, "\n([^\n]*)") do
i = i + 1
if not string.find(s, file .. "%.lua:%d+:") then
error(message, i)
return
end
end
error(message, 2)
return
end
return condition
end
local function argCheck(arg, num, kind, kind2, kind3, kind4)
if tostring(type(arg)) ~= kind then
if kind2 then
if tostring(type(arg)) ~= kind2 then
if kind3 then
if tostring(type(arg)) ~= kind3 then
if kind4 then
if tostring(type(arg)) ~= kind4 then
local _,_,func = string.find(debugstack(), "\n.-`(.-)'\n")
assert(false, format("Bad argument #%d to `%s' (%s, %s, %s, or %s expected, got %s)", num, func, kind, kind2, kind3, kind4, type(arg)))
end
else
local _,_,func = string.find(debugstack(), "\n.-`(.-)'\n")
assert(false, format("Bad argument #%d to `%s' (%s, %s, or %s expected, got %s)", num, func, kind, kind2, kind3, type(arg)))
end
end
else
local _,_,func = string.find(debugstack(), "\n.-`(.-)'\n")
assert(false, format("Bad argument #%d to `%s' (%s or %s expected, got %s)", num, func, kind, kind2, type(arg)))
end
end
else
local _,_,func = string.find(debugstack(), "\n.-`(.-)'\n")
assert(false, format("Bad argument #%d to `%s' (%s expected, got %s)", num, func, kind, type(arg)))
end
end
end
local lib = {}
local COPPER_ABBR = strlower(strsub(COPPER, 1, 1))
local SILVER_ABBR = strlower(strsub(SILVER, 1, 1))
local GOLD_ABBR = strlower(strsub(GOLD, 1, 1))
local COLOR_WHITE = "ffffff"
local COLOR_GREEN = "00ff00"
local COLOR_RED = "ff0000"
local COLOR_COPPER = "eda55f"
local COLOR_SILVER = "c7c7cf"
local COLOR_GOLD = "ffd700"
local inf = 1/0
function lib:FormatMoneyExtended(value, colorize, textColor)
argCheck(value, 2, "number")
local gold = value / 10000
local silver = abs(mod(value / 100, 100))
local copper = abs(mod(value, 100))
local color = COLOR_WHITE
if textColor then
if value > 0 then
color = COLOR_GREEN
elseif value < 0 then
color = COLOR_RED
end
end
if colorize then
if value == inf or value == -inf then
return format("|cff%s%s|r", color, value)
elseif value ~= value then
return format("|cff%s0|r|cff%s %s|r", COLOR_WHITE, COLOR_COPPER, COPPER)
elseif value >= 10000 or value <= -10000 then
return format("|cff%s%d|r|cff%s %s|r |cff%s%d|r|cff%s %s|r |cff%s%d|r|cff%s %s|r", color, gold, COLOR_GOLD, GOLD, color, silver, COLOR_SILVER, SILVER, color, copper, COLOR_COPPER, COPPER)
elseif value >= 100 or value <= -100 then
return format("|cff%s%d|r|cff%s %s|r |cff%s%d|r|cff%s %s|r", color, silver, COLOR_SILVER, SILVER, color, copper, COLOR_COPPER, COPPER)
else
return format("|cff%s%d|r|cff%s %s|r", color, copper, COLOR_COPPER, COPPER)
end
else
if value == inf or value == -inf then
return format("%s", value)
elseif value ~= value then
return format("0 %s", COPPER)
elseif value >= 10000 or value <= -10000 then
return format("%d %s %d %s %d %s", gold, GOLD, silver, SILVER, copper, COPPER)
elseif value >= 100 or value <= -100 then
return format("%d %s %d %s", silver, SILVER, copper, COPPER)
else
return format("%d %s", copper, COPPER)
end
end
end
function lib:FormatMoneyFull(value, colorize, textColor)
argCheck(value, 2, "number")
local gold = value / 10000
local silver = abs(mod(value / 100, 100))
local copper = abs(mod(value, 100))
local color = COLOR_WHITE
if textColor then
if value > 0 then
color = COLOR_GREEN
elseif value < 0 then
color = COLOR_RED
end
end
if colorize then
if value == inf or value == -inf then
return format("|cff%s%s|r", color, value)
elseif value ~= value then
return format("|cff%s0|r|cff%s%s|r", COLOR_WHITE, COLOR_COPPER, COPPER_ABBR)
elseif value >= 10000 or value <= -10000 then
return format("|cff%s%d|r|cff%s%s|r |cff%s%d|r|cff%s%s|r |cff%s%d|r|cff%s%s|r", color, gold, COLOR_GOLD, GOLD_ABBR, color, silver, COLOR_SILVER, SILVER_ABBR, color, copper, COLOR_COPPER, COPPER_ABBR)
elseif value >= 100 or value <= -100 then
return format("|cff%s%d|r|cff%s%s|r |cff%s%d|r|cff%s%s|r", color, silver, COLOR_SILVER, SILVER_ABBR, color, copper, COLOR_COPPER, COPPER_ABBR)
else
return format("|cff%s%d|r|cff%s%s|r", color, copper, COLOR_COPPER, COPPER_ABBR)
end
else
if value == inf or value == -inf then
return format("%s", value)
elseif value ~= value then
return format("0%s", COPPER_ABBR)
elseif value >= 10000 or value <= -10000 then
return format("%d%s %d%s %d%s", gold, GOLD_ABBR, silver, SILVER_ABBR, copper, COPPER_ABBR)
elseif value >= 100 or value <= -100 then
return format("%d%s %d%s", silver, SILVER_ABBR, copper, COPPER_ABBR)
else
return format("%d%s", copper, COPPER_ABBR)
end
end
end
function lib:FormatMoneyShort(copper, colorize, textColor)
argCheck(copper, 2, "number")
local color = COLOR_WHITE
if textColor then
if copper > 0 then
color = COLOR_GREEN
elseif copper < 0 then
color = COLOR_RED
end
end
if colorize then
if value == inf or value == -inf then
return format("|cff%s%s|r", color, value)
elseif value ~= value then
return format("|cff%s0|r|cff%s%s|r", COLOR_WHITE, COLOR_COPPER, COPPER_ABBR)
elseif copper >= 10000 or copper <= -10000 then
return format("|cff%s%.1f|r|cff%s%s|r", color, copper / 10000, COLOR_GOLD, GOLD_ABBR)
elseif copper >= 100 or copper <= -100 then
return format("|cff%s%.1f|r|cff%s%s|r", color, copper / 100, COLOR_SILVER, SILVER_ABBR)
else
return format("|cff%s%d|r|cff%s%s|r", color, copper, COLOR_COPPER, COPPER_ABBR)
end
else
if value == inf or value == -inf then
return format("%s", value)
elseif value ~= value then
return format("0%s", COPPER_ABBR)
elseif copper >= 10000 or copper <= -10000 then
return format("%.1f%s", copper / 10000, GOLD_ABBR)
elseif copper >= 100 or copper <= -100 then
return format("%.1f%s", copper / 100, SILVER_ABBR)
else
return format("%.0f%s", copper, COPPER_ABBR)
end
end
end
function lib:FormatMoneyCondensed(value, colorize, textColor)
argCheck(value, 2, "number")
local negl = value < 0 and "(-" or ""
local negr = value < 0 and ")" or ""
if value < 0 then
if colorize and textColor then
negl = "|cffff0000-(|r"
negr = "|cffff0000)|r"
else
negl = "-("
negr = ")"
end
else
negl = ""
negr = ""
end
local gold = floor(math.abs(value) / 10000)
local silver = mod(floor(math.abs(value) / 100), 100)
local copper = mod(floor(math.abs(value)), 100)
if colorize then
if value == inf or value == -inf then
return format("%s|cff%s%s|r%s", negl, COLOR_COPPER, math.abs(value), negr)
elseif value ~= value then
return format("|cff%s0|r", COLOR_COPPER)
elseif gold ~= 0 then
return format("%s|cff%s%d|r.|cff%s%02d|r.|cff%s%02d|r%s", negl, COLOR_GOLD, gold, COLOR_SILVER, silver, COLOR_COPPER, copper, negr)
elseif silver ~= 0 then
return format("%s|cff%s%d|r.|cff%s%02d|r%s", negl, COLOR_SILVER, silver, COLOR_COPPER, copper, negr)
else
return format("%s|cff%s%d|r%s", negl, COLOR_COPPER, copper, negr)
end
else
if value == inf or value == -inf then
return tostring(value)
elseif value ~= value then
return "0"
elseif gold ~= 0 then
return format("%s%d.%02d.%02d%s", negl, gold, silver, copper, negr)
elseif silver ~= 0 then
return format("%s%d.%02d%s", negl, silver, copper, negr)
else
return format("%s%d%s", negl, copper, negr)
end
end
end
local t
function lib:FormatDurationExtended(duration, colorize, hideSeconds)
argCheck(duration, 2, "number")
local negative = ""
if duration ~= duration then
duration = 0
end
if duration < 0 then
negative = "-"
duration = -duration
end
local days = floor(duration / 86400)
local hours = mod(floor(duration / 3600), 24)
local mins = mod(floor(duration / 60), 60)
local secs = mod(floor(duration), 60)
if not t then
t = {}
else
for k in pairs(t) do
t[k] = nil
end
table.setn(t, 0)
end
if not colorize then
if duration == nil or duration > 86400*365 then
return "Undetermined"
end
if days > 1 then
table.insert(t, format("%d %s", days, DAYS_ABBR_P1))
elseif days == 1 then
table.insert(t, format("%d %s", days, DAYS_ABBR))
end
if hours > 1 then
table.insert(t, format("%d %s", hours, HOURS_ABBR_P1))
elseif hours == 1 then
table.insert(t, format("%d %s", hours, HOURS_ABBR))
end
if mins > 1 then
table.insert(t, format("%d %s", mins, MINUTES_ABBR_P1))
elseif mins == 1 then
table.insert(t, format("%d %s", mins, MINUTES_ABBR))
end
if not hideSeconds then
if secs > 1 then
table.insert(t, format("%d %s", secs, SECONDS_ABBR_P1))
elseif secs == 1 then
table.insert(t, format("%d %s", secs, SECONDS_ABBR))
end
end
if table.getn(t) == 0 then
if not hideSeconds then
return "0 " .. SECONDS_ABBR_P1
else
return "0 " .. MINUTES_ABBR_P1
end
else
return negative .. table.concat(t, " ")
end
else
if duration == nil or duration > 86400*365 then
return "|cffffffffUndetermined|r"
end
if days > 1 then
table.insert(t, format("|cffffffff%d|r %s", days, DAYS_ABBR_P1))
elseif days == 1 then
table.insert(t, format("|cffffffff%d|r %s", days, DAYS_ABBR))
end
if hours > 1 then
table.insert(t, format("|cffffffff%d|r %s", hours, HOURS_ABBR_P1))
elseif hours == 1 then
table.insert(t, format("|cffffffff%d|r %s", hours, HOURS_ABBR))
end
if mins > 1 then
table.insert(t, format("|cffffffff%d|r %s", mins, MINUTES_ABBR_P1))
elseif mins == 1 then
table.insert(t, format("|cffffffff%d|r %s", mins, MINUTES_ABBR))
end
if not hideSeconds then
if secs > 1 then
table.insert(t, format("|cffffffff%d|r %s", secs, SECONDS_ABBR_P1))
elseif secs == 1 then
table.insert(t, format("|cffffffff%d|r %s", secs, SECONDS_ABBR))
end
end
if table.getn(t) == 0 then
if not hideSeconds then
return "|cffffffff0|r " .. SECONDS_ABBR_P1
else
return "|cffffffff0|r " .. MINUTES_ABBR_P1
end
elseif negative == "-" then
return "|cffffffff-|r" .. table.concat(t, " ")
else
return table.concat(t, " ")
end
end
end
local DAY_ONELETTER_ABBR = string.gsub(DAY_ONELETTER_ABBR, "%s*%%d%s*", "")
local HOUR_ONELETTER_ABBR = string.gsub(HOUR_ONELETTER_ABBR, "%s*%%d%s*", "")
local MINUTE_ONELETTER_ABBR = string.gsub(MINUTE_ONELETTER_ABBR, "%s*%%d%s*", "")
local SECOND_ONELETTER_ABBR = string.gsub(SECOND_ONELETTER_ABBR, "%s*%%d%s*", "")
function lib:FormatDurationFull(duration, colorize, hideSeconds)
argCheck(duration, 2, "number")
local negative = ""
if duration ~= duration then
duration = 0
end
if duration < 0 then
negative = "-"
duration = -duration
end
if not colorize then
if not hideSeconds then
if duration == nil or duration > 86400*365 then
return "Undetermined"
elseif duration >= 86400 then
return format("%s%d%s %02d%s %02d%s %02d%s", negative, duration/86400, DAY_ONELETTER_ABBR, mod(duration/3600, 24), HOUR_ONELETTER_ABBR, mod(duration/60, 60), MINUTE_ONELETTER_ABBR, mod(duration, 60), SECOND_ONELETTER_ABBR)
elseif duration >= 3600 then
return format("%s%d%s %02d%s %02d%s", negative, duration/3600, HOUR_ONELETTER_ABBR, mod(duration/60, 60), MINUTE_ONELETTER_ABBR, mod(duration, 60), SECOND_ONELETTER_ABBR)
elseif duration >= 120 then
return format("%s%d%s %02d%s", negative, duration/60, MINUTE_ONELETTER_ABBR, mod(duration, 60), SECOND_ONELETTER_ABBR)
else
return format("%s%d%s", negative, duration, SECOND_ONELETTER_ABBR)
end
else
if duration == nil or duration > 86400*365 then
return "Undetermined"
elseif duration >= 86400 then
return format("%s%d%s %02d%s %02d%s", negative, duration/86400, DAY_ONELETTER_ABBR, mod(duration/3600, 24), HOUR_ONELETTER_ABBR, mod(duration/60, 60), MINUTE_ONELETTER_ABBR)
elseif duration >= 3600 then
return format("%s%d%s %02d%s", negative, duration/3600, HOUR_ONELETTER_ABBR, mod(duration/60, 60), MINUTE_ONELETTER_ABBR)
else
return format("%s%d%s", negative, duration/60, MINUTE_ONELETTER_ABBR)
end
end
else
if not hideSeconds then
if duration == nil or duration > 86400*365 then
return "|cffffffffUndetermined|r"
elseif duration >= 86400 then
return format("|cffffffff%s%d|r%s |cffffffff%02d|r%s |cffffffff%02d|r%s |cffffffff%02d|r%s", negative, duration/86400, DAY_ONELETTER_ABBR, mod(duration/3600, 24), HOUR_ONELETTER_ABBR, mod(duration/60, 60), MINUTE_ONELETTER_ABBR, mod(duration, 60), SECOND_ONELETTER_ABBR)
elseif duration >= 3600 then
return format("|cffffffff%s%d|r%s |cffffffff%02d|r%s |cffffffff%02d|r%s", negative, duration/3600, HOUR_ONELETTER_ABBR, mod(duration/60, 60), MINUTE_ONELETTER_ABBR, mod(duration, 60), SECOND_ONELETTER_ABBR)
elseif duration >= 120 then
return format("|cffffffff%s%d|r%s |cffffffff%02d|r%s", negative, duration/60, MINUTE_ONELETTER_ABBR, mod(duration, 60), SECOND_ONELETTER_ABBR)
else
return format("|cffffffff%s%d|r%s", negative, duration, SECOND_ONELETTER_ABBR)
end
else
if duration == nil or duration > 86400*365 then
return "|cffffffffUndetermined|r"
elseif duration >= 86400 then
return format("|cffffffff%s%d|r%s |cffffffff%02d|r%s |cffffffff%02d|r%s", negative, duration/86400, DAY_ONELETTER_ABBR, mod(duration/3600, 24), HOUR_ONELETTER_ABBR, mod(duration/60, 60), MINUTE_ONELETTER_ABBR)
elseif duration >= 3600 then
return format("|cffffffff%s%d|r%s |cffffffff%02d|r%s", negative, duration/3600, HOUR_ONELETTER_ABBR, mod(duration/60, 60), MINUTE_ONELETTER_ABBR)
else
return format("|cffffffff%s%d|r%s", negative, duration/60, MINUTE_ONELETTER_ABBR)
end
end
end
end
function lib:FormatDurationShort(duration, colorize, hideSeconds)
argCheck(duration, 2, "number")
local negative = ""
if duration ~= duration then
duration = 0
end
if duration < 0 then
negative = "-"
duration = -duration
end
if not colorize then
if duration == nil or duration >= 86400*365 then
return "***"
elseif duration >= 172800 then
return format("%s%.1f %s", negative, duration/86400, DAYS_ABBR_P1)
elseif duration >= 7200 then
return format("%s%.1f %s", negative, duration/3600, HOURS_ABBR_P1)
elseif duration >= 120 or not hideSeconds then
return format("%s%.1f %s", negative, duration/60, MINUTES_ABBR_P1)
else
return format("%s%.0f %s", negative, duration, SECONDS_ABBR_P1)
end
else
if duration == nil or duration >= 86400*365 then
return "|cffffffff***|r"
elseif duration >= 172800 then
return format("|cffffffff%s%.1f|r %s", negative, duration/86400, DAYS_ABBR_P1)
elseif duration >= 7200 then
return format("|cffffffff%s%.1f|r %s", negative, duration/3600, HOURS_ABBR_P1)
elseif duration >= 120 or not hideSeconds then
return format("|cffffffff%s%.1f|r %s", negative, duration/60, MINUTES_ABBR_P1)
else
return format("|cffffffff%s%.0f|r %s", negative, duration, SECONDS_ABBR_P1)
end
end
end
function lib:FormatDurationCondensed(duration, colorize, hideSeconds)
argCheck(duration, 2, "number")
local negative = ""
if duration ~= duration then
duration = 0
end
if duration < 0 then
negative = "-"
duration = -duration
end
if not colorize then
if hideSeconds then
if duration == nil or duration >= 86400*365 then
return format("%s**%s **:**", negative, DAY_ONELETTER_ABBR)
elseif duration >= 86400 then
return format("%s%d%s %d:%02d", negative, duration/86400, DAY_ONELETTER_ABBR, mod(duration/3600, 24), mod(duration/60, 60))
else
return format("%s%d:%02d", negative, duration/3600, mod(duration/60, 60))
end
else
if duration == nil or duration >= 86400*365 then
return negative .. "**:**:**:**"
elseif duration >= 86400 then
return format("%s%d%s %d:%02d:%02d", negative, duration/86400, DAY_ONELETTER_ABBR, mod(duration/3600, 24), mod(duration/60, 60), mod(duration, 60))
elseif duration >= 3600 then
return format("%s%d:%02d:%02d", negative, duration/3600, mod(duration/60, 60), mod(duration, 60))
else
return format("%s%d:%02d", negative, duration/60, mod(duration, 60))
end
end
else
if hideSeconds then
if duration == nil or duration >= 86400*365 then
return format("|cffffffff%s**|r%s |cffffffff**|r:|cffffffff**|r", negative, DAY_ONELETTER_ABBR)
elseif duration >= 86400 then
return format("|cffffffff%s%d|r%s |cffffffff%d|r:|cffffffff%02d|r", negative, duration/86400, DAY_ONELETTER_ABBR, mod(duration/3600, 24), mod(duration/60, 60))
else
return format("|cffffffff%s%d|r:|cffffffff%02d|r", negative, duration/3600, mod(duration/60, 60))
end
else
if duration == nil or duration >= 86400*365 then
return format("|cffffffff%s**|r%s |cffffffff**|r:|cffffffff**|r:|cffffffff**|r", negative, DAY_ONELETTER_ABBR)
elseif duration >= 86400 then
return format("|cffffffff%s%d|r%s |cffffffff%d|r:|cffffffff%02d|r:|cffffffff%02d|r", negative, duration/86400, DAY_ONELETTER_ABBR, mod(duration/3600, 24), mod(duration/60, 60), mod(duration, 60))
elseif duration >= 3600 then
return format("|cffffffff%s%d|r:|cffffffff%02d|r:|cffffffff%02d|r", negative, duration/3600, mod(duration/60, 60), mod(duration, 60))
else
return format("|cffffffff%s%d|r:|cffffffff%02d|r", negative, duration/60, mod(duration, 60))
end
end
end
end
function lib:GetLibraryVersion()
return MAJOR_VERSION, MINOR_VERSION
end
function lib:LibActivate(stub, oldLib, oldList)
end
function lib:LibDeactivate(stub)
end
AbacusLib:Register(lib)
lib = nil