summaryrefslogtreecommitdiffstats
path: root/autoload/vimtex/qf/latexlog.vim
diff options
context:
space:
mode:
Diffstat (limited to 'autoload/vimtex/qf/latexlog.vim')
-rw-r--r--autoload/vimtex/qf/latexlog.vim209
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