mirror of
https://github.com/SpaceVim/SpaceVim.git
synced 2025-04-02 09:50:30 +08:00
115 lines
2.8 KiB
VimL
115 lines
2.8 KiB
VimL
|
|
let s:self = {
|
|
\ 'name' : '',
|
|
\ 'silent' : 1,
|
|
\ 'level' : 1,
|
|
\ 'file' : '',
|
|
\ 'temp' : [],
|
|
\ }
|
|
|
|
"1 : log all messages
|
|
"2 : log warning and error messages
|
|
"3 : log error messages only
|
|
let s:levels = ['Info', 'Warn', 'Error']
|
|
|
|
function! SpaceVim#api#logger#get() abort
|
|
return deepcopy(s:self)
|
|
endfunction
|
|
|
|
function! s:self.set_level(l) abort
|
|
let self.level = a:l
|
|
endfunction
|
|
|
|
function! s:self.error(msg) abort
|
|
let time = strftime('%H:%M:%S')
|
|
let log = '[ ' . self.name . ' ] [' . time . '] [ ' . s:levels[2] . ' ] ' . a:msg
|
|
if !self.silent
|
|
echoerr log
|
|
endif
|
|
call self.write(log)
|
|
endfunction
|
|
|
|
function! s:self.write(msg) abort
|
|
if empty(self.file)
|
|
call add(self.temp, a:msg)
|
|
return
|
|
endif
|
|
if !isdirectory(fnamemodify(self.file, ':p:h'))
|
|
call mkdir(expand(fnamemodify(self.file, ':p:h')), 'p')
|
|
endif
|
|
let flags = filewritable(self.file) ? 'a' : ''
|
|
call writefile([a:msg], self.file, flags)
|
|
endfunction
|
|
|
|
function! s:self.warn(msg) abort
|
|
if self.level > 2
|
|
return
|
|
endif
|
|
let time = strftime('%H:%M:%S')
|
|
let log = '[ ' . self.name . ' ] [' . time . '] [ ' . s:levels[1] . ' ] ' . a:msg
|
|
if !self.silent
|
|
echohl WarningMsg
|
|
echom log
|
|
echohl None
|
|
endif
|
|
call self.write(log)
|
|
endfunction
|
|
|
|
function! s:self.info(msg) abort
|
|
if self.level > 1
|
|
return
|
|
endif
|
|
let time = strftime('%H:%M:%S')
|
|
let log = '[ ' . self.name . ' ] [' . time . '] [ ' . s:levels[0] . ' ] ' . a:msg
|
|
if !self.silent
|
|
echom log
|
|
endif
|
|
call self.write(log)
|
|
endfunction
|
|
|
|
function! s:self.set_name(name) abort
|
|
let self.name = a:name
|
|
endfunction
|
|
|
|
function! s:self.get_name() abort
|
|
return self.name
|
|
endfunction
|
|
|
|
function! s:self.set_file(file) abort
|
|
let self.file = a:file
|
|
endfunction
|
|
|
|
function! s:self.view(l) abort
|
|
let info = ''
|
|
if filereadable(self.file)
|
|
let logs = readfile(self.file, '')
|
|
let info .= join(filter(logs, 'self._comp(v:val, a:l)'), "\n")
|
|
else
|
|
let info .= '[ ' . self.name . ' ] : logger file ' . self.file
|
|
\ . ' does not exists, only log for current process will be shown!'
|
|
let info .= "\n"
|
|
let info .= join(filter(deepcopy(self.temp), 'self._comp(v:val, a:l)'), "\n")
|
|
endif
|
|
return info
|
|
endfunction
|
|
|
|
function! s:self._comp(msg, l) abort
|
|
if a:msg =~# '\[ ' . self.name . ' \] \[\d\d\:\d\d\:\d\d\] \[ '
|
|
\ . s:levels[2] . ' \]'
|
|
return 1
|
|
elseif a:msg =~# '\[ ' . self.name . ' \] \[\d\d\:\d\d\:\d\d\] \[ '
|
|
\ . s:levels[1] . ' \]'
|
|
if a:l > 2
|
|
return 0
|
|
else
|
|
return 1
|
|
endif
|
|
else
|
|
if a:l > 1
|
|
return 0
|
|
else
|
|
return 1
|
|
endif
|
|
endif
|
|
endfunction
|