Mercurial > vim
changeset 36002:b0022c9aff0d
runtime(pandoc): refine pandoc compiler settings
Commit: https://github.com/vim/vim/commit/d55e698fa02195bf451b072eb2fb20cfbf7bddf5
Author: Konfekt <Konfekt@users.noreply.github.com>
Date: Tue Aug 20 20:18:28 2024 +0200
runtime(pandoc): refine pandoc compiler settings
closes: https://github.com/vim/vim/issues/15529
Signed-off-by: Christian Brabandt <cb@256bit.org>
Signed-off-by: Konfekt <Konfekt@users.noreply.github.com>
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Tue, 20 Aug 2024 20:30:03 +0200 |
parents | d77b2a6c4532 |
children | 0071ce92bf67 |
files | runtime/compiler/pandoc.vim runtime/doc/quickfix.txt |
diffstat | 2 files changed, 32 insertions(+), 21 deletions(-) [+] |
line wrap: on
line diff
--- a/runtime/compiler/pandoc.vim +++ b/runtime/compiler/pandoc.vim @@ -1,6 +1,7 @@ " Vim compiler file " Compiler: Pandoc " Maintainer: Konfekt +" Last Change: 2024 Aug 20 " " Expects output file extension, say `:make html` or `:make pdf`. " Passes additional arguments to pandoc, say `:make html --self-contained`. @@ -25,31 +26,34 @@ let s:supported_filetypes = silent! function s:PandocFiletype(filetype) abort let ft = a:filetype - if ft ==# 'pandoc' - return 'markdown' - elseif ft ==# 'tex' - return 'latex' - elseif ft ==# 'xml' - " Pandoc does not support XML as a generic input format, but it does support - " EndNote XML and Jats XML out of which the latter seems more universal. - return 'jats' - elseif ft ==# 'text' || empty(ft) - return 'markdown' - elseif index(s:supported_filetypes, &ft) >= 0 - return ft + + if ft ==# 'pandoc' | return 'markdown' + elseif ft ==# 'tex' | return 'latex' + " Pandoc does not support XML as a generic input format, but it does support + " EndNote XML and Jats XML out of which the latter seems more universal. + elseif ft ==# 'xml' | return 'jats' + elseif ft ==# 'text' || empty(ft) | return 'markdown' + elseif index(s:supported_filetypes, &ft) >= 0 | return ft else - echomsg 'Unsupported filetype: ' . ft . ', falling back to Markdown as input format!' + echomsg 'Unsupported filetype: '..ft..', falling back to Markdown as input format!' return 'markdown' endif endfunction -execute 'CompilerSet makeprg=pandoc\ --standalone' . - \ '\ --metadata\ title=%:t:r:S' . - \ '\ --metadata\ lang=' . matchstr(&spelllang, '^\a\a') . - \ '\ --from=' . s:PandocFiletype(&filetype) . - \ '\ ' . escape(get(b:, 'pandoc_compiler_args', get(g:, 'pandoc_compiler_args', '')), ' ') . - \ '\ --output\ %:r:S.$*\ %:S' + +let b:pandoc_compiler_from = get(b:, 'pandoc_compiler_from', s:PandocFiletype(&filetype)) +let b:pandoc_compiler_lang = get(b:, 'pandoc_compiler_lang', &spell ? matchstr(&spelllang, '^\a\a') : '') -CompilerSet errorformat="%f",\ line\ %l:\ %m +execute 'CompilerSet makeprg=pandoc'..escape( + \ ' --standalone' . + \ (b:pandoc_compiler_from ==# 'markdown' && (getline(1) =~# '^%\s\+\S\+' || (search('^title:\s+\S+', 'cnw') > 0)) ? + \ '' : ' --metadata title=%:t:r:S') . + \ (empty(b:pandoc_compiler_lang) ? + \ '' : ' --metadata lang='..b:pandoc_compiler_lang) . + \ ' --from='..b:pandoc_compiler_from . + \ ' '..get(b:, 'pandoc_compiler_args', get(g:, 'pandoc_compiler_args', '')) . + \ ' --output %:r:S.$* -- %:S', ' ') + +CompilerSet errorformat=%f,\ line\ %l:\ %m let &cpo = s:keepcpo unlet s:keepcpo
--- a/runtime/doc/quickfix.txt +++ b/runtime/doc/quickfix.txt @@ -1,4 +1,4 @@ -*quickfix.txt* For Vim version 9.1. Last change: 2024 Aug 05 +*quickfix.txt* For Vim version 9.1. Last change: 2024 Aug 20 VIM REFERENCE MANUAL by Bram Moolenaar @@ -1345,6 +1345,13 @@ Additional arguments can be passed to pa - either by appending them to make, say `:make html --self-contained` . - or setting them in `b:pandoc_compiler_args` or `g:pandoc_compiler_args`. +The `--from` argument is an educated guess using the buffer file type; +it can be overridden by setting `b:pandoc_compiler_from`. +Likewise the `--metadata lang` argument is set using `&spelllang`; +it can be overridden by setting `b:pandoc_compiler_lang`. +If `--from=markdown` is assumed and no title set in a title header or +YAML block, then the filename (without extension) is used as the title. + PERL *quickfix-perl* *compiler-perl* The Perl compiler plugin doesn't actually compile, but invokes Perl's internal