mirror of
https://github.com/gryf/tagbar.git
synced 2025-12-17 11:30:28 +01:00
Improve prototype handling
This commit is contained in:
@@ -913,7 +913,7 @@ function! s:MapKeys() abort
|
||||
|
||||
nnoremap <script> <silent> <buffer> <CR> :call <SID>JumpToTag(0)<CR>
|
||||
nnoremap <script> <silent> <buffer> p :call <SID>JumpToTag(1)<CR>
|
||||
nnoremap <script> <silent> <buffer> <Space> :call <SID>ShowPrototype()<CR>
|
||||
nnoremap <script> <silent> <buffer> <Space> :call <SID>ShowPrototype(1)<CR>
|
||||
|
||||
nnoremap <script> <silent> <buffer> + :call <SID>OpenFold()<CR>
|
||||
nnoremap <script> <silent> <buffer> <kPlus> :call <SID>OpenFold()<CR>
|
||||
@@ -949,7 +949,7 @@ function! s:CreateAutocommands() abort
|
||||
augroup TagbarAutoCmds
|
||||
autocmd!
|
||||
autocmd BufEnter __Tagbar__ nested call s:QuitIfOnlyWindow()
|
||||
autocmd CursorHold __Tagbar__ call s:ShowPrototype()
|
||||
autocmd CursorHold __Tagbar__ call s:ShowPrototype(0)
|
||||
|
||||
autocmd BufWritePost * call
|
||||
\ s:AutoUpdate(fnamemodify(expand('<afile>'), ':p'), 1)
|
||||
@@ -2060,27 +2060,26 @@ function! s:ParseTagline(part1, part2, typeinfo, fileinfo) abort
|
||||
endfunction
|
||||
|
||||
" s:GetPrototype() {{{2
|
||||
" Look for unbalanced opening parantheses and join lines until they are
|
||||
" Look for unbalanced opening parantheses and add lines until they are
|
||||
" balanced do get the complete prototype.
|
||||
function! s:GetPrototype(linenr) abort
|
||||
let line = getline(a:linenr)
|
||||
let line = substitute(line, '^\s\+', '', '')
|
||||
let list = split(line, '\zs')
|
||||
|
||||
let start = index(list, '(')
|
||||
if start == -1
|
||||
return line
|
||||
return substitute(line, '^\s\+', '', '')
|
||||
endif
|
||||
|
||||
let opening = count(list, '(', 0, start)
|
||||
let closing = count(list, ')', 0, start)
|
||||
if closing >= opening
|
||||
return line
|
||||
return substitute(line, '^\s\+', '', '')
|
||||
endif
|
||||
|
||||
let balance = opening - closing
|
||||
|
||||
let lines = [line]
|
||||
let prototype = line
|
||||
let curlinenr = a:linenr
|
||||
while balance > 0
|
||||
let curlinenr += 1
|
||||
@@ -2089,14 +2088,9 @@ function! s:GetPrototype(linenr) abort
|
||||
let opening += count(curlist, '(')
|
||||
let closing += count(curlist, ')')
|
||||
let balance = opening - closing
|
||||
let lines += [curline]
|
||||
let prototype .= "\n" . curline
|
||||
endwhile
|
||||
|
||||
let prototype = join(lines, ' ')
|
||||
let prototype = substitute(prototype, '(\s\+', '(', 'g')
|
||||
let prototype = substitute(prototype, '\s\+)', ')', 'g')
|
||||
let prototype = substitute(prototype, '\s\+', ' ', 'g')
|
||||
|
||||
return prototype
|
||||
endfunction
|
||||
|
||||
@@ -2804,14 +2798,30 @@ function! s:JumpToTag(stay_in_tagbar) abort
|
||||
endfunction
|
||||
|
||||
" s:ShowPrototype() {{{2
|
||||
function! s:ShowPrototype() abort
|
||||
function! s:ShowPrototype(long) abort
|
||||
let taginfo = s:GetTagInfo(line('.'), 1)
|
||||
|
||||
if empty(taginfo)
|
||||
return
|
||||
endif
|
||||
|
||||
echo taginfo.getPrototype()
|
||||
let prototype = taginfo.getPrototype()
|
||||
|
||||
if !a:long
|
||||
" join all lines
|
||||
let prototype = substitute(prototype, '^\s\+', '', '')
|
||||
let prototype = substitute(prototype, '\_s\+', ' ', 'g')
|
||||
let prototype = substitute(prototype, '(\s\+', '(', 'g')
|
||||
let prototype = substitute(prototype, '\s\+)', ')', 'g')
|
||||
" Avoid hit-enter prompts
|
||||
let maxlen = &columns - 12
|
||||
if len(prototype) > maxlen
|
||||
let prototype = prototype[:maxlen - 1 - 3]
|
||||
let prototype .= '...'
|
||||
endif
|
||||
endif
|
||||
|
||||
echo prototype
|
||||
endfunction
|
||||
|
||||
" s:ToggleHelp() {{{2
|
||||
|
||||
@@ -223,11 +223,12 @@ strange things will happen. This is unfortunately unavoidable.
|
||||
|
||||
Displaying the prototype of a tag~
|
||||
Tagbar can display the prototype of a tag. More precisely it can display the
|
||||
line in which the tag is defined. This can be done by either pressing <Space>
|
||||
when on a tag or hovering over a tag with the mouse. In the former case the
|
||||
prototype will be displayed in the command line |Command-line|, in the latter
|
||||
case it will be displayed in a pop-up window. The prototype will also be
|
||||
displayed when the cursor stays on a tag for 'updatetime' milliseconds.
|
||||
line(s) in which the tag is defined. This can be done by either pressing
|
||||
<Space> when on a tag or hovering over a tag with the mouse. In the former
|
||||
case the prototype will be displayed in the |Command-line|, in the latter case
|
||||
it will be displayed in a pop-up window. The prototype will also be displayed
|
||||
if the cursor stays on a tag for 'updatetime' milliseconds. In that case the
|
||||
prototype may be abbreviated in order to avoid |hit-enter| prompts.
|
||||
|
||||
------------------------------------------------------------------------------
|
||||
COMMANDS *tagbar-commands*
|
||||
|
||||
Reference in New Issue
Block a user