From f6deaa6ccf331ce0cd204acfee3db0729f6e3e3d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Karl=20Yngve=20Lerv=C3=A5g?= Date: Mon, 11 Jul 2016 23:44:37 +0200 Subject: [PATCH] Cf. #477: Add folding for usepackages --- autoload/vimtex/fold.vim | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/autoload/vimtex/fold.vim b/autoload/vimtex/fold.vim index 583cf1c..097fe49 100644 --- a/autoload/vimtex/fold.vim +++ b/autoload/vimtex/fold.vim @@ -41,7 +41,7 @@ function! vimtex#fold#init_script() " {{{1 " " List of identifiers for improving efficiency " - let s:folded = '\v^\s*\%' + let s:folded = '\v^\s*\%|^\s*\]\{' let s:folded .= '|\\%(' . join([ \ 'begin', \ 'end', @@ -51,6 +51,7 @@ function! vimtex#fold#init_script() " {{{1 \ '%(front|main|back)matter', \ 'appendix', \ 'part', + \ 'usepackage', \ ], '|') . ')' endfunction @@ -138,6 +139,15 @@ function! vimtex#fold#level(lnum) " {{{1 endif endif + " Fold usepackages + if line =~# '^\s*\\usepackage\s*\[\s*\%($\|%\)' + let s:usepackage = 1 + return 'a1' + elseif get(s:, 'start', 0) && line =~# '^\s*\]{' + let s:usepackage = 0 + return 's1' + endif + " Fold chapters and sections for [part, level] in b:vimtex_fold.parts if line =~# part @@ -236,6 +246,13 @@ function! vimtex#fold#text() " {{{1 " Initialize let line = getline(v:foldstart) + " Text for usepackage + if line =~# '^\s*\\usepackage' + return '\usepackage[...]{' + \ . vimtex#cmd#get_at(v:foldstart, 1).args[0].text + \ . '}' + endif + let level = v:foldlevel > 1 \ ? repeat('-', v:foldlevel-2) . g:vimtex_fold_levelmarker \ : ''