
Before this change the Startify buffer didn't close if only split actions ('s' and 'v') were used to open files.
322 lines
9.9 KiB
VimL
322 lines
9.9 KiB
VimL
" Plugin: https://github.com/mhinz/vim-startify
|
|
" Description: Start screen displaying recently used stuff.
|
|
" Maintainer: Marco Hinz <http://github.com/mhinz>
|
|
" Version: 1.6
|
|
|
|
if exists('g:autoloaded_startify') || &cp
|
|
finish
|
|
endif
|
|
let g:autoloaded_startify = 1
|
|
|
|
let s:session_dir = resolve(expand(get(g:, 'startify_session_dir',
|
|
\ has('win32') ? '$HOME\vimfiles\session' : '~/.vim/session')))
|
|
|
|
" Function: startify#insane_in_the_membrane {{{1
|
|
function! startify#insane_in_the_membrane() abort
|
|
if !empty(v:servername) && exists('g:startify_skiplist_server')
|
|
for servname in g:startify_skiplist_server
|
|
if (servname == v:servername)
|
|
return
|
|
endif
|
|
endfor
|
|
endif
|
|
setlocal nonumber noswapfile bufhidden=wipe
|
|
if (v:version >= 703)
|
|
setlocal norelativenumber
|
|
endif
|
|
setfiletype startify
|
|
|
|
let special = get(g:, 'startify_enable_special', 1)
|
|
let sep = startify#get_separator()
|
|
let cnt = 0
|
|
|
|
if special
|
|
call append('$', ' [e] <empty buffer>')
|
|
endif
|
|
|
|
if get(g:, 'startify_show_files', 1) && !empty(v:oldfiles)
|
|
let entries = {}
|
|
let numfiles = get(g:, 'startify_show_files_number', 10)
|
|
if special
|
|
call append('$', '')
|
|
endif
|
|
for fname in v:oldfiles
|
|
let expfname = resolve(fnamemodify(fname, ':p'))
|
|
" filter duplicates, bookmarks and entries from the skiplist
|
|
if has_key(entries, expfname) ||
|
|
\ !filereadable(expfname) ||
|
|
\ (exists('g:startify_skiplist') && s:is_in_skiplist(expfname)) ||
|
|
\ (exists('g:startify_bookmarks') && s:is_bookmark(expfname))
|
|
continue
|
|
endif
|
|
let entries[expfname] = 1
|
|
let index = s:get_index_as_string(cnt)
|
|
call append('$', ' ['. index .']'. repeat(' ', (3 - strlen(index))) . fname)
|
|
execute 'nnoremap <buffer> '. index .' :edit '. s:escape(fname) .' <bar> lcd %:h<cr>'
|
|
let cnt += 1
|
|
if (cnt == numfiles)
|
|
break
|
|
endif
|
|
endfor
|
|
endif
|
|
|
|
let sfiles = split(globpath(s:session_dir, '*'), '\n')
|
|
|
|
if get(g:, 'startify_show_sessions', 1) && !empty(sfiles)
|
|
call append('$', '')
|
|
for i in range(len(sfiles))
|
|
let idx = (i + cnt)
|
|
let index = s:get_index_as_string(idx)
|
|
call append('$', ' ['. index .']'. repeat(' ', (3 - strlen(index))) . fnamemodify(sfiles[i], ':t:r'))
|
|
execute 'nnoremap <buffer> '. index .' :source '. s:escape(sfiles[i]) .'<cr>'
|
|
endfor
|
|
let cnt = idx
|
|
endif
|
|
|
|
if exists('g:startify_bookmarks')
|
|
call append('$', '')
|
|
for fname in g:startify_bookmarks
|
|
let cnt += 1
|
|
let index = s:get_index_as_string(cnt)
|
|
call append('$', ' ['. index .']'. repeat(' ', (3 - strlen(index))) . fname)
|
|
execute 'nnoremap <buffer> '. index .' :edit '. s:escape(fname) .' <bar> lcd %:h<cr>'
|
|
endfor
|
|
endif
|
|
|
|
if special
|
|
call append('$', ['', ' [q] <quit>'])
|
|
endif
|
|
|
|
setlocal nomodifiable nomodified
|
|
|
|
nnoremap <buffer><silent> e :enew<cr>
|
|
nnoremap <buffer><silent> i :enew <bar> startinsert<cr>
|
|
nnoremap <buffer><silent> b :call <SID>set_mark('B')<cr>
|
|
nnoremap <buffer><silent> s :call <SID>set_mark('S')<cr>
|
|
nnoremap <buffer><silent> v :call <SID>set_mark('V')<cr>
|
|
nnoremap <buffer> <cr> :call <SID>open_buffers(expand('<cword>'))<cr>
|
|
nnoremap <buffer> <2-LeftMouse> :execute 'normal '. matchstr(getline('.'), '\w\+')<cr>
|
|
nnoremap <buffer> q
|
|
\ :if (len(filter(range(0, bufnr('$')), 'buflisted(v:val)')) > 1) <bar>
|
|
\ bd <bar>
|
|
\ else <bar>
|
|
\ quit <bar>
|
|
\ endif<cr>
|
|
|
|
if exists('g:startify_empty_buffer_key')
|
|
execute 'nnoremap <buffer><silent> '. g:startify_empty_buffer_key .' :enew<cr>'
|
|
endif
|
|
|
|
autocmd! startify *
|
|
autocmd startify CursorMoved <buffer> call s:set_cursor()
|
|
autocmd startify BufLeave <buffer> autocmd! startify *
|
|
autocmd startify WinLeave <buffer> bd
|
|
|
|
call cursor(special ? 4 : 2, 5)
|
|
endfunction
|
|
|
|
" Function: startify#session_delete {{{1
|
|
function! startify#session_delete(...) abort
|
|
if !isdirectory(s:session_dir)
|
|
echo 'The session directory does not exist: '. s:session_dir
|
|
return
|
|
elseif empty(startify#session_list_as_string(''))
|
|
echo 'There are no sessions...'
|
|
return
|
|
endif
|
|
let spath = s:session_dir . startify#get_separator() . (exists('a:1')
|
|
\ ? a:1
|
|
\ : input('Delete this session: ', fnamemodify(v:this_session, ':t'), 'custom,startify#session_list_as_string'))
|
|
\ | redraw
|
|
echo 'Really delete '. spath .'? [y/n]' | redraw
|
|
if (nr2char(getchar()) == 'y')
|
|
if delete(spath) == 0
|
|
echo 'Deleted session '. spath .'!'
|
|
else
|
|
echo 'Deletion failed!'
|
|
endif
|
|
else
|
|
echo 'Deletion aborted!'
|
|
endif
|
|
endfunction
|
|
|
|
" Function: startify#session_save {{{1
|
|
function! startify#session_save(...) abort
|
|
if !isdirectory(s:session_dir)
|
|
if exists('*mkdir')
|
|
echo 'The session directory does not exist: '. s:session_dir .'. Create it? [y/n]' | redraw
|
|
if (nr2char(getchar()) == 'y')
|
|
call mkdir(s:session_dir, 'p')
|
|
else
|
|
echo
|
|
return
|
|
endif
|
|
else
|
|
echo 'The session directory does not exist: '. s:session_dir
|
|
return
|
|
endif
|
|
endif
|
|
if exists('a:1')
|
|
let sname = a:1
|
|
else
|
|
let sname = input('Save under this session name: ', fnamemodify(v:this_session, ':t'), 'custom,startify#session_list_as_string')
|
|
redraw
|
|
if empty(sname)
|
|
echo 'You gave an empty name!'
|
|
return
|
|
endif
|
|
endif
|
|
let spath = s:session_dir . startify#get_separator() . sname
|
|
if !filereadable(spath)
|
|
execute 'mksession '. s:escape(spath) | echo 'Session saved under: '. spath
|
|
return
|
|
endif
|
|
echo 'Session already exists. Overwrite? [y/n]' | redraw
|
|
if nr2char(getchar()) == 'y'
|
|
execute 'mksession! '. s:escape(spath) | echo 'Session saved under: '. spath
|
|
else
|
|
echo 'Did NOT save the session!'
|
|
endif
|
|
endfunction
|
|
|
|
" Function: startify#session_load {{{1
|
|
function! startify#session_load(...) abort
|
|
if !isdirectory(s:session_dir)
|
|
echo 'The session directory does not exist: '. s:session_dir
|
|
return
|
|
elseif empty(startify#session_list_as_string(''))
|
|
echo 'There are no sessions...'
|
|
return
|
|
endif
|
|
let spath = s:session_dir . startify#get_separator() . (exists('a:1')
|
|
\ ? a:1
|
|
\ : input('Load this session: ', fnamemodify(v:this_session, ':t'), 'custom,startify#session_list_as_string'))
|
|
\ | redraw
|
|
if filereadable(spath)
|
|
execute 'source '. s:escape(spath)
|
|
else
|
|
echo 'No such file: '. spath
|
|
endif
|
|
endfunction
|
|
|
|
" Function: startify#session_list {{{1
|
|
function! startify#session_list(lead, ...) abort
|
|
return map(split(globpath(s:session_dir, '*'.a:lead.'*'), '\n'), 'fnamemodify(v:val, ":t")')
|
|
endfunction
|
|
|
|
" Function: startify#session_list_as_string {{{1
|
|
function! startify#session_list_as_string(lead, ...) abort
|
|
return join(map(split(globpath(s:session_dir, '*'.a:lead.'*'), '\n'), 'fnamemodify(v:val, ":t")'), "\n")
|
|
endfunction
|
|
|
|
" Function: startify#get_separator {{{1
|
|
function! startify#get_separator() abort
|
|
return !exists('+shellslash') || &shellslash ? '/' : '\'
|
|
endfunction
|
|
|
|
" Function: s:escape {{{1
|
|
function! s:escape(path) abort
|
|
return !exists('+shellslash') || &shellslash ? fnameescape(a:path) : escape(a:path, '\')
|
|
endfunction
|
|
|
|
" Function: s:is_in_skiplist {{{1
|
|
function! s:is_in_skiplist(arg) abort
|
|
for regexp in g:startify_skiplist
|
|
if (a:arg =~# regexp)
|
|
return 1
|
|
endif
|
|
endfor
|
|
endfunction
|
|
|
|
" Function: s:is_bookmark {{{1
|
|
function! s:is_bookmark(arg) abort
|
|
"for foo in filter(map(copy(g:startify_bookmarks), 'resolve(fnamemodify(v:val, ":p"))'), '!isdirectory(v:val)')
|
|
for foo in map(filter(copy(g:startify_bookmarks), '!isdirectory(v:val)'), 'resolve(fnamemodify(v:val, ":p"))')
|
|
if foo == a:arg
|
|
return 1
|
|
endif
|
|
endfor
|
|
endfunction
|
|
|
|
" Function: s:open_buffers {{{1
|
|
function! s:open_buffers(cword) abort
|
|
if exists('s:marked') && !empty(s:marked)
|
|
for i in range(len(s:marked))
|
|
for val in values(s:marked)
|
|
if val[0] == i
|
|
if val[3] == 'S'
|
|
execute 'split '. val[2]
|
|
elseif val[3] == 'V'
|
|
execute 'vsplit '. val[2]
|
|
else
|
|
execute 'edit '. val[2]
|
|
endif
|
|
continue
|
|
endif
|
|
endfor
|
|
endfor
|
|
else
|
|
execute 'normal '. a:cword
|
|
endif
|
|
endfunction
|
|
|
|
" Function: s:set_mark {{{1
|
|
"
|
|
" Markers are saved in the s:marked dict using the follow format:
|
|
" - s:marked[0]: ID (for sorting)
|
|
" - s:marked[1]: what the brackets contained before
|
|
" - s:marked[2]: the actual path
|
|
" - s:marked[3]: type (buffer, split, vsplit)
|
|
"
|
|
function! s:set_mark(type) abort
|
|
if !exists('s:marked')
|
|
let s:marked = {}
|
|
let s:nmarked = 0
|
|
endif
|
|
" matches[1]: content between brackets
|
|
" matches[2]: path
|
|
let matches = matchlist(getline('.'), '\v\[(.*)\]\s+(.*)')
|
|
if matches[2] =~ '\V<empty buffer>\|<quit>' || matches[2] =~ '^\w\+$'
|
|
return
|
|
endif
|
|
setlocal modifiable
|
|
if matches[1] =~ 'B\|S\|V'
|
|
let s:nmarked -= 1
|
|
execute 'normal! ci]'. remove(s:marked, line('.'))[1]
|
|
else
|
|
let s:marked[line('.')] = [s:nmarked, matches[1], matches[2], a:type]
|
|
let s:nmarked += 1
|
|
execute 'normal! ci]'. repeat(a:type, len(matches[1]))
|
|
endif
|
|
setlocal nomodifiable nomodified
|
|
endfunction
|
|
|
|
" Function: s:get_index_as_string {{{1
|
|
function! s:get_index_as_string(idx) abort
|
|
if exists('g:startify_custom_indices')
|
|
let listlen = len(g:startify_custom_indices)
|
|
return (a:idx < listlen) ? g:startify_custom_indices[a:idx] : string(a:idx - listlen)
|
|
else
|
|
return string(a:idx)
|
|
endif
|
|
endfunction
|
|
|
|
" Function: s:set_cursor {{{1
|
|
function! s:set_cursor() abort
|
|
let s:line_old = exists('s:line_new') ? s:line_new : 5
|
|
let s:line_new = line('.')
|
|
if empty(getline(s:line_new))
|
|
if (s:line_new > s:line_old)
|
|
let s:line_new += 1
|
|
call cursor(s:line_new, 5) " going down
|
|
else
|
|
let s:line_new -= 1
|
|
call cursor((s:line_new < 2 ? 2 : s:line_new), 5) " going up
|
|
endif
|
|
else
|
|
call cursor((s:line_new < 2 ? 2 : 0), 5) " hold cursor in column
|
|
endif
|
|
endfunction
|
|
|
|
" vim: et sw=2 sts=2
|