Improve the new approach

Works better but there seems to be a difference when selecting an entry by
mapping and by hitting <cr>.
This commit is contained in:
Marco Hinz 2013-07-26 01:53:34 +02:00
parent 34ba64ca88
commit 7189c4bdef

View file

@ -23,25 +23,22 @@ let s:show_sessions = get(g:, 'startify_show_sessions', 1)
function! startify#insane_in_the_membrane() abort function! startify#insane_in_the_membrane() abort
if !empty(v:servername) && exists('g:startify_skiplist_server') if !empty(v:servername) && exists('g:startify_skiplist_server')
for servname in g:startify_skiplist_server for servname in g:startify_skiplist_server
if (servname == v:servername) if servname == v:servername
return return
endif endif
endfor endfor
endif endif
enew enew
setfiletype startify setfiletype startify
"silent file startify
"setlocal buftype=nofile setlocal buftype=nofile
"setlocal bufhidden=wipe setlocal bufhidden=wipe
setlocal nobuflisted setlocal nobuflisted
setlocal noswapfile setlocal noswapfile
"setlocal nonumber nolist statusline=\ %t
setlocal nonumber nolist statusline=\ startify setlocal nonumber nolist statusline=\ startify
if (v:version >= 703) if v:version >= 703
setlocal norelativenumber setlocal norelativenumber
endif endif
@ -82,17 +79,12 @@ function! startify#insane_in_the_membrane() abort
nnoremap <buffer><silent> e :enew<cr> nnoremap <buffer><silent> e :enew<cr>
nnoremap <buffer><silent> i :enew <bar> startinsert<cr> nnoremap <buffer><silent> i :enew <bar> startinsert<cr>
nnoremap <buffer><silent> b :call <SID>set_mark('B')<cr> nnoremap <buffer><silent> b :call <sid>set_mark('B')<cr>
nnoremap <buffer><silent> s :call <SID>set_mark('S')<cr> nnoremap <buffer><silent> s :call <sid>set_mark('S')<cr>
nnoremap <buffer><silent> v :call <SID>set_mark('V')<cr> nnoremap <buffer><silent> v :call <sid>set_mark('V')<cr>
nnoremap <buffer> <cr> :call <SID>open_buffers(expand('<cword>'))<cr> nnoremap <buffer> <cr> :call <sid>open_buffers(expand('<cword>'))<cr>
nnoremap <buffer> <2-LeftMouse> :execute 'normal '. matchstr(getline('.'), '\w\+')<cr> nnoremap <buffer> <2-LeftMouse> :execute 'normal' matchstr(getline('.'), '\w\+')<cr>
nnoremap <buffer><silent> q nnoremap <buffer><silent> q :call <sid>close()<cr>
\ :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') if exists('g:startify_empty_buffer_key')
execute 'nnoremap <buffer><silent> '. g:startify_empty_buffer_key .' :enew<cr>' execute 'nnoremap <buffer><silent> '. g:startify_empty_buffer_key .' :enew<cr>'
@ -100,8 +92,6 @@ function! startify#insane_in_the_membrane() abort
autocmd! startify * autocmd! startify *
autocmd startify CursorMoved <buffer> call s:set_cursor() autocmd startify CursorMoved <buffer> call s:set_cursor()
"autocmd startify BufLeave <buffer> autocmd! startify *
"autocmd startify WinLeave <buffer> bd
call cursor((s:show_special ? 4 : 2) + s:offset_header, 5) call cursor((s:show_special ? 4 : 2) + s:offset_header, 5)
endfunction endfunction
@ -364,26 +354,46 @@ endfunction
" Function: s:open_buffers {{{1 " Function: s:open_buffers {{{1
function! s:open_buffers(cword) abort function! s:open_buffers(cword) abort
let id = bufnr('%') enew
if exists('s:marked') && !empty(s:marked) if exists('s:marked') && !empty(s:marked)
for i in range(len(s:marked)) for i in range(len(s:marked))
for val in values(s:marked) for val in values(s:marked)
if val[0] == i if val[0] == i
if val[3] == 'S' if val[3] == 'S'
execute 'split '. val[2] if line2byte('$') == -1
execute 'edit' val[2]
else
execute 'split' val[2]
endif
elseif val[3] == 'V' elseif val[3] == 'V'
execute 'vsplit '. val[2] if line2byte('$') == -1
execute 'edit' val[2]
else
execute 'vsplit' val[2]
endif
else else
execute 'edit '. val[2] execute 'edit' val[2]
endif endif
continue continue
endif endif
endfor endfor
endfor endfor
else else
execute 'normal '. a:cword execute 'normal' a:cword
endif
endfunction
" Function: s:close {{{1
function! s:close() abort
if len(filter(range(0, bufnr('$')), 'buflisted(v:val)'))
if bufloaded(bufnr('#'))
b #
else
bn
endif
else
quit
endif endif
execute 'silent bdelete' id
endfunction endfunction
" Function: s:get_index_as_string {{{1 " Function: s:get_index_as_string {{{1