Mercurial > wow > reaction
view libs/AceDebug-2.0/AceDebug-2.0.lua @ 1:c11ca1d8ed91
Version 0.1
author | Flick <flickerstreak@gmail.com> |
---|---|
date | Tue, 20 Mar 2007 21:03:57 +0000 |
parents | |
children |
line wrap: on
line source
--[[ Name: AceDebug-2.0 Revision: $Rev: 18708 $ Developed by: The Ace Development Team (http://www.wowace.com/index.php/The_Ace_Development_Team) Inspired By: Ace 1.x by Turan (turan@gryphon.com) Website: http://www.wowace.com/ Documentation: http://www.wowace.com/index.php/AceDebug-2.0 SVN: http://svn.wowace.com/root/trunk/Ace2/AceDebug-2.0 Description: Mixin to allow for simple debugging capabilities. Dependencies: AceLibrary, AceOO-2.0 ]] local MAJOR_VERSION = "AceDebug-2.0" local MINOR_VERSION = "$Revision: 18708 $" if not AceLibrary then error(MAJOR_VERSION .. " requires AceLibrary") end if not AceLibrary:IsNewVersion(MAJOR_VERSION, MINOR_VERSION) then return end if not AceLibrary:HasInstance("AceOO-2.0") then error(MAJOR_VERSION .. " requires AceOO-2.0") end if GetLocale() == "frFR" then DEBUGGING = "D\195\169boguage" TOGGLE_DEBUGGING = "Activer/d\195\169sactiver le d\195\169boguage" elseif GetLocale() == "deDE" then DEBUGGING = "Debuggen" TOGGLE_DEBUGGING = "Aktiviert/Deaktiviert Debugging" elseif GetLocale() == "koKR" then DEBUGGING = "디버깅" TOGGLE_DEBUGGING = "디버깅 기능 사용함/사용안함" elseif GetLocale() == "zhTW" then DEBUGGING = "除錯" TOGGLE_DEBUGGING = "啟用/停用除錯功能" elseif GetLocale() == "zhCN" then DEBUGGING = "\232\176\131\232\175\149" TOGGLE_DEBUGGING = "\229\144\175\231\148\168/\231\166\129\231\148\168 \232\176\131\232\175\149" else -- enUS DEBUGGING = "Debugging" TOGGLE_DEBUGGING = "Enable/disable debugging" end local AceOO = AceLibrary:GetInstance("AceOO-2.0") local AceDebug = AceOO.Mixin {"Debug", "CustomDebug", "IsDebugging", "SetDebugging", "SetDebugLevel", "LevelDebug", "CustomLevelDebug", "GetDebugLevel"} local function print(text, r, g, b, frame, delay) (frame or DEFAULT_CHAT_FRAME):AddMessage(text, r, g, b, 1, delay or 5) end local tmp = {} function AceDebug:CustomDebug(r, g, b, frame, delay, a1, ...) if not self.debugging then return end local output = string.format("|cff7fff7f(DEBUG) %s:[%s.%3d]|r", tostring(self), date("%H:%M:%S"), math.fmod(GetTime(), 1) * 1000) a1 = tostring(a1) if string.find(a1, "%%") and select('#', ...) >= 1 then for i = 1, select('#', ...) do tmp[i] = tostring((select(i, ...))) end output = output .. " " .. string.format(a1, unpack(tmp)) for i = 1, select('#', ...) do tmp[i] = nil end else -- This block dynamically rebuilds the tmp array stopping on the first nil. tmp[1] = output tmp[2] = a1 for i = 1, select('#', ...) do tmp[i+2] = tostring((select(i, ...))) end output = table.concat(tmp, " ") for i = 1, select('#', ...) + 2 do tmp[i] = nil end end print(output, r, g, b, frame or self.debugFrame, delay) end function AceDebug:Debug(...) AceDebug.CustomDebug(self, nil, nil, nil, nil, nil, ...) end function AceDebug:IsDebugging() return self.debugging end function AceDebug:SetDebugging(debugging) self.debugging = debugging end -- Takes a number 1-3 -- Level 1: Critical messages that every user should receive -- Level 2: Should be used for local debugging (function calls, etc) -- Level 3: Very verbose debugging, will dump everything and anything -- If set to nil, you will receive no debug information function AceDebug:SetDebugLevel(level) AceDebug:argCheck(level, 1, "number", "nil") if not level then self.debuglevel = nil return end if level < 1 or level > 3 then AceDebug:error("Bad argument #1 to `SetDebugLevel`, must be a number 1-3") end self.debuglevel = level end function AceDebug:GetDebugLevel() return self.debuglevel end function AceDebug:CustomLevelDebug(level, r, g, b, frame, delay, ...) if not self.debugging or not self.debuglevel then return end AceDebug:argCheck(level, 1, "number") if level < 1 or level > 3 then AceDebug:error("Bad argument #1 to `LevelDebug`, must be a number 1-3") end if level > self.debuglevel then return end local output = string.format("|cff7fff7f(DEBUG) %s:[%s.%3d]|r", tostring(self), date("%H:%M:%S"), math.fmod(GetTime(), 1) * 1000) a1 = tostring(a1) if string.find(a1, "%%") and select('#', ...) >= 2 then for i = 1, select('#', ...) do tmp[i] = tostring((select(i, ...))) end output = output .. " " .. string.format(a1, unpack(tmp)) for i = 1, select('#', ...) do tmp[i] = nil end else -- This block dynamically rebuilds the tmp array stopping on the first nil. tmp[1] = output tmp[2] = a1 for i = 1, select('#', ...) do tmp[i+2] = tostring((select(i, ...))) end output = table.concat(tmp, " ") for i = 1, select('#', ...) + 2 do tmp[i] = nil end end print(output, r, g, b, frame or self.debugFrame, delay) end function AceDebug:LevelDebug(level, ...) if not self.debugging or not self.debuglevel then return end AceDebug:argCheck(level, 1, "number") if level < 1 or level > 3 then AceDebug:error("Bad argument #1 to `LevelDebug`, must be a number 1-3") end if level > self.debuglevel then return end AceDebug.CustomLevelDebug(self, level, nil, nil, nil, nil, nil, ...) end local options function AceDebug:GetAceOptionsDataTable(target) if not options then options = { debug = { name = DEBUGGING, desc = TOGGLE_DEBUGGING, type = "toggle", get = "IsDebugging", set = "SetDebugging", order = -2, } } end return options end AceLibrary:Register(AceDebug, MAJOR_VERSION, MINOR_VERSION, AceDebug.activate) AceDebug = AceLibrary(MAJOR_VERSION)