Added support for compile only subfile (#211, #280)

This commit is contained in:
Karl Yngve Lervåg 2016-01-14 14:57:35 +01:00
parent 1a8542d48a
commit 55979afc7d

View File

@ -64,6 +64,29 @@ function! vimtex#init() " {{{1
let s:initialized = 1 let s:initialized = 1
"
" Support for subfile package (toggle)
"
if exists('s:subfile')
let l:subfile = deepcopy(b:vimtex)
let l:subfile.tex = s:subfile
let l:subfile.pid = 0
let l:subfile.name = fnamemodify(s:subfile, ':t:r')
let l:subfile.root = fnamemodify(s:subfile, ':h')
let l:subfile.base = fnamemodify(s:subfile, ':t')
let s:vimtex_next_id += 1
let g:vimtex_data[s:vimtex_next_id] = l:subfile
let b:subfile = {
\ 'active' : 0,
\ 'main_id' : b:vimtex_id,
\ 'sub_id' : s:vimtex_next_id,
\}
unlet s:subfile
endif
" "
" Allow custom configuration through an event hook " Allow custom configuration through an event hook
" "
@ -104,7 +127,7 @@ function! vimtex#info(global) " {{{1
endfunction endfunction
" }}}1 " }}}1
function! vimtex#wordcount(detailed) " {{{1 function! vimtex#wc(detailed) " {{{1
" Run texcount, save output to lines variable " Run texcount, save output to lines variable
let cmd = 'cd ' . vimtex#util#shellescape(b:vimtex.root) let cmd = 'cd ' . vimtex#util#shellescape(b:vimtex.root)
let cmd .= '; texcount -nosub -sum ' let cmd .= '; texcount -nosub -sum '
@ -172,6 +195,22 @@ if !exists('s:reloading_script')
endfunction endfunction
endif endif
" }}}1
function! vimtex#subfile_toggle() " {{{1
if exists('b:subfile')
let b:subfile.active = !b:subfile.active
let b:vimtex_id = b:subfile.active ? b:subfile.sub_id : b:subfile.main_id
let b:vimtex = g:vimtex_data[b:vimtex_id]
call vimtex#echo#status(['vimtex: ',
\ ['Normal', 'Changed to `'],
\ ['VimtexSuccess', b:vimtex.base],
\ ['Normal', "' "],
\ ['VimtexInfo', b:subfile.active ? '[subfile]' : '[main]' ]])
endif
endfunction
" }}}1 " }}}1
@ -279,14 +318,16 @@ function! s:init_buffer() " {{{1
" "
" Define commands " Define commands
command! -buffer -bang VimtexInfo call vimtex#info(<q-bang> == "!") command! -buffer -bang VimtexInfo call vimtex#info(<q-bang> == "!")
command! -buffer -bang VimtexWordCount call vimtex#wordcount(<q-bang> == "!") command! -buffer -bang VimtexWordCount call vimtex#wc(<q-bang> == "!")
command! -buffer VimtexReload call vimtex#reload() command! -buffer VimtexReload call vimtex#reload()
command! -buffer VimtexSubfileToggle call vimtex#subfile_toggle()
" Define mappings " Define mappings
nnoremap <buffer> <plug>(vimtex-info) :VimtexInfo<cr> nnoremap <buffer> <plug>(vimtex-info) :VimtexInfo<cr>
nnoremap <buffer> <plug>(vimtex-info-full) :VimtexInfo!<cr> nnoremap <buffer> <plug>(vimtex-info-full) :VimtexInfo!<cr>
nnoremap <buffer> <plug>(vimtex-reload) :VimtexReload<cr> nnoremap <buffer> <plug>(vimtex-reload) :VimtexReload<cr>
nnoremap <buffer> <plug>(vimtex-subfile-toggle) :VimtexSubfileToggle<cr>
" "
" Attach autocommands " Attach autocommands
@ -314,6 +355,7 @@ function! s:init_mappings() " {{{1
call s:map('n', '<localleader>li', '<plug>(vimtex-info)') call s:map('n', '<localleader>li', '<plug>(vimtex-info)')
call s:map('n', '<localleader>lI', '<plug>(vimtex-info-full)') call s:map('n', '<localleader>lI', '<plug>(vimtex-info-full)')
call s:map('n', '<localleader>lx', '<plug>(vimtex-reload)') call s:map('n', '<localleader>lx', '<plug>(vimtex-reload)')
call s:map('n', '<localleader>lS', '<plug>(vimtex-subfile-toggle)')
call s:map('n', 'dse', '<plug>(vimtex-delete-env)') call s:map('n', 'dse', '<plug>(vimtex-delete-env)')
call s:map('n', 'dsc', '<plug>(vimtex-delete-cmd)') call s:map('n', 'dsc', '<plug>(vimtex-delete-cmd)')
@ -442,6 +484,7 @@ function! s:get_main() " {{{1
let l:candidate = s:get_main_from_specifier( let l:candidate = s:get_main_from_specifier(
\ '^\C\s*\\documentclass\[\zs.*\ze\]{subfiles}') \ '^\C\s*\\documentclass\[\zs.*\ze\]{subfiles}')
if l:candidate !=# '' if l:candidate !=# ''
let s:subfile = expand('%:p')
return l:candidate return l:candidate
endif endif