mirror of
				https://github.com/neovim/neovim.git
				synced 2025-11-04 01:34:25 +00:00 
			
		
		
		
	vim-patch:d55e698: runtime(pandoc): refine pandoc compiler settings
closes: vim/vim#15529
d55e698fa0
Co-authored-by: Konfekt <Konfekt@users.noreply.github.com>
			
			
This commit is contained in:
		@@ -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'
 | 
			
		||||
 | 
			
		||||
CompilerSet errorformat="%f",\ line\ %l:\ %m
 | 
			
		||||
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') : '')
 | 
			
		||||
 | 
			
		||||
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
 | 
			
		||||
 
 | 
			
		||||
@@ -1305,6 +1305,13 @@ Additional arguments can be passed to pandoc:
 | 
			
		||||
- 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
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user