Refactoring: show_dir and show_files

This de-duplicates the shared code, and adds some (first) improvements
to not stat all of v:oldfiles (twice).

If accepted, it allows for easily adding a cache for abs_path handling
etc.

 - Add _show_filtered_oldfiles and _get_filtered_oldfiles
 - Fixes g:startify_files_number<1
This commit is contained in:
Daniel Hahler 2014-11-22 14:23:39 +01:00 committed by Marco Hinz
parent f86d604915
commit 1b6b53f2f9

View file

@ -369,72 +369,20 @@ function! startify#open_buffers() abort
endif
endfunction
" Function: s:show_dir {{{1
function! s:show_dir(cnt) abort
if empty(v:oldfiles)
return a:cnt
endif
let cnt = a:cnt
let num = s:numfiles
" Function: s:_get_filtered_oldfiles {{{1
function! s:_get_filtered_oldfiles(num, prefix)
let num = a:num
let filter_prefix = len(a:prefix) > 0
let entries = {}
let cwd = escape(getcwd(), '\')
let files = filter(map(copy(v:oldfiles),
\ 'glob(fnameescape(fnamemodify(resolve(v:val), ":p")))'), 'match(v:val, cwd) == 0')
let files = []
if !empty(files)
if exists('s:last_message')
call s:print_section_header()
for fname in copy(v:oldfiles)
if num <= 0
break
endif
for abs_path in files
let abs_path = glob(abs_path)
" filter duplicates, bookmarks and entries from the skiplist
if has_key(entries, abs_path)
\ || !filereadable(abs_path)
\ || s:is_in_skiplist(abs_path)
\ || (exists('g:startify_bookmarks') && s:is_bookmark(abs_path))
continue
endif
let entries[abs_path] = 1
let index = s:get_index_as_string(cnt)
let display_path = fnamemodify(abs_path, s:relative_path ? ':.' : ':p:~')
call append('$', ' ['. index .']'. repeat(' ', (3 - strlen(index))) . display_path)
execute 'nnoremap <buffer><silent>' index ':edit' escape(abs_path, ' ') '<bar> call <sid>check_user_options()<cr>'
let cnt += 1
let num -= 1
if !num
break
endif
endfor
call append('$', '')
endif
return cnt
endfunction
" Function: s:show_files {{{1
function! s:show_files(cnt) abort
if empty(v:oldfiles)
return a:cnt
endif
if exists('s:last_message')
call s:print_section_header()
endif
let cnt = a:cnt
let num = s:numfiles
let entries = {}
for fname in v:oldfiles
let abs_path = glob(fnameescape(fnamemodify(resolve(fname), ':p')))
let abs_path = glob(fnameescape(fnamemodify(resolve(fname), ":p")))
" filter duplicates, bookmarks and entries from the skiplist
if has_key(entries, abs_path)
@ -444,26 +392,54 @@ function! s:show_files(cnt) abort
continue
endif
let entries[abs_path] = 1
let index = s:get_index_as_string(cnt)
let display_path = fnamemodify(abs_path, s:relative_path ? ':.' : ':p:~')
call append('$', ' ['. index .']'. repeat(' ', (3 - strlen(index))) . display_path)
execute 'nnoremap <buffer><silent>' index ':edit' escape(abs_path, ' ') '<bar> call <sid>check_user_options()<cr>'
let cnt += 1
let num -= 1
if !num
break
if filter_prefix && match(abs_path, a:prefix) != 0
continue
endif
endfor
call append('$', '')
let display_path = fnamemodify(abs_path, s:relative_path ? ':.' : ':p:~')
let entries[abs_path] = 1
let files += [[abs_path, display_path]]
let num -= 1
endfor
return files
endfun
" Function: s:_show_filtered_oldfiles {{{1
function! s:_show_filtered_oldfiles(cnt, prefix) abort
let cnt = a:cnt
let files = s:_get_filtered_oldfiles(s:numfiles, a:prefix)
if !empty(files)
if exists('s:last_message')
call s:print_section_header()
endif
for [abs_path, display_path] in files
let index = s:get_index_as_string(cnt)
call append('$', ' ['. index .']'. repeat(' ', (3 - strlen(index))) . display_path)
execute 'nnoremap <buffer><silent>' index ':edit' escape(abs_path, ' ') '<bar> call <sid>check_user_options()<cr>'
let cnt += 1
endfor
call append('$', '')
endif
return cnt
endfunction
" Function: s:show_dir {{{1
function! s:show_dir(cnt) abort
let cwd = escape(getcwd(), '\')
return s:_show_filtered_oldfiles(a:cnt, cwd)
endfunction
" Function: s:show_files {{{1
function! s:show_files(cnt) abort
return s:_show_filtered_oldfiles(a:cnt, '')
endfunction
" Function: s:show_sessions {{{1
function! s:show_sessions(cnt) abort
let sfiles = split(globpath(s:session_dir, '*'), '\n')