" Vim compiler file " Compiler: Pandoc " Maintainer: Konfekt " " Expects output file extension, say `:make html` or `:make pdf`. " Passes additional arguments to pandoc, say `:make html --self-contained`. if exists("current_compiler") finish endif let s:keepcpo = &cpo set cpo&vim let current_compiler = 'pandoc' " As of 2024-04-08 pandoc supports the following text input formats with " an ftplugin on Github: let s:supported_filetypes = \ [ 'bibtex', 'markdown', 'creole', 'json', 'csv', 'tsv', 'docbook', \ 'xml', 'fb2', 'html', 'jira', 'tex', 'mediawiki', 'nroff', 'org', \ 'rtf', 'rst', 't2t', 'textile', 'twiki', 'typst', 'vimwiki' ] " .. and out of those the following are included in Vim's runtime: " 'xml', 'tex', 'html', 'rst', 'json', 'nroff', 'markdown' 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 else 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 &cpo = s:keepcpo unlet s:keepcpo