mirror of
https://github.com/rojo-rbx/rojo.git
synced 2026-04-20 20:55:50 +00:00
56 lines
1.1 KiB
Lua
56 lines
1.1 KiB
Lua
local Fmt = require(script.Parent.Fmt)
|
|
|
|
local Level = {
|
|
Error = 0,
|
|
Warning = 1,
|
|
Info = 2,
|
|
Debug = 3,
|
|
Trace = 4,
|
|
}
|
|
|
|
local function getLogLevel()
|
|
return Level.Info
|
|
end
|
|
|
|
local function addTags(tag, message)
|
|
return tag .. message:gsub("\n", "\n" .. tag)
|
|
end
|
|
|
|
local TRACE_TAG = (" "):rep(15) .. "[Rojo-Trace] "
|
|
local INFO_TAG = (" "):rep(15) .. "[Rojo-Info] "
|
|
local DEBUG_TAG = (" "):rep(15) .. "[Rojo-Debug] "
|
|
local WARN_TAG = "[Rojo-Warn] "
|
|
|
|
local Log = {}
|
|
|
|
Log.Level = Level
|
|
|
|
function Log.setLogLevelThunk(thunk)
|
|
getLogLevel = thunk
|
|
end
|
|
|
|
function Log.trace(template, ...)
|
|
if getLogLevel() >= Level.Trace then
|
|
print(addTags(TRACE_TAG, Fmt.fmt(template, ...)))
|
|
end
|
|
end
|
|
|
|
function Log.info(template, ...)
|
|
if getLogLevel() >= Level.Info then
|
|
print(addTags(INFO_TAG, Fmt.fmt(template, ...)))
|
|
end
|
|
end
|
|
|
|
function Log.debug(template, ...)
|
|
if getLogLevel() >= Level.Debug then
|
|
print(addTags(DEBUG_TAG, Fmt.fmt(template, ...)))
|
|
end
|
|
end
|
|
|
|
function Log.warn(template, ...)
|
|
if getLogLevel() >= Level.Warning then
|
|
warn(addTags(WARN_TAG, Fmt.fmt(template, ...)))
|
|
end
|
|
end
|
|
|
|
return Log |