vim 带有模糊搜索的缓冲区
vim sbuffer with fuzzy search
我通常在 vim(或 neovim)中的不同 windows 和选项卡中打开大量文件。要跳转到打开文件的 window,我使用 :sbuffer。为此,我输入了文件名的开头部分并使用 .我想以模糊搜索的方式找到文件的名称。
我怎么看,我按 ,输入一部分文件名,直到看到模糊搜索找到的文件,然后按 。如果文件已经在任何选项卡的 window 中打开,vim 将移动到那里而不是在实际的 window.
中打开它
您知道如何使用任何模糊搜索插件实现这一目标吗?我不担心文件未打开时的行为,因为通常我会在打开文件时手动处理拆分。
谢谢!
我个人使用 FZF plugin 进行所有模糊搜索。
这里有一段代码可以实现您的要求:
set switchbuf=useopen,usetab
function! HandleFZFSink(filename)
echo a:filename
try
exe "sbuffer " . a:filename
catch
exe "edit " . a:filename
endtry
endfunction
function! FZFTmp()
let cmd = 'ls --color=never 2> /dev/null'
silent! exe fzf#run({'source': cmd, 'sink': function('HandleFZFSink'), 'down':'40%'})
endfunction
nnoremap <silent> , :<C-u>call FZFTmp()<CR>
Fzf
可能是您最好的选择之一。
fzf.vim and fzf.
两者都需要
此外,fzf vim 在 fzf 主仓库中有一个 readme(是的...)。
我不记得我是在哪里找到这个的,但这是我从某处的 Fzf 手册中复制的配置(它只是稍微调整了一下):
let g:fzf_command_prefix = 'Fzf'
let g:fzf_buffers_jump = 1 " [Buffers] to existing split
function! s:build_location_list(lines) abort
call setloclist(0, map(copy(a:lines), '{ "filename": v:val }'))
lopen
endfunction
function! s:build_quickfix_list(lines) abort
call setqflist(map(copy(a:lines), '{ "filename": v:val }'))
copen
endfunction
" An action can be a reference to a function that processes selected lines
let g:fzf_action = {
\ 'ctrl-l': function('s:build_quickfix_list'),
\ 'ctrl-r': function('s:build_location_list'),
\ 'ctrl-t': 'tab split',
\ 'ctrl-x': 'split',
\ 'ctrl-v': 'vsplit'}
" \ 'ctrl-o': '<S-tab>',
" \ 'ctrl-i': 'insert_match',
" function! s:insert_match(lines) abort
" <c-r>=echo('a:lines')<cr>
" endfunction
nnoremap <leader>ff :FzfFiles $HOME<cr>
nnoremap <leader><c-f> :FzfFiles .<cr>
nnoremap <leader>F :FzfFiles /<cr>
nnoremap <leader>fb :FzfBuffers<cr>
nnoremap <leader>b :FzfBuffers<cr>
nnoremap <leader>fw :FzfWindows<cr>
nnoremap <leader>ft :FzfTags<cr>
nnoremap <leader>f<c-t> :FzfBTags<cr>
nnoremap <leader>fc :FzfCommit<cr>
nnoremap <leader>f<c-c> :FzfBCommit<cr>
nnoremap <leader>fg :FzfGFiles?<cr>
nnoremap <leader>f<c-g> :FzfGFiles<cr>
nnoremap <leader>fl :FzfLines<cr>
nnoremap <leader>f<c-l> :FzfBLines<cr>
nnoremap <leader>f; :FzfHistory:<cr>
nnoremap <leader>f/ :FzfHistory/<cr>
nnoremap <leader>fh :FzfHistory<cr>
nnoremap <leader>fm :FzfHelptags<cr>
nnoremap <leader>fs <esc>:FzfSnippets<cr>
nnoremap <leader>fr <esc>:Rg<cr>
inoremap <c-x><c-s> <c-o>:FzfSnippets<cr>
" Enable per-command history.
" CTRL-N and CTRL-P will be automatically bound to next-history and
" previous-history instead of down and up. If you don't like the change,
" explicitly bind the keys to down and up in your $FZF_DEFAULT_OPTS.
let g:fzf_history_dir = '~/.local/share/fzf-history'
let g:fzf_tags_command = 'ctags -R'
" Border color
let g:fzf_layout = {'up':'~90%', 'window': { 'width': 0.8, 'height': 0.8,'yoffset':0.5,'xoffset': 0.5, 'highlight': 'Todo', 'border': 'rounded' } }
let $FZF_DEFAULT_OPTS = '--layout=reverse --info=inline --bind "ctrl-o:toggle+up,ctrl-space:toggle-preview"'
let $FZF_DEFAULT_COMMAND="rg --files --hidden --glob '!.git/**'"
"-g '!{node_modules,.git}'
" Customize fzf colors to match your color scheme
let g:fzf_colors =
\ { 'fg': ['fg', 'Normal'],
\ 'bg': ['bg', 'Normal'],
\ 'gutter': ['bg', 'Normal'],
\ 'hl': ['fg', 'Comment'],
\ 'fg+': ['fg', 'CursorLine', 'CursorColumn', 'Normal'],
\ 'bg+': ['bg', 'Visual', 'CursorColumn'],
\ 'hl+': ['fg', 'Statement'],
\ 'info': ['fg', 'PreProc'],
\ 'border': ['fg', 'vertsplit'],
\ 'prompt': ['fg', 'Conditional'],
\ 'pointer': ['fg', 'Exception'],
\ 'marker': ['fg', 'Keyword'],
\ 'spinner': ['fg', 'Label'],
\ 'header': ['fg', 'Comment'] }
" \ 'border': ['fg', 'Conditional'],
"Get Files
command! -bang -nargs=? -complete=dir Files
\ call fzf#vim#files(<q-args>, fzf#vim#with_preview({'options': ['--layout=reverse', '--info=inline']}), <bang>0)
" Get text in files with Rg
command! -bang -nargs=* Rg
\ call fzf#vim#grep(
\ "rg --column --line-number --no-heading --color=always --smart-case --glob '!.git/**' ".shellescape(<q-args>), 1,
\ fzf#vim#with_preview(), <bang>0)
" Ripgrep advanced
function! RipgrepFzf(query, fullscreen) abort
let command_fmt = 'rg --column --line-number --no-heading --color=always --smart-case %s || true'
let initial_command = printf(command_fmt, shellescape(a:query))
let reload_command = printf(command_fmt, '{q}')
let spec = {'options': ['--phony', '--query', a:query, '--bind', 'change:reload:'.reload_command]}
call fzf#vim#grep(initial_command, 1, fzf#vim#with_preview(spec), a:fullscreen)
endfunction
command! -nargs=* -bang RG call RipgrepFzf(<q-args>, <bang>0)
" Git grep
command! -bang -nargs=* GGrep
\ call fzf#vim#grep(
\ 'git grep --line-number '.shellescape(<q-args>), 0,
\ fzf#vim#with_preview({'dir': systemlist('git rev-parse --show-toplevel')[0]}), <bang>0)
我只是稍微调整了一下,但你可能会喜欢它,因为它是 set switchbuf=usetab
(或 useopen)的 fzf 范例。它允许 Vim 在缓冲区已经打开的地方使用 window 而不是在当前 window.
中打开它
let g:fzf_buffers_jump = 1 " [Buffers] to existing split
希望对您有所帮助!
我通常在 vim(或 neovim)中的不同 windows 和选项卡中打开大量文件。要跳转到打开文件的 window,我使用 :sbuffer。为此,我输入了文件名的开头部分并使用 .我想以模糊搜索的方式找到文件的名称。
我怎么看,我按 ,输入一部分文件名,直到看到模糊搜索找到的文件,然后按 。如果文件已经在任何选项卡的 window 中打开,vim 将移动到那里而不是在实际的 window.
中打开它您知道如何使用任何模糊搜索插件实现这一目标吗?我不担心文件未打开时的行为,因为通常我会在打开文件时手动处理拆分。
谢谢!
我个人使用 FZF plugin 进行所有模糊搜索。
这里有一段代码可以实现您的要求:
set switchbuf=useopen,usetab
function! HandleFZFSink(filename)
echo a:filename
try
exe "sbuffer " . a:filename
catch
exe "edit " . a:filename
endtry
endfunction
function! FZFTmp()
let cmd = 'ls --color=never 2> /dev/null'
silent! exe fzf#run({'source': cmd, 'sink': function('HandleFZFSink'), 'down':'40%'})
endfunction
nnoremap <silent> , :<C-u>call FZFTmp()<CR>
Fzf
可能是您最好的选择之一。
fzf.vim and fzf.
此外,fzf vim 在 fzf 主仓库中有一个 readme(是的...)。
我不记得我是在哪里找到这个的,但这是我从某处的 Fzf 手册中复制的配置(它只是稍微调整了一下):
let g:fzf_command_prefix = 'Fzf'
let g:fzf_buffers_jump = 1 " [Buffers] to existing split
function! s:build_location_list(lines) abort
call setloclist(0, map(copy(a:lines), '{ "filename": v:val }'))
lopen
endfunction
function! s:build_quickfix_list(lines) abort
call setqflist(map(copy(a:lines), '{ "filename": v:val }'))
copen
endfunction
" An action can be a reference to a function that processes selected lines
let g:fzf_action = {
\ 'ctrl-l': function('s:build_quickfix_list'),
\ 'ctrl-r': function('s:build_location_list'),
\ 'ctrl-t': 'tab split',
\ 'ctrl-x': 'split',
\ 'ctrl-v': 'vsplit'}
" \ 'ctrl-o': '<S-tab>',
" \ 'ctrl-i': 'insert_match',
" function! s:insert_match(lines) abort
" <c-r>=echo('a:lines')<cr>
" endfunction
nnoremap <leader>ff :FzfFiles $HOME<cr>
nnoremap <leader><c-f> :FzfFiles .<cr>
nnoremap <leader>F :FzfFiles /<cr>
nnoremap <leader>fb :FzfBuffers<cr>
nnoremap <leader>b :FzfBuffers<cr>
nnoremap <leader>fw :FzfWindows<cr>
nnoremap <leader>ft :FzfTags<cr>
nnoremap <leader>f<c-t> :FzfBTags<cr>
nnoremap <leader>fc :FzfCommit<cr>
nnoremap <leader>f<c-c> :FzfBCommit<cr>
nnoremap <leader>fg :FzfGFiles?<cr>
nnoremap <leader>f<c-g> :FzfGFiles<cr>
nnoremap <leader>fl :FzfLines<cr>
nnoremap <leader>f<c-l> :FzfBLines<cr>
nnoremap <leader>f; :FzfHistory:<cr>
nnoremap <leader>f/ :FzfHistory/<cr>
nnoremap <leader>fh :FzfHistory<cr>
nnoremap <leader>fm :FzfHelptags<cr>
nnoremap <leader>fs <esc>:FzfSnippets<cr>
nnoremap <leader>fr <esc>:Rg<cr>
inoremap <c-x><c-s> <c-o>:FzfSnippets<cr>
" Enable per-command history.
" CTRL-N and CTRL-P will be automatically bound to next-history and
" previous-history instead of down and up. If you don't like the change,
" explicitly bind the keys to down and up in your $FZF_DEFAULT_OPTS.
let g:fzf_history_dir = '~/.local/share/fzf-history'
let g:fzf_tags_command = 'ctags -R'
" Border color
let g:fzf_layout = {'up':'~90%', 'window': { 'width': 0.8, 'height': 0.8,'yoffset':0.5,'xoffset': 0.5, 'highlight': 'Todo', 'border': 'rounded' } }
let $FZF_DEFAULT_OPTS = '--layout=reverse --info=inline --bind "ctrl-o:toggle+up,ctrl-space:toggle-preview"'
let $FZF_DEFAULT_COMMAND="rg --files --hidden --glob '!.git/**'"
"-g '!{node_modules,.git}'
" Customize fzf colors to match your color scheme
let g:fzf_colors =
\ { 'fg': ['fg', 'Normal'],
\ 'bg': ['bg', 'Normal'],
\ 'gutter': ['bg', 'Normal'],
\ 'hl': ['fg', 'Comment'],
\ 'fg+': ['fg', 'CursorLine', 'CursorColumn', 'Normal'],
\ 'bg+': ['bg', 'Visual', 'CursorColumn'],
\ 'hl+': ['fg', 'Statement'],
\ 'info': ['fg', 'PreProc'],
\ 'border': ['fg', 'vertsplit'],
\ 'prompt': ['fg', 'Conditional'],
\ 'pointer': ['fg', 'Exception'],
\ 'marker': ['fg', 'Keyword'],
\ 'spinner': ['fg', 'Label'],
\ 'header': ['fg', 'Comment'] }
" \ 'border': ['fg', 'Conditional'],
"Get Files
command! -bang -nargs=? -complete=dir Files
\ call fzf#vim#files(<q-args>, fzf#vim#with_preview({'options': ['--layout=reverse', '--info=inline']}), <bang>0)
" Get text in files with Rg
command! -bang -nargs=* Rg
\ call fzf#vim#grep(
\ "rg --column --line-number --no-heading --color=always --smart-case --glob '!.git/**' ".shellescape(<q-args>), 1,
\ fzf#vim#with_preview(), <bang>0)
" Ripgrep advanced
function! RipgrepFzf(query, fullscreen) abort
let command_fmt = 'rg --column --line-number --no-heading --color=always --smart-case %s || true'
let initial_command = printf(command_fmt, shellescape(a:query))
let reload_command = printf(command_fmt, '{q}')
let spec = {'options': ['--phony', '--query', a:query, '--bind', 'change:reload:'.reload_command]}
call fzf#vim#grep(initial_command, 1, fzf#vim#with_preview(spec), a:fullscreen)
endfunction
command! -nargs=* -bang RG call RipgrepFzf(<q-args>, <bang>0)
" Git grep
command! -bang -nargs=* GGrep
\ call fzf#vim#grep(
\ 'git grep --line-number '.shellescape(<q-args>), 0,
\ fzf#vim#with_preview({'dir': systemlist('git rev-parse --show-toplevel')[0]}), <bang>0)
我只是稍微调整了一下,但你可能会喜欢它,因为它是 set switchbuf=usetab
(或 useopen)的 fzf 范例。它允许 Vim 在缓冲区已经打开的地方使用 window 而不是在当前 window.
let g:fzf_buffers_jump = 1 " [Buffers] to existing split
希望对您有所帮助!