mirror of
https://github.com/SpaceVim/SpaceVim.git
synced 2025-01-24 09:50:04 +08:00
99 lines
2.0 KiB
Lua
99 lines
2.0 KiB
Lua
local fn = nil
|
|
if vim.fn == nil then
|
|
fn = require('spacevim').fn
|
|
else
|
|
fn = vim.fn
|
|
end
|
|
|
|
local cmd = require('spacevim').cmd
|
|
|
|
local M = {
|
|
['name'] = '',
|
|
['silent'] = 1,
|
|
['level'] = 1,
|
|
['verbose'] = 1,
|
|
['file'] = '',
|
|
['temp'] = {},
|
|
}
|
|
|
|
local levels = {'Info', 'Warn', 'Error'}
|
|
|
|
function M.set_silent(sl)
|
|
M.silent = sl
|
|
end
|
|
|
|
function M.set_verbose(vb)
|
|
M.verbose = vb
|
|
end
|
|
|
|
function M.set_level(l)
|
|
M.level = l
|
|
end
|
|
|
|
function M.error(msg)
|
|
local time = fn.strftime('%H:%M:%S')
|
|
local log = '[ ' .. M.name .. ' ] [' .. time .. '] [ ' .. levels[1] .. ' ] ' .. msg
|
|
if M.silent == 0 and M.verbose >= 1 then
|
|
cmd('echohl Error')
|
|
cmd('echom "' .. log .. '"')
|
|
cmd('echohl None')
|
|
end
|
|
M.write(log)
|
|
end
|
|
|
|
function M.write(msg)
|
|
table.insert(M.temp, msg)
|
|
if M.file ~= '' then
|
|
if fn.isdirectory(fn.fnamemodify(M.file, ':p:h')) == 0 then
|
|
fn.mkdir(fn.expand(fn.fnamemodify(M.file, ':p:h')), 'p')
|
|
end
|
|
local flags = ''
|
|
if fn.filereadable(M.file) == 1 then
|
|
flags = 'a'
|
|
end
|
|
fn.writefile({msg}, M.file, flags)
|
|
end
|
|
|
|
end
|
|
|
|
function M.warn(msg, ...)
|
|
if M.level <= 2 then
|
|
local time = fn.strftime('%H:%M:%S')
|
|
local log = '[ ' .. M.name .. ' ] [' .. time .. '] [ ' .. levels[1] .. ' ] ' .. msg
|
|
if (M.silent == 0 and M.verbose >= 2) or select(1, ...) == 1 then
|
|
cmd('echohl WarningMsg')
|
|
cmd('echom "' .. log .. '"')
|
|
cmd('echohl None')
|
|
end
|
|
M.write(log)
|
|
end
|
|
|
|
end
|
|
|
|
function M.info(msg)
|
|
if M.level <= 1 then
|
|
local time = fn.strftime('%H:%M:%S')
|
|
local log = '[ ' .. M.name .. ' ] [' .. time .. '] [ ' .. levels[1] .. ' ] ' .. msg
|
|
if M.silent == 0 and M.verbose >= 3 then
|
|
cmd('echom "' .. log .. '"')
|
|
end
|
|
M.write(log)
|
|
end
|
|
end
|
|
|
|
function M.set_name(name)
|
|
M.name = name
|
|
end
|
|
|
|
function M.get_name()
|
|
return M.name
|
|
end
|
|
|
|
function M.set_file(file)
|
|
M.file = file
|
|
end
|
|
|
|
|
|
|
|
return M
|