Fix indentation for listings
This commit is contained in:
parent
bb66d60e44
commit
6abd9ef2be
@ -22,21 +22,15 @@ setlocal indentkeys&
|
|||||||
setlocal indentkeys+=[,(,{,),},],\&,=item
|
setlocal indentkeys+=[,(,{,),},],\&,=item
|
||||||
|
|
||||||
function! VimtexIndent() " {{{1
|
function! VimtexIndent() " {{{1
|
||||||
" Find a non-blank non-comment line above the current line
|
let l:nprev = s:get_prev_line(prevnonblank(v:lnum - 1))
|
||||||
let l:nprev = prevnonblank(v:lnum - 1)
|
if l:nprev == 0 | return 0 | endif
|
||||||
while l:nprev != 0 && getline(l:nprev) =~# '^\s*%'
|
|
||||||
let l:nprev = prevnonblank(l:nprev - 1)
|
|
||||||
endwhile
|
|
||||||
if l:nprev == 0
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
|
|
||||||
" Get current and previous line and remove comments
|
" Get current and previous line and remove comments
|
||||||
let l:cur = substitute(getline(v:lnum), '\\\@<!%.*', '', '')
|
let l:cur = substitute(getline(v:lnum), '\\\@<!%.*', '', '')
|
||||||
let l:prev = substitute(getline(l:nprev), '\\\@<!%.*', '', '')
|
let l:prev = substitute(getline(l:nprev), '\\\@<!%.*', '', '')
|
||||||
|
|
||||||
" Check for verbatim modes
|
" Check for verbatim modes
|
||||||
if synIDattr(synID(v:lnum, indent(v:lnum), 1), 'name') ==# 'texZone'
|
if s:is_verbatim(l:cur, v:lnum)
|
||||||
return empty(l:cur) ? indent(l:nprev) : indent(v:lnum)
|
return empty(l:cur) ? indent(l:nprev) : indent(v:lnum)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
@ -50,14 +44,9 @@ function! VimtexIndent() " {{{1
|
|||||||
return indent(v:lnum)
|
return indent(v:lnum)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
" Find previous non-empty non-comment non-ampersand line
|
let l:nprev = s:get_prev_line(l:nprev, 'ignore-ampersands')
|
||||||
while l:nprev != 0 && (match(l:prev, '\\\@<!&') != -1 || l:prev =~# '^\s*%')
|
if l:nprev == 0 | return 0 | endif
|
||||||
let l:nprev = prevnonblank(l:nprev - 1)
|
|
||||||
let l:prev = getline(l:nprev)
|
let l:prev = getline(l:nprev)
|
||||||
endwhile
|
|
||||||
if l:nprev == 0
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
|
|
||||||
let l:ind = indent(l:nprev)
|
let l:ind = indent(l:nprev)
|
||||||
let l:ind += s:indent_envs(l:cur, l:prev)
|
let l:ind += s:indent_envs(l:cur, l:prev)
|
||||||
@ -67,12 +56,38 @@ function! VimtexIndent() " {{{1
|
|||||||
endfunction
|
endfunction
|
||||||
"}}}
|
"}}}
|
||||||
|
|
||||||
|
function! s:get_prev_line(lnum, ...) " {{{1
|
||||||
|
let l:ignore_amps = a:0 > 0
|
||||||
|
|
||||||
|
let l:lnum = a:lnum
|
||||||
|
let l:prev = getline(l:lnum)
|
||||||
|
|
||||||
|
while l:lnum != 0
|
||||||
|
\ && (l:prev =~# '^\s*%'
|
||||||
|
\ || s:is_verbatim(l:prev, l:lnum)
|
||||||
|
\ || match(l:prev, '\\\@<!&') >= 0)
|
||||||
|
let l:lnum = prevnonblank(l:lnum - 1)
|
||||||
|
let l:prev = getline(l:lnum)
|
||||||
|
endwhile
|
||||||
|
|
||||||
|
return l:lnum
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
function! s:is_verbatim(line, lnum) " {{{1
|
||||||
|
let l:env = a:line !~# '\v\\%(begin|end)\{%(verbatim|lstlisting|minted)'
|
||||||
|
let l:syn = synIDattr(synID(a:lnum, 1, 1), 'name') ==# 'texZone'
|
||||||
|
return l:env && l:syn
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
function! s:indent_envs(cur, prev) " {{{1
|
function! s:indent_envs(cur, prev) " {{{1
|
||||||
let l:ind = 0
|
let l:ind = 0
|
||||||
|
|
||||||
" First for general environments
|
" First for general environments
|
||||||
let l:ind += &sw*((a:prev =~# '\\begin{.*}') && (a:prev !~# s:envs_ignore))
|
let l:ind += &sw*((a:prev =~# '\\begin{.*}') && (a:prev !~# 'document'))
|
||||||
let l:ind -= &sw*((a:cur =~# '\\end{.*}') && (a:cur !~# s:envs_ignore))
|
let l:ind -= &sw*((a:cur =~# '\\end{.*}') && (a:cur !~# 'document'))
|
||||||
|
|
||||||
" Indentation for prolonged items in lists
|
" Indentation for prolonged items in lists
|
||||||
let l:ind += &sw*((a:prev =~# s:envs_item) && (a:cur !~# s:envs_enditem))
|
let l:ind += &sw*((a:prev =~# s:envs_item) && (a:cur !~# s:envs_enditem))
|
||||||
@ -82,7 +97,6 @@ function! s:indent_envs(cur, prev) " {{{1
|
|||||||
return l:ind
|
return l:ind
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
let s:envs_ignore = 'document\|verbatim\|lstlisting'
|
|
||||||
let s:envs_lists = 'itemize\|description\|enumerate\|thebibliography'
|
let s:envs_lists = 'itemize\|description\|enumerate\|thebibliography'
|
||||||
let s:envs_item = '^\s*\\item'
|
let s:envs_item = '^\s*\\item'
|
||||||
let s:envs_beglist = '\\begin{\%(' . s:envs_lists . '\)'
|
let s:envs_beglist = '\\begin{\%(' . s:envs_lists . '\)'
|
||||||
|
@ -151,7 +151,13 @@ Given tex (Indent verbatims):
|
|||||||
echo "test"
|
echo "test"
|
||||||
\end{verbatim}
|
\end{verbatim}
|
||||||
|
|
||||||
Do (TODO):
|
\begin{lstlisting}
|
||||||
|
Indent
|
||||||
|
should
|
||||||
|
not affect verbatim environments!
|
||||||
|
\end{lstlisting}
|
||||||
|
|
||||||
|
Do:
|
||||||
gg=G
|
gg=G
|
||||||
|
|
||||||
Expect tex:
|
Expect tex:
|
||||||
@ -160,3 +166,9 @@ Expect tex:
|
|||||||
echo "test"
|
echo "test"
|
||||||
\end{verbatim}
|
\end{verbatim}
|
||||||
|
|
||||||
|
\begin{lstlisting}
|
||||||
|
Indent
|
||||||
|
should
|
||||||
|
not affect verbatim environments!
|
||||||
|
\end{lstlisting}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user