diff options
Diffstat (limited to 'autoload/vimtex/qf/latexlog.vim')
-rw-r--r-- | autoload/vimtex/qf/latexlog.vim | 209 |
1 files changed, 209 insertions, 0 deletions
diff --git a/autoload/vimtex/qf/latexlog.vim b/autoload/vimtex/qf/latexlog.vim new file mode 100644 index 00000000..0046543e --- /dev/null +++ b/autoload/vimtex/qf/latexlog.vim @@ -0,0 +1,209 @@ +if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'latex') == -1 + +" vimtex - LaTeX plugin for Vim +" +" Maintainer: Karl Yngve LervÄg +" Email: karl.yngve@gmail.com +" + +function! vimtex#qf#latexlog#new() abort " {{{1 + return deepcopy(s:qf) +endfunction + +" }}}1 + + +let s:qf = { + \ 'name' : 'LaTeX logfile', + \} + +function! s:qf.init(state) abort dict "{{{1 + let self.config = get(g:, 'vimtex_quickfix_latexlog', {}) + let self.config.default = get(self.config, 'default', 1) + let self.config.packages = get(self.config, 'packages', {}) + let self.config.packages.default = get(self.config.packages, 'default', + \ self.config.default) + + let self.types = map( + \ filter(items(s:), 'v:val[0] =~# ''^type_'''), + \ 'v:val[1]') +endfunction + +" }}}1 +function! s:qf.set_errorformat() abort dict "{{{1 + " + " Note: The errorformat assumes we're using the -file-line-error with + " [pdf]latex. For more info, see |errorformat-LaTeX|. + " + + " Push file to file stack + setlocal errorformat=%-P**%f + setlocal errorformat+=%-P**\"%f\" + + " Match errors + setlocal errorformat+=%E!\ LaTeX\ %trror:\ %m + setlocal errorformat+=%E%f:%l:\ %m + setlocal errorformat+=%E!\ %m + + " More info for undefined control sequences + setlocal errorformat+=%Z<argument>\ %m + + " More info for some errors + setlocal errorformat+=%Cl.%l\ %m + + " + " Define general warnings + " + let l:default = self.config.default + if get(self.config, 'font', l:default) + setlocal errorformat+=%+WLaTeX\ Font\ Warning:\ %.%#line\ %l%.%# + setlocal errorformat+=%-CLaTeX\ Font\ Warning:\ %m + setlocal errorformat+=%-C(Font)%m + else + setlocal errorformat+=%-WLaTeX\ Font\ Warning:\ %m + endif + + if !get(self.config, 'references', l:default) + setlocal errorformat+=%-WLaTeX\ %.%#Warning:\ %.%#eference%.%#undefined%.%#line\ %l%.%# + setlocal errorformat+=%-WLaTeX\ %.%#Warning:\ %.%#undefined\ references. + endif + + if get(self.config, 'general', l:default) + setlocal errorformat+=%+WLaTeX\ %.%#Warning:\ %.%#line\ %l%.%# + setlocal errorformat+=%+WLaTeX\ %.%#Warning:\ %m + endif + + if get(self.config, 'overfull', l:default) + setlocal errorformat+=%+WOverfull\ %\\%\\hbox%.%#\ at\ lines\ %l--%*\\d + setlocal errorformat+=%+WOverfull\ %\\%\\hbox%.%#\ at\ line\ %l + setlocal errorformat+=%+WOverfull\ %\\%\\vbox%.%#\ at\ line\ %l + endif + + if get(self.config, 'underfull', l:default) + setlocal errorformat+=%+WUnderfull\ %\\%\\hbox%.%#\ at\ lines\ %l--%*\\d + setlocal errorformat+=%+WUnderfull\ %\\%\\vbox%.%#\ at\ line\ %l + endif + + " + " Define package related warnings + " + let l:default = self.config.packages.default + if get(self.config.packages, 'natbib', l:default) + setlocal errorformat+=%+WPackage\ natbib\ Warning:\ %m\ on\ input\ line\ %l. + else + setlocal errorformat+=%-WPackage\ natbib\ Warning:\ %m\ on\ input\ line\ %l. + endif + + if get(self.config.packages, 'biblatex', l:default) + setlocal errorformat+=%+WPackage\ biblatex\ Warning:\ %m + setlocal errorformat+=%-C(biblatex)%.%#in\ t%.%# + setlocal errorformat+=%-C(biblatex)%.%#Please\ v%.%# + setlocal errorformat+=%-C(biblatex)%.%#LaTeX\ a%.%# + setlocal errorformat+=%-C(biblatex)%m + else + setlocal errorformat+=%-WPackage\ biblatex\ Warning:\ %m + endif + + if get(self.config.packages, 'babel', l:default) + setlocal errorformat+=%+WPackage\ babel\ Warning:\ %m + setlocal errorformat+=%-Z(babel)%.%#input\ line\ %l. + setlocal errorformat+=%-C(babel)%m + else + setlocal errorformat+=%-WPackage\ babel\ Warning:\ %m + endif + + if get(self.config.packages, 'hyperref', l:default) + setlocal errorformat+=%+WPackage\ hyperref\ Warning:\ %m + setlocal errorformat+=%-C(hyperref)%m\ on\ input\ line\ %l. + setlocal errorformat+=%-C(hyperref)%m + else + setlocal errorformat+=%-WPackage\ hyperref\ Warning:\ %m + endif + + if get(self.config.packages, 'scrreprt', l:default) + setlocal errorformat+=%+WPackage\ scrreprt\ Warning:\ %m + setlocal errorformat+=%-C(scrreprt)%m + else + setlocal errorformat+=%-WPackage\ scrreprt\ Warning:\ %m + endif + + if get(self.config.packages, 'fixltx2e', l:default) + setlocal errorformat+=%+WPackage\ fixltx2e\ Warning:\ %m + setlocal errorformat+=%-C(fixltx2e)%m + else + setlocal errorformat+=%-WPackage\ fixltx2e\ Warning:\ %m + endif + + if get(self.config.packages, 'titlesec', l:default) + setlocal errorformat+=%+WPackage\ titlesec\ Warning:\ %m + setlocal errorformat+=%-C(titlesec)%m + else + setlocal errorformat+=%-WPackage\ titlesec\ Warning:\ %m + endif + + if get(self.config.packages, 'general', l:default) + setlocal errorformat+=%+WPackage\ %.%#\ Warning:\ %m\ on\ input\ line\ %l. + setlocal errorformat+=%+WPackage\ %.%#\ Warning:\ %m + setlocal errorformat+=%-Z(%.%#)\ %m\ on\ input\ line\ %l. + setlocal errorformat+=%-C(%.%#)\ %m + endif + + " Ignore unmatched lines + setlocal errorformat+=%-G%.%# +endfunction + +" }}}1 +function! s:qf.addqflist(tex, log) abort dict "{{{1 + if empty(a:log) || !filereadable(a:log) + throw 'Vimtex: No log file found' + endif + + let self.errorformat_saved = &l:errorformat + call self.set_errorformat() + execute 'caddfile' fnameescape(a:log) + let &l:errorformat = self.errorformat_saved + + " Apply some post processing of the quickfix list + let self.main = a:tex + let self.root = b:vimtex.root + call self.fix_paths() +endfunction + +" }}}1 +function! s:qf.pprint_items() abort dict " {{{1 + return [[ 'config', self.config ]] +endfunction + +" }}}1 +function! s:qf.fix_paths() abort dict " {{{1 + let l:qflist = getqflist() + + for l:qf in l:qflist + " For errors and warnings that don't supply a file, the basename of the + " main file is used. However, if the working directory is not the root of + " the LaTeX project, than this results in bufnr = 0. + if l:qf.bufnr == 0 + let l:qf.bufnr = bufnr(self.main) + continue + endif + + " The buffer names of all file:line type errors are relative to the root of + " the main LaTeX file. + let l:file = fnamemodify( + \ simplify(self.root . '/' . bufname(l:qf.bufnr)), ':.') + if !filereadable(l:file) | continue | endif + + if !bufexists(l:file) + execute 'badd' l:file + endif + + let l:qf.filename = l:file + let l:qf.bufnr = bufnr(l:file) + endfor + + call setqflist(l:qflist, 'r') +endfunction + +" }}}1 + +endif |