|
@@ -1,60 +1,59 @@
|
|
|
local Log = {}
|
|
|
|
|
|
---- Creates a log handle based on Plenary.log
|
|
|
----@param opts these are passed verbatim to Plenary.log
|
|
|
----@return log handle
|
|
|
-function Log:new(opts)
|
|
|
- local status_ok, handle = pcall(require, "plenary.log")
|
|
|
- if not status_ok then
|
|
|
- vim.notify("Plenary.log is not available. Logging to console only", vim.log.levels.DEBUG)
|
|
|
- end
|
|
|
-
|
|
|
- self.__handle = handle
|
|
|
-
|
|
|
- local path = string.format("%s/%s.log", vim.api.nvim_call_function("stdpath", { "cache" }), opts.plugin)
|
|
|
-
|
|
|
- self.get_path = function()
|
|
|
- return path
|
|
|
- end
|
|
|
-
|
|
|
- setmetatable({}, Log)
|
|
|
- return self
|
|
|
-end
|
|
|
-
|
|
|
+--- Adds a log entry using Plenary.log
|
|
|
+---@param msg any
|
|
|
+---@param level string [same as vim.log.log_levels]
|
|
|
function Log:add_entry(msg, level)
|
|
|
- local status_ok, _ = pcall(require, "plenary.log")
|
|
|
- if not status_ok then
|
|
|
- return vim.notify(msg, vim.log.levels[level])
|
|
|
+ assert(type(level) == "string")
|
|
|
+ if self.__handle then
|
|
|
+ -- plenary uses lower-case log levels
|
|
|
+ self.__handle[level:lower()](msg)
|
|
|
+ end
|
|
|
+ local status_ok, plenary = pcall(require, "plenary")
|
|
|
+ if status_ok then
|
|
|
+ local default_opts = { plugin = "lunarvim", level = lvim.log.level }
|
|
|
+ local handle = plenary.log.new(default_opts)
|
|
|
+ handle[level:lower()](msg)
|
|
|
+ self.__handle = handle
|
|
|
end
|
|
|
- -- plenary uses lower-case log levels
|
|
|
- return self.__handle[level:lower()](msg)
|
|
|
+ -- don't do anything if plenary is not available
|
|
|
end
|
|
|
|
|
|
---- Creates or retrieves a log handle for the default logfile
|
|
|
---- based on Plenary.log
|
|
|
----@return log handle
|
|
|
-function Log:new_default()
|
|
|
- return Log:new { plugin = "lunarvim", level = lvim.log.level }
|
|
|
+---Retrieves the path of the logfile
|
|
|
+---@return string path of the logfile
|
|
|
+function Log:get_path()
|
|
|
+ return string.format("%s/%s.log", vim.fn.stdpath "cache", "lunarvim")
|
|
|
end
|
|
|
|
|
|
+---Add a log entry at TRACE level
|
|
|
+---@param msg any
|
|
|
function Log:trace(msg)
|
|
|
self:add_entry(msg, "TRACE")
|
|
|
end
|
|
|
|
|
|
+---Add a log entry at DEBUG level
|
|
|
+---@param msg any
|
|
|
function Log:debug(msg)
|
|
|
self:add_entry(msg, "DEBUG")
|
|
|
end
|
|
|
|
|
|
+---Add a log entry at INFO level
|
|
|
+---@param msg any
|
|
|
function Log:info(msg)
|
|
|
self:add_entry(msg, "INFO")
|
|
|
end
|
|
|
|
|
|
+---Add a log entry at WARN level
|
|
|
+---@param msg any
|
|
|
function Log:warn(msg)
|
|
|
- self:add_entry(msg, "TRACE")
|
|
|
+ self:add_entry(msg, "WARN")
|
|
|
end
|
|
|
|
|
|
+---Add a log entry at ERROR level
|
|
|
+---@param msg any
|
|
|
function Log:error(msg)
|
|
|
- self:add_entry(msg, "TRACE")
|
|
|
+ self:add_entry(msg, "ERROR")
|
|
|
end
|
|
|
|
|
|
+setmetatable({}, Log)
|
|
|
return Log
|