Show current buffers in the middle of the tabline (bling/vim-airline#222)

This commit is contained in:
Markus Koller 2013-09-21 20:13:19 +02:00
parent 7d78fbf2cc
commit 3cc1dcb697

View File

@ -17,9 +17,6 @@ let s:builder_context = {
let s:buf_min_count = get(g:, 'airline#extensions#tabline#buffer_min_count', 0) let s:buf_min_count = get(g:, 'airline#extensions#tabline#buffer_min_count', 0)
let s:tab_min_count = get(g:, 'airline#extensions#tabline#tab_min_count', 0) let s:tab_min_count = get(g:, 'airline#extensions#tabline#tab_min_count', 0)
" TODO: temporary
let s:buf_max = get(g:, 'airline#extensions#tabline#buffer_max', winwidth(0) / 24)
function! airline#extensions#tabline#init(ext) function! airline#extensions#tabline#init(ext)
if has('gui_running') if has('gui_running')
set guioptions-=e set guioptions-=e
@ -103,18 +100,59 @@ function! s:get_buffer_list()
endif endif
endfor endfor
" TODO: temporary fix; force the active buffer to be first when there are many buffers open let s:current_buffer_list = buffers
if len(buffers) > s:buf_max && index(buffers, cur) > -1 return buffers
while buffers[1] != cur endfunction
let first = remove(buffers, 0)
call add(buffers, first) function! s:get_visible_buffers()
endwhile let buffers = s:get_buffer_list()
let buffers = buffers[:s:buf_max] let cur = bufnr('%')
call insert(buffers, -1, 0)
call add(buffers, -1) let total_width = 0
let max_width = 0
for nr in buffers
" TODO: get this information from the builder?
let width = len(airline#extensions#tabline#get_buffer_name(nr)) + 4
let total_width += width
let max_width = max([max_width, width])
endfor
" only show current and surrounding buffers if there are too many buffers
if total_width > winwidth(0) && index(buffers, cur) > -1
let buf_count = len(buffers)
let position = index(buffers, cur)
" determine how many buffers to show based on the longest buffer width,
" use one on the right side and put the rest on the left
let buf_max = winwidth(0) / max_width
let buf_right = 1
let buf_left = max([0, buf_max - buf_right])
let start = max([0, position - buf_left])
let end = min([buf_count, position + buf_right])
" fill up available space on the right
if position < buf_left
let end += (buf_left - position)
endif
" fill up available space on the left
if end > buf_count - 1 - buf_right
let start -= max([0, buf_right - (buf_count - 1 - position)])
endif
let buffers = eval('buffers[' . start . ':' . end . ']')
if start > 0
call insert(buffers, -1, 0)
endif
if end < buf_count - 1
call add(buffers, -1)
endif
endif endif
let s:current_buffer_list = buffers
return buffers return buffers
endfunction endfunction
@ -122,7 +160,7 @@ function! s:get_buffers()
let b = airline#builder#new(s:builder_context) let b = airline#builder#new(s:builder_context)
let cur = bufnr('%') let cur = bufnr('%')
let tab_bufs = tabpagebuflist(tabpagenr()) let tab_bufs = tabpagebuflist(tabpagenr())
for nr in s:get_buffer_list() for nr in s:get_visible_buffers()
if nr < 0 if nr < 0
call b.add_raw('%#airline_tabhid#...') call b.add_raw('%#airline_tabhid#...')
continue continue