2022-01-04 23:15:17 +08:00
|
|
|
--=============================================================================
|
|
|
|
-- logger.lua --- logger implemented in lua
|
2023-03-26 13:50:22 +08:00
|
|
|
-- Copyright (c) 2016-2023 Wang Shidong & Contributors
|
2022-01-04 23:15:17 +08:00
|
|
|
-- Author: Wang Shidong < wsdjeg@outlook.com >
|
|
|
|
-- URL: https://spacevim.org
|
|
|
|
-- License: GPLv3
|
|
|
|
--=============================================================================
|
|
|
|
|
2021-08-14 20:51:00 +08:00
|
|
|
local M = {}
|
|
|
|
|
|
|
|
local logger = require('spacevim.api').import('logger')
|
|
|
|
local cmd = require('spacevim').cmd
|
2021-08-15 19:06:48 +08:00
|
|
|
local call = require('spacevim').call
|
2021-08-29 16:37:19 +08:00
|
|
|
local echo = require('spacevim').echo
|
2021-08-14 20:51:00 +08:00
|
|
|
local fn = nil
|
|
|
|
if vim.fn == nil then
|
2023-04-03 12:46:38 +08:00
|
|
|
fn = require('spacevim').fn
|
2021-08-14 20:51:00 +08:00
|
|
|
else
|
2023-04-03 12:46:38 +08:00
|
|
|
fn = vim.fn
|
2021-08-14 20:51:00 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
logger.set_name('SpaceVim')
|
|
|
|
logger.set_level(1)
|
|
|
|
logger.set_silent(1)
|
|
|
|
logger.set_verbose(1)
|
|
|
|
|
|
|
|
function M.info(msg)
|
2023-04-03 12:46:38 +08:00
|
|
|
logger.info(msg)
|
2021-08-14 20:51:00 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
function M.warn(msg, ...)
|
2023-04-03 12:46:38 +08:00
|
|
|
logger.warn(msg, ...)
|
2021-08-14 20:51:00 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
function M.error(msg)
|
2023-04-03 12:46:38 +08:00
|
|
|
logger.error(msg)
|
2021-08-14 20:51:00 +08:00
|
|
|
end
|
|
|
|
|
2021-08-15 19:06:48 +08:00
|
|
|
function M.debug(msg)
|
2023-04-03 12:46:38 +08:00
|
|
|
logger.debug(msg)
|
2021-08-15 19:06:48 +08:00
|
|
|
end
|
|
|
|
|
2021-08-14 20:51:00 +08:00
|
|
|
function M.setLevel(level)
|
2023-04-03 12:46:38 +08:00
|
|
|
logger.set_level(level)
|
2021-08-14 20:51:00 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
function M.setOutput(file)
|
2023-04-03 12:46:38 +08:00
|
|
|
logger.set_file(file)
|
2021-08-14 20:51:00 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
function M.viewRuntimeLog()
|
2023-09-16 15:21:40 +08:00
|
|
|
-- this function should be more faster, and view runtime log without filter
|
|
|
|
local info = '### SpaceVim runtime log :\n\n' .. logger.view_all()
|
2023-04-03 12:46:38 +08:00
|
|
|
cmd('tabnew')
|
|
|
|
cmd('setl nobuflisted')
|
|
|
|
cmd('nnoremap <buffer><silent> q :tabclose!<CR>')
|
|
|
|
-- put info into buffer
|
|
|
|
fn.append(0, fn.split(info, '\n'))
|
|
|
|
cmd('setl nomodifiable')
|
|
|
|
cmd('setl buftype=nofile')
|
|
|
|
cmd('setl filetype=SpaceVimLog')
|
|
|
|
-- M.syntax_extra()
|
2021-08-15 19:06:48 +08:00
|
|
|
end
|
|
|
|
|
2021-08-29 16:37:19 +08:00
|
|
|
function M.viewLog(...)
|
2023-04-03 12:46:38 +08:00
|
|
|
local argvs = { ... }
|
|
|
|
local info = '<details><summary> SpaceVim debug information </summary>\n\n'
|
|
|
|
.. '### SpaceVim options :\n\n'
|
|
|
|
.. '```toml\n'
|
|
|
|
.. fn.join(call('SpaceVim#options#list'), '\n')
|
|
|
|
.. '\n```\n'
|
|
|
|
.. '\n\n'
|
|
|
|
.. '### SpaceVim layers :\n\n'
|
2021-08-15 19:06:48 +08:00
|
|
|
.. call('SpaceVim#layers#report')
|
2023-04-03 12:46:38 +08:00
|
|
|
.. '\n\n'
|
|
|
|
.. '### SpaceVim Health checking :\n\n'
|
2021-08-15 19:06:48 +08:00
|
|
|
.. call('SpaceVim#health#report')
|
2023-04-03 12:46:38 +08:00
|
|
|
.. '\n\n'
|
|
|
|
.. '### SpaceVim runtime log :\n\n'
|
|
|
|
.. '```log\n'
|
2021-08-15 19:06:48 +08:00
|
|
|
.. logger.view(logger.level)
|
2023-04-03 12:46:38 +08:00
|
|
|
.. '\n```\n</details>\n\n'
|
|
|
|
if argvs ~= nil and #argvs >= 1 then
|
|
|
|
local bang = argvs[1]
|
|
|
|
if bang == 1 then
|
|
|
|
cmd('tabnew')
|
|
|
|
cmd('setl nobuflisted')
|
|
|
|
cmd('nnoremap <buffer><silent> q :tabclose!<CR>')
|
|
|
|
-- put info into buffer
|
|
|
|
fn.append(0, fn.split(info, '\n'))
|
|
|
|
cmd('setl nomodifiable')
|
|
|
|
cmd('setl buftype=nofile')
|
|
|
|
cmd('setl filetype=markdown')
|
2021-08-29 16:37:19 +08:00
|
|
|
else
|
2023-04-03 12:46:38 +08:00
|
|
|
echo(info)
|
2021-08-15 19:06:48 +08:00
|
|
|
end
|
2023-04-03 12:46:38 +08:00
|
|
|
else
|
|
|
|
return info
|
|
|
|
end
|
2021-08-14 20:51:00 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
function M.syntax_extra()
|
2023-04-03 12:46:38 +08:00
|
|
|
fn.matchadd('ErrorMsg', '.*[\\sError\\s\\].*')
|
|
|
|
fn.matchadd('WarningMsg', '.*[\\sWarn\\s\\].*')
|
2021-08-14 20:51:00 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
function M.derive(name)
|
2023-04-03 12:46:38 +08:00
|
|
|
local derive = {
|
|
|
|
origin_name = logger.get_name(),
|
2023-04-24 23:36:18 +08:00
|
|
|
_debug_mode = true,
|
2023-04-03 12:46:38 +08:00
|
|
|
derive_name = fn.printf('%' .. fn.strdisplaywidth(logger.get_name()) .. 'S', name),
|
|
|
|
}
|
|
|
|
|
|
|
|
function derive.info(msg)
|
|
|
|
logger.set_name(derive.derive_name)
|
|
|
|
logger.info(msg)
|
|
|
|
logger.set_name(derive.origin_name)
|
|
|
|
end
|
|
|
|
function derive.warn(msg)
|
|
|
|
logger.set_name(derive.derive_name)
|
|
|
|
logger.warn(msg)
|
|
|
|
logger.set_name(derive.origin_name)
|
|
|
|
end
|
|
|
|
function derive.error(msg)
|
|
|
|
logger.set_name(derive.derive_name)
|
|
|
|
logger.error(msg)
|
|
|
|
logger.set_name(derive.origin_name)
|
|
|
|
end
|
|
|
|
|
|
|
|
function derive.debug(msg)
|
|
|
|
if derive._debug_mode then
|
|
|
|
logger.set_name(derive.derive_name)
|
|
|
|
logger.debug(msg)
|
|
|
|
logger.set_name(derive.origin_name)
|
2021-08-15 19:06:48 +08:00
|
|
|
end
|
2023-04-03 12:46:38 +08:00
|
|
|
end
|
|
|
|
function derive.start_debug()
|
|
|
|
derive._debug_mode = true
|
|
|
|
end
|
|
|
|
function derive.stop_debug()
|
|
|
|
derive._debug_mode = false
|
|
|
|
end
|
2023-04-03 12:52:27 +08:00
|
|
|
function derive.debug_enabled() -- {{{
|
2023-04-03 12:46:38 +08:00
|
|
|
return derive._debug_mode
|
|
|
|
end
|
|
|
|
-- }}}
|
|
|
|
return derive
|
2021-08-14 20:51:00 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
return M
|