Fix #548: Also handle multi-line short titles

This commit is contained in:
Karl Yngve Lervåg 2016-10-21 09:17:19 +02:00
parent d457431284
commit acdefeb9f5
2 changed files with 34 additions and 26 deletions

View File

@ -127,10 +127,11 @@ function! vimtex#toc#get_entries() " {{{1
for [l:file, l:lnum, l:line] in l:parsed for [l:file, l:lnum, l:line] in l:parsed
" Handle multi-line sections (and chapter/subsection/etc) " Handle multi-line sections (and chapter/subsection/etc)
if get(s:, 'sec_continue', 0) if get(s:, 'sec_continue', 0)
let [l:end, l:count] = s:find_indx_closing_brace(0, l:line, s:sec_count, 1) let [l:end, l:count] = s:find_closing(0, l:line, s:sec_count, s:sec_type)
if l:count == 0 if l:count == 0
let l:toc[-1].title = s:parse_line_sec_title( let l:toc[-1].title = s:parse_line_sec_title(
\ l:toc[-1].title . strpart(l:line, 0, l:end)) \ l:toc[-1].title . strpart(l:line, 0, l:end+1))
unlet s:sec_type
unlet s:sec_count unlet s:sec_count
unlet s:sec_continue unlet s:sec_continue
else else
@ -397,18 +398,16 @@ endfunction
function! s:parse_line_sec(file, lnum, line) " {{{1 function! s:parse_line_sec(file, lnum, line) " {{{1
let level = matchstr(a:line, s:re_sec_level) let level = matchstr(a:line, s:re_sec_level)
let title = matchlist(a:line, s:re_sec)[1] let type = matchlist(a:line, s:re_sec)[1]
if empty(title)
let title = matchstr(a:line, s:re_sec_title) let title = matchstr(a:line, s:re_sec_title)
let l:count = 1
\ + len(substitute(title, '[^{]', '', 'g')) let [l:end, l:count] = s:find_closing(0, title, 1, type)
\ - len(substitute(title, '[^}]', '', 'g')) if l:count == 0
if l:count > 0 let title = s:parse_line_sec_title(strpart(title, 0, l:end+1))
let s:sec_continue = 1
let s:sec_count = l:count
else else
let title = s:parse_line_sec_title(title) let s:sec_type = type
endif let s:sec_count = l:count
let s:sec_continue = 1
endif endif
" Check if section is starred " Check if section is starred
@ -507,12 +506,13 @@ function! s:clear_texorpdfstring(title) " {{{1
if l:i1 < 0 | return a:title | endif if l:i1 < 0 | return a:title | endif
" Find start of included part " Find start of included part
let l:i2 = s:find_indx_closing_brace(match(a:title, '{', l:i1+1), a:title, 1) let [l:i2, l:dummy] = s:find_closing(
\ match(a:title, '{', l:i1+1), a:title, 1, '{')
let l:i2 = match(a:title, '{', l:i2+1) let l:i2 = match(a:title, '{', l:i2+1)
if l:i2 < 0 | return a:title | endif if l:i2 < 0 | return a:title | endif
" Find end of included part " Find end of included part
let l:i3 = s:find_indx_closing_brace(l:i2, a:title, 1) let [l:i3, l:dummy] = s:find_closing(l:i2, a:title, 1, '{')
if l:i3 < 0 | return a:title | endif if l:i3 < 0 | return a:title | endif
return strpart(a:title, 0, l:i1) return strpart(a:title, 0, l:i1)
@ -521,25 +521,28 @@ function! s:clear_texorpdfstring(title) " {{{1
endfunction endfunction
" }}}1 " }}}1
function! s:find_indx_closing_brace(start, string, count, ...) " {{{1 function! s:find_closing(start, string, count, type) " {{{1
if a:type ==# '{'
let l:re = '{\|}'
let l:open = '{'
else
let l:re = '\[\|\]'
let l:open = '['
endif
let l:i2 = a:start let l:i2 = a:start
let l:count = a:count let l:count = a:count
while l:count > 0 while l:count > 0
let l:i2 = match(a:string, '{\|}', l:i2+1) let l:i2 = match(a:string, l:re, l:i2+1)
if l:i2 < 0 | break | endif if l:i2 < 0 | break | endif
if a:string[l:i2] ==# '{' if a:string[l:i2] ==# l:open
let l:count += 1 let l:count += 1
else else
let l:count -= 1 let l:count -= 1
endif endif
endwhile endwhile
if a:0 > 0
return [l:i2, l:count] return [l:i2, l:count]
else
return l:i2
endif
endfunction endfunction
" }}}1 " }}}1
@ -580,10 +583,10 @@ let s:sec_to_value = {
\ } \ }
" Define regular expressions to match document parts " Define regular expressions to match document parts
let s:re_sec = '\v^\s*\\%(part|chapter|%(sub)*section)\*?\s*%(\[(.{-})\])?\{' let s:re_sec = '\v^\s*\\%(part|chapter|%(sub)*section)\*?\s*(\[|\{)'
let s:re_sec_title = s:re_sec . '\zs.{-}\ze\%?\s*$'
let s:re_sec_starred = '\v^\s*\\%(part|chapter|%(sub)*section)\*' let s:re_sec_starred = '\v^\s*\\%(part|chapter|%(sub)*section)\*'
let s:re_sec_level = '\v^\s*\\\zs%(part|chapter|%(sub)*section)' let s:re_sec_level = '\v^\s*\\\zs%(part|chapter|%(sub)*section)'
let s:re_sec_title = s:re_sec . '\zs.{-}\}?\ze\%?\s*$'
let s:re_vimtex_include = '%\s*vimtex-include:\?\s\+\zs\f\+' let s:re_vimtex_include = '%\s*vimtex-include:\?\s\+\zs\f\+'
let s:re_matters = '\v^\s*\\%(front|main|back)matter>' let s:re_matters = '\v^\s*\\%(front|main|back)matter>'
let s:re_structure = '\v^\s*\\((front|main|back)matter|appendix)>' let s:re_structure = '\v^\s*\\((front|main|back)matter|appendix)>'

View File

@ -23,6 +23,11 @@
\subsection{Test sub section 2} \subsection{Test sub section 2}
Some text. Some text.
\chapter[Parsing toc specific entries works
also for multi-line --- A second Hurray!]{Parsing {toc entries works
also for} multi-line \texorpdfstring{stuff}{entries}
--- Hurray!}
\chapter*{Test chapter 1} \chapter*{Test chapter 1}
Test of starred chapter. Test of starred chapter.