2021-01-01 20:57:00 +08:00
|
|
|
" MIT License. Copyright (c) 2013-2021 Bailey Ling Christian Brabandt et al.
|
2013-08-18 01:35:06 +08:00
|
|
|
" vim: et ts=2 sts=2 sw=2
|
2013-08-16 09:47:54 +08:00
|
|
|
|
2016-09-24 08:16:30 +08:00
|
|
|
scriptencoding utf-8
|
|
|
|
|
2013-09-01 05:42:09 +08:00
|
|
|
call airline#init#bootstrap()
|
2019-08-21 04:19:48 +08:00
|
|
|
|
|
|
|
" couple of static variables. Those should not change within a session, thus
|
|
|
|
" can be initialized here as "static"
|
2013-09-19 10:23:50 +08:00
|
|
|
let s:spc = g:airline_symbols.space
|
2018-09-25 22:03:30 +08:00
|
|
|
let s:nomodeline = (v:version > 703 || (v:version == 703 && has("patch438"))) ? '<nomodeline>' : ''
|
2019-08-21 04:20:39 +08:00
|
|
|
let s:has_strchars = exists('*strchars')
|
2019-08-21 04:22:06 +08:00
|
|
|
let s:has_strcharpart = exists('*strcharpart')
|
2020-02-14 06:29:33 +08:00
|
|
|
let s:focusgained_ignore_time = 0
|
2013-09-01 00:57:02 +08:00
|
|
|
|
2019-02-04 00:30:55 +08:00
|
|
|
" TODO: Try to cache winwidth(0) function
|
|
|
|
" e.g. store winwidth per window and access that, only update it, if the size
|
|
|
|
" actually changed.
|
2021-05-14 01:25:14 +08:00
|
|
|
function! airline#util#winwidth(...) abort
|
2019-02-04 00:30:55 +08:00
|
|
|
let nr = get(a:000, 0, 0)
|
|
|
|
if get(g:, 'airline_statusline_ontop', 0)
|
|
|
|
return &columns
|
|
|
|
else
|
|
|
|
return winwidth(nr)
|
|
|
|
endif
|
|
|
|
endfunction
|
|
|
|
|
2017-05-03 03:22:47 +08:00
|
|
|
function! airline#util#shorten(text, winwidth, minwidth, ...)
|
2019-02-04 00:30:55 +08:00
|
|
|
if airline#util#winwidth() < a:winwidth && len(split(a:text, '\zs')) > a:minwidth
|
2017-05-03 03:22:47 +08:00
|
|
|
if get(a:000, 0, 0)
|
|
|
|
" shorten from tail
|
|
|
|
return '…'.matchstr(a:text, '.\{'.a:minwidth.'}$')
|
|
|
|
else
|
|
|
|
" shorten from beginning of string
|
|
|
|
return matchstr(a:text, '^.\{'.a:minwidth.'}').'…'
|
|
|
|
endif
|
2016-07-02 15:49:05 +08:00
|
|
|
else
|
|
|
|
return a:text
|
|
|
|
endif
|
|
|
|
endfunction
|
|
|
|
|
2013-09-01 00:33:58 +08:00
|
|
|
function! airline#util#wrap(text, minwidth)
|
2019-02-04 00:30:55 +08:00
|
|
|
if a:minwidth > 0 && airline#util#winwidth() < a:minwidth
|
2013-09-01 00:33:58 +08:00
|
|
|
return ''
|
|
|
|
endif
|
|
|
|
return a:text
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
function! airline#util#append(text, minwidth)
|
2019-02-04 00:30:55 +08:00
|
|
|
if a:minwidth > 0 && airline#util#winwidth() < a:minwidth
|
2013-09-01 00:33:58 +08:00
|
|
|
return ''
|
|
|
|
endif
|
2013-09-30 22:37:02 +08:00
|
|
|
let prefix = s:spc == "\ua0" ? s:spc : s:spc.s:spc
|
|
|
|
return empty(a:text) ? '' : prefix.g:airline_left_alt_sep.s:spc.a:text
|
2013-08-29 07:29:35 +08:00
|
|
|
endfunction
|
|
|
|
|
2016-04-21 15:11:22 +08:00
|
|
|
function! airline#util#warning(msg)
|
|
|
|
echohl WarningMsg
|
|
|
|
echomsg "airline: ".a:msg
|
|
|
|
echohl Normal
|
|
|
|
endfunction
|
|
|
|
|
2013-09-01 00:33:58 +08:00
|
|
|
function! airline#util#prepend(text, minwidth)
|
2019-02-04 00:30:55 +08:00
|
|
|
if a:minwidth > 0 && airline#util#winwidth() < a:minwidth
|
2013-09-01 00:33:58 +08:00
|
|
|
return ''
|
|
|
|
endif
|
2013-09-19 10:23:50 +08:00
|
|
|
return empty(a:text) ? '' : a:text.s:spc.g:airline_right_alt_sep.s:spc
|
2013-08-29 08:57:58 +08:00
|
|
|
endfunction
|
|
|
|
|
2019-12-22 20:26:59 +08:00
|
|
|
if v:version >= 704
|
|
|
|
function! airline#util#getbufvar(bufnr, key, def)
|
|
|
|
return getbufvar(a:bufnr, a:key, a:def)
|
|
|
|
endfunction
|
|
|
|
else
|
|
|
|
function! airline#util#getbufvar(bufnr, key, def)
|
|
|
|
let bufvals = getbufvar(a:bufnr, '')
|
|
|
|
return get(bufvals, a:key, a:def)
|
|
|
|
endfunction
|
|
|
|
endif
|
|
|
|
|
2013-08-18 12:50:48 +08:00
|
|
|
if v:version >= 704
|
2013-08-18 05:39:06 +08:00
|
|
|
function! airline#util#getwinvar(winnr, key, def)
|
|
|
|
return getwinvar(a:winnr, a:key, a:def)
|
|
|
|
endfunction
|
|
|
|
else
|
|
|
|
function! airline#util#getwinvar(winnr, key, def)
|
|
|
|
let winvals = getwinvar(a:winnr, '')
|
2013-08-18 12:50:48 +08:00
|
|
|
return get(winvals, a:key, a:def)
|
2013-08-18 05:39:06 +08:00
|
|
|
endfunction
|
|
|
|
endif
|
2013-08-16 09:50:24 +08:00
|
|
|
|
2013-08-18 05:50:41 +08:00
|
|
|
if v:version >= 704
|
2013-08-22 11:12:07 +08:00
|
|
|
function! airline#util#exec_funcrefs(list, ...)
|
2013-08-18 05:50:41 +08:00
|
|
|
for Fn in a:list
|
2013-08-23 04:22:54 +08:00
|
|
|
let code = call(Fn, a:000)
|
2013-08-22 11:12:07 +08:00
|
|
|
if code != 0
|
|
|
|
return code
|
2013-08-16 09:47:54 +08:00
|
|
|
endif
|
2013-08-18 05:50:41 +08:00
|
|
|
endfor
|
2013-08-22 11:12:07 +08:00
|
|
|
return 0
|
2013-08-18 05:50:41 +08:00
|
|
|
endfunction
|
|
|
|
else
|
2013-08-22 11:12:07 +08:00
|
|
|
function! airline#util#exec_funcrefs(list, ...)
|
2013-08-18 05:50:41 +08:00
|
|
|
" for 7.2; we cannot iterate the list, hence why we use range()
|
|
|
|
" for 7.3-[97, 328]; we cannot reuse the variable, hence the {}
|
|
|
|
for i in range(0, len(a:list) - 1)
|
|
|
|
let Fn{i} = a:list[i]
|
2013-08-23 04:22:54 +08:00
|
|
|
let code = call(Fn{i}, a:000)
|
2013-08-22 11:12:07 +08:00
|
|
|
if code != 0
|
|
|
|
return code
|
2013-08-18 05:50:41 +08:00
|
|
|
endif
|
|
|
|
endfor
|
|
|
|
return 0
|
|
|
|
endfunction
|
|
|
|
endif
|
2018-03-19 22:58:50 +08:00
|
|
|
|
|
|
|
" Compatibility wrapper for strchars, in case this vim version does not
|
|
|
|
" have it natively
|
|
|
|
function! airline#util#strchars(str)
|
2019-08-21 04:20:39 +08:00
|
|
|
if s:has_strchars
|
2018-03-19 22:58:50 +08:00
|
|
|
return strchars(a:str)
|
|
|
|
else
|
|
|
|
return strlen(substitute(a:str, '.', 'a', 'g'))
|
|
|
|
endif
|
|
|
|
endfunction
|
2018-05-12 04:22:46 +08:00
|
|
|
|
2019-07-30 18:32:39 +08:00
|
|
|
function! airline#util#strcharpart(...)
|
2019-08-21 04:22:06 +08:00
|
|
|
if s:has_strcharpart
|
2019-07-30 18:32:39 +08:00
|
|
|
return call('strcharpart', a:000)
|
|
|
|
else
|
|
|
|
" does not handle multibyte chars :(
|
|
|
|
return a:1[(a:2):(a:3)]
|
|
|
|
endif
|
|
|
|
endfunction
|
|
|
|
|
2018-05-12 04:22:46 +08:00
|
|
|
function! airline#util#ignore_buf(name)
|
|
|
|
let pat = '\c\v'. get(g:, 'airline#ignore_bufadd_pat', '').
|
|
|
|
\ get(g:, 'airline#extensions#tabline#ignore_bufadd_pat',
|
2019-08-26 21:16:38 +08:00
|
|
|
\ '!|defx|gundo|nerd_tree|startify|tagbar|term://|undotree|vimfiler')
|
2018-05-12 04:22:46 +08:00
|
|
|
return match(a:name, pat) > -1
|
|
|
|
endfunction
|
2018-06-04 23:31:13 +08:00
|
|
|
|
|
|
|
function! airline#util#has_fugitive()
|
2019-08-21 04:23:19 +08:00
|
|
|
if !exists("s:has_fugitive")
|
|
|
|
let s:has_fugitive = exists('*fugitive#head') || exists('*FugitiveHead')
|
|
|
|
endif
|
|
|
|
return s:has_fugitive
|
2018-06-04 23:31:13 +08:00
|
|
|
endfunction
|
|
|
|
|
2019-12-10 15:19:23 +08:00
|
|
|
function! airline#util#has_gina()
|
|
|
|
if !exists("s:has_gina")
|
2019-12-17 18:08:08 +08:00
|
|
|
let s:has_gina = (exists(':Gina') && v:version >= 800)
|
2019-12-10 15:19:23 +08:00
|
|
|
endif
|
|
|
|
return s:has_gina
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
|
2018-06-04 23:31:13 +08:00
|
|
|
function! airline#util#has_lawrencium()
|
2019-08-21 04:24:08 +08:00
|
|
|
if !exists("s:has_lawrencium")
|
|
|
|
let s:has_lawrencium = exists('*lawrencium#statusline')
|
|
|
|
endif
|
|
|
|
return s:has_lawrencium
|
2018-06-04 23:31:13 +08:00
|
|
|
endfunction
|
|
|
|
|
|
|
|
function! airline#util#has_vcscommand()
|
2019-08-21 04:30:20 +08:00
|
|
|
if !exists("s:has_vcscommand")
|
|
|
|
let s:has_vcscommand = exists('*VCSCommandGetStatusLine')
|
|
|
|
endif
|
|
|
|
return get(g:, 'airline#extensions#branch#use_vcscommand', 0) && s:has_vcscommand
|
2018-06-04 23:31:13 +08:00
|
|
|
endfunction
|
|
|
|
|
|
|
|
function! airline#util#has_custom_scm()
|
|
|
|
return !empty(get(g:, 'airline#extensions#branch#custom_head', ''))
|
|
|
|
endfunction
|
2018-09-25 22:03:30 +08:00
|
|
|
|
|
|
|
function! airline#util#doautocmd(event)
|
2021-05-03 11:44:45 +08:00
|
|
|
if !exists('#airline') && a:event !=? 'AirlineToggledOff'
|
2021-04-30 19:25:26 +08:00
|
|
|
" airline disabled
|
|
|
|
return
|
|
|
|
endif
|
2018-09-25 22:03:30 +08:00
|
|
|
exe printf("silent doautocmd %s User %s", s:nomodeline, a:event)
|
2018-11-14 03:47:41 +08:00
|
|
|
endfunction
|
2018-11-14 05:14:13 +08:00
|
|
|
|
|
|
|
function! airline#util#themes(match)
|
2021-05-03 04:52:45 +08:00
|
|
|
let files = split(globpath(&rtp, 'autoload/airline/themes/'.a:match.'*.vim', 1), "\n")
|
2020-01-30 20:42:21 +08:00
|
|
|
return sort(map(files, 'fnamemodify(v:val, ":t:r")') + ('random' =~ a:match ? ['random'] : []))
|
2018-11-14 05:14:13 +08:00
|
|
|
endfunction
|
2019-12-13 16:59:45 +08:00
|
|
|
|
2019-12-22 19:06:35 +08:00
|
|
|
function! airline#util#stl_disabled(winnr)
|
2019-12-13 16:59:45 +08:00
|
|
|
" setting the statusline is disabled,
|
2019-12-22 20:26:59 +08:00
|
|
|
" either globally, per window, or per buffer
|
2019-12-13 16:59:45 +08:00
|
|
|
" w:airline_disabled is deprecated!
|
|
|
|
return get(g:, 'airline_disable_statusline', 0) ||
|
2019-12-22 19:06:35 +08:00
|
|
|
\ airline#util#getwinvar(a:winnr, 'airline_disable_statusline', 0) ||
|
2019-12-22 20:26:59 +08:00
|
|
|
\ airline#util#getwinvar(a:winnr, 'airline_disabled', 0) ||
|
|
|
|
\ airline#util#getbufvar(winbufnr(a:winnr), 'airline_disable_statusline', 0)
|
2019-12-13 16:59:45 +08:00
|
|
|
endfunction
|
2020-01-28 22:54:00 +08:00
|
|
|
|
2020-01-29 03:58:45 +08:00
|
|
|
function! airline#util#ignore_next_focusgain()
|
2020-02-14 06:29:33 +08:00
|
|
|
if has('win32')
|
|
|
|
" Setup an ignore for platforms that trigger FocusLost on calls to
|
|
|
|
" system(). macvim (gui and terminal) and Linux terminal vim do not.
|
|
|
|
let s:focusgained_ignore_time = localtime()
|
|
|
|
endif
|
2020-01-28 22:54:00 +08:00
|
|
|
endfunction
|
|
|
|
|
2020-01-29 03:58:45 +08:00
|
|
|
function! airline#util#try_focusgained()
|
2020-02-14 06:29:33 +08:00
|
|
|
" Ignore lasts for at most one second and is cleared on the first
|
|
|
|
" focusgained. We use ignore to prevent system() calls from triggering
|
|
|
|
" FocusGained (which occurs 100% on win32 and seem to sometimes occur under
|
|
|
|
" tmux).
|
|
|
|
let dt = localtime() - s:focusgained_ignore_time
|
|
|
|
let s:focusgained_ignore_time = 0
|
|
|
|
return dt >= 1
|
2020-01-28 22:54:00 +08:00
|
|
|
endfunction
|
2020-01-29 03:58:45 +08:00
|
|
|
|