Edit pick (bad solution)
This commit is contained in:
parent
f815a09243
commit
7505221c76
1 changed files with 60 additions and 0 deletions
60
vim/vim.symlink/plugin/pick.vim
Normal file
60
vim/vim.symlink/plugin/pick.vim
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
if !exists("g:pick_executable")
|
||||||
|
let g:pick_executable = "pick"
|
||||||
|
endif
|
||||||
|
|
||||||
|
function! PickCommand(choice_command, pick_args, vim_command)
|
||||||
|
try
|
||||||
|
let selection = system(a:choice_command . " | " . g:pick_executable . " " . a:pick_args)
|
||||||
|
redraw!
|
||||||
|
if v:shell_error == 0
|
||||||
|
try
|
||||||
|
exec a:vim_command . " " . selection
|
||||||
|
catch /E325/
|
||||||
|
endtry
|
||||||
|
endif
|
||||||
|
catch /Vim:Interrupt/
|
||||||
|
" Swallow the ^C so that the redraw below happens; otherwise there will be
|
||||||
|
" leftovers from pick on the screen
|
||||||
|
redraw!
|
||||||
|
endtry
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! PickFile()
|
||||||
|
call PickCommand(s:FileListCommand(), "", ":edit")
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! PickFileVerticalSplit()
|
||||||
|
call PickCommand(s:FileListCommand(), "", ":vsplit")
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! PickFileSplit()
|
||||||
|
call PickCommand(s:FileListCommand(), "", ":split")
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! PickFileTab()
|
||||||
|
call PickCommand(s:FileListCommand(), "", ":tabedit")
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! PickBuffer()
|
||||||
|
call PickCommand(s:BufferListCommand(), "", ":buffer")
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! PickTag()
|
||||||
|
call PickCommand(s:TagCommand(), "", ":tag")
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:FileListCommand()
|
||||||
|
return "find * -type f -o -type l"
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:BufferListCommand()
|
||||||
|
let bufnrs = filter(range(1, bufnr("$")), 'buflisted(v:val)')
|
||||||
|
let buffers = map(bufnrs, 'bufname(v:val)')
|
||||||
|
return 'echo "' . join(buffers, "\n") . '"'
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:TagCommand()
|
||||||
|
let l:tag_files = join(split(&tags, ","), " ")
|
||||||
|
|
||||||
|
return "cat " . l:tag_files . " 2> /dev/null | awk -F$'\t' '{print $1}' | sort -u | grep -v '^!'"
|
||||||
|
endfunction
|
Loading…
Add table
Reference in a new issue