wordcount: move User autocommand to plugin

Do not scatter the autocommands around, but rather move the auto command
to the main plugin file. The function that handles the auto command will
be created in the autoload script.

Also add a call to force updating the tabline, if g:airline_statusline_ontop
is defined.

In addition, the wordcount() extension did not correctly notice
block-wise visual mode, so while creating the airline#mode_changed()
function, make the mode also detect blockwise visual mode correctly.
This commit is contained in:
Christian Brabandt 2019-02-04 08:25:45 +01:00
parent 8867301f78
commit 25e384f236
No known key found for this signature in database
GPG Key ID: F3F92DA383FDDE09
3 changed files with 10 additions and 6 deletions

View File

@ -271,3 +271,11 @@ function! airline#update_tabline()
call airline#extensions#tabline#redraw() call airline#extensions#tabline#redraw()
endif endif
endfunction endfunction
function! airline#mode_changed()
" airline#visual_active
" Boolean: for when to get visual wordcount
" needed for the wordcount extension
let g:airline#visual_active = (mode() =~? '[vs]')
call airline#update_tabline()
endfunction

View File

@ -68,9 +68,8 @@ function! s:update_wordcount(force_update)
endif endif
endfunction endfunction
let s:visual_active = 0 " Boolean: for when to get visual wordcount
function airline#extensions#wordcount#get() function airline#extensions#wordcount#get()
if s:visual_active if get(g:, 'airline#visual_active', 0)
return s:format_wordcount(s:get_wordcount(1)) return s:format_wordcount(s:get_wordcount(1))
else else
if get(b:, 'airline_changedtick', 0) != b:changedtick if get(b:, 'airline_changedtick', 0) != b:changedtick
@ -109,9 +108,5 @@ function! airline#extensions#wordcount#apply(...)
endfunction endfunction
function! airline#extensions#wordcount#init(ext) function! airline#extensions#wordcount#init(ext)
augroup airline_wordcount
autocmd! User AirlineModeChanged nested
\ let s:visual_active = (mode() ==? 'v' || mode() ==? 's')
augroup END
call a:ext.add_statusline_func('airline#extensions#wordcount#apply') call a:ext.add_statusline_func('airline#extensions#wordcount#apply')
endfunction endfunction

View File

@ -145,6 +145,7 @@ function! s:airline_toggle()
autocmd BufWritePost */autoload/airline/themes/*.vim autocmd BufWritePost */autoload/airline/themes/*.vim
\ exec 'source '.split(globpath(&rtp, 'autoload/airline/themes/'.g:airline_theme.'.vim', 1), "\n")[0] \ exec 'source '.split(globpath(&rtp, 'autoload/airline/themes/'.g:airline_theme.'.vim', 1), "\n")[0]
\ | call airline#load_theme() \ | call airline#load_theme()
autocmd User AirlineModeChanged nested call airline#mode_changed()
if get(g:, 'airline_statusline_ontop', 0) if get(g:, 'airline_statusline_ontop', 0)
" Force update of tabline more often " Force update of tabline more often