From af3f209d7a30bc07c4c82a30efe000efd7ad35b4 Mon Sep 17 00:00:00 2001 From: Christian Brabandt Date: Thu, 28 Jan 2016 17:27:17 +0100 Subject: [PATCH] Try to avoid excessive redraws. Most of them seem to be caused by using :hi statements, although the highlighting group to be created is exactly the same. Therefore, get the info from actual definition and only execute :hi when the new group is actually different. Also try to avoid to generate :hi statements when the popupmen is visible. This causes flickers. --- autoload/airline/extensions/tabline.vim | 3 ++ autoload/airline/highlighter.vim | 38 +++++++++++++++++++------ 2 files changed, 32 insertions(+), 9 deletions(-) diff --git a/autoload/airline/extensions/tabline.vim b/autoload/airline/extensions/tabline.vim index 1e96c9d..cb8d22c 100644 --- a/autoload/airline/extensions/tabline.vim +++ b/autoload/airline/extensions/tabline.vim @@ -59,6 +59,9 @@ function! s:update_tabline() endfunction function! airline#extensions#tabline#load_theme(palette) + if pumvisible() + return + endif let colors = get(a:palette, 'tabline', {}) let l:tab = get(colors, 'airline_tab', a:palette.normal.airline_b) let l:tabsel = get(colors, 'airline_tabsel', a:palette.normal.airline_a) diff --git a/autoload/airline/highlighter.vim b/autoload/airline/highlighter.vim index d9ade3e..09312d6 100644 --- a/autoload/airline/highlighter.vim +++ b/autoload/airline/highlighter.vim @@ -59,23 +59,40 @@ function! airline#highlighter#get_highlight2(fg, bg, ...) endfunction function! airline#highlighter#exec(group, colors) + if pumvisible() + return + endif let colors = a:colors if s:is_win32term let colors[2] = s:gui2cui(get(colors, 0, ''), get(colors, 2, '')) let colors[3] = s:gui2cui(get(colors, 1, ''), get(colors, 3, '')) endif - exec printf('hi %s %s %s %s %s %s %s %s', - \ a:group, - \ get(colors, 0, '') isnot# '' ? 'guifg='.colors[0] : '', - \ get(colors, 1, '') isnot# '' ? 'guibg='.colors[1] : '', - \ get(colors, 2, '') isnot# '' ? 'ctermfg='.colors[2] : '', - \ get(colors, 3, '') isnot# '' ? 'ctermbg='.colors[3] : '', - \ get(colors, 4, '') isnot# '' ? 'gui='.colors[4] : '', - \ get(colors, 4, '') isnot# '' ? 'cterm='.colors[4] : '', - \ get(colors, 4, '') isnot# '' ? 'term='.colors[4] : '') + let cmd= printf('hi %s %s %s %s %s %s %s %s', + \ a:group, s:Get(colors, 0, 'guifg=', ''), s:Get(colors, 1, 'guibg=', ''), + \ s:Get(colors, 2, 'ctermfg=', ''), s:Get(colors, 3, 'ctermbg=', ''), + \ s:Get(colors, 4, 'gui=', ''), s:Get(colors, 4, 'cterm=', ''), + \ s:Get(colors, 4, 'term=', '')) + let old_hi = airline#highlighter#get_highlight(a:group) + if len(colors) == 4 + call add(colors, '') + endif + if old_hi != colors + exe cmd + endif +endfunction + +function! s:Get(dict, key, prefix, default) + if get(a:dict, a:key, a:default) isnot# a:default + return a:prefix. get(a:dict, a:key) + else + return '' + endif endfunction function! s:exec_separator(dict, from, to, inverse, suffix) + if pumvisible() + return + endif let l:from = airline#themes#get_highlight(a:from.a:suffix) let l:to = airline#themes#get_highlight(a:to.a:suffix) let group = a:from.'_to_'.a:to.a:suffix @@ -89,6 +106,9 @@ function! s:exec_separator(dict, from, to, inverse, suffix) endfunction function! airline#highlighter#load_theme() + if pumvisible() + return + endif for winnr in filter(range(1, winnr('$')), 'v:val != winnr()') call airline#highlighter#highlight_modified_inactive(winbufnr(winnr)) endfor