This plugin makes searching in files easier than ever!
It supports many common grep tools (ag, ack, git grep, ripgrep, pt, findstr and our beloved BSD/GNU grep) out-of-the-box and it is easy to add new ones.
- Using the prompt: Just insert the search query or switch through the available grep tools.
- Using the operator: search for the current visual selection or motion right away or pre-fill the prompt with it.
- Using the pre-defined commands: All supported tools come with their own
command for convenience.
:GrepperAg 'foo bar' test/
does just what you would expect. - Build your own mappings commands: For maximum customization simply use the
:Grepper
command. It is fully configurable using flags that take priority over options defined in your vimrc. Actually, all the default commands like:GrepperAck
etc. a built atop of:Grepper
.
- For fast and simple navigation, all found matches are either put in the quickfix or location list.
- Asynchronous search with Vim and Neovim.
- The operator action is repeatable if vim-repeat is installed.
- Emits an User event when a search finishes, for further customization.
- The exact search command used is put in
w:quickfix_title
which is used by all common statusline plugins.
Don't use plugins just because they provide "Neovim support". Depending on their range of duty, they might "improve" the wrong end of a task.
E.g. vim-gitgutter might have async
Neovim support for getting the output of git diff
, but that one returns almost
instantly anyway. The real bottleneck here is processing that output and setting
the signs using VimL, which still happens synchronously. So, use the plugin
because of its git integration, not because of hyped async support.
Neovim is no panacea (yet).
Use your favorite plugin manager. E.g. vim-plug:
Plug 'mhinz/vim-grepper'
" Optional: used for repeating operator actions via "."
Plug 'tpope/vim-repeat'
For the whole truth: :h grepper
.
Just using :Grepper
will use the default options. It opens a prompt and you
can use <tab>
to switch to another tool. When matches are found, the quickfix
window opens and the cursor jumps there. If the query is empty, the word under
the cursor is used as query.
The quickfix window defines mappings for opening matches in new windows or tabs, with and without jumping to it.
If you're used to the default behaviour of :grep
, not opening the quickfix
window and jumping to the first match, you can change the default options:
" Mimic :grep and make ag the default tool.
let g:grepper = {
\ 'tools': ['ag', 'git', 'grep'],
\ 'open': 0,
\ 'jump': 1,
\ }
Related help:
:h grepper-mappings
:h grepper-options
Create mappings for :Grepper
with different configurations:
nnoremap <leader>git :Grepper -tool git -noswitch<cr>
nnoremap <leader>ag :Grepper -tool ag -grepprg ag --vimgrep -G '^.+\.txt'<cr>
nnoremap <leader>* :Grepper -tool ack -cword -noprompt<cr>
The first two mappings open a prompt whereas the last one will search for the word under the cursor right away.
Related help: :h :Grepper
Build your own commands:
command! -nargs=* -complete=file GG Grepper -tool git -query <args>
command! -nargs=* Ag Grepper -noprompt -tool ag -grepprg ag --vimgrep <args> %
Now :GG 'foo bar' *.txt
would search all text files for the string "foo bar"
and :Ag foo
would search for "foo", but only in the current file. (Vim will
replace %
in a command with the buffer name.)
Use grepper on motions or visual selections by using the operator:
nmap gs <plug>(GrepperOperator)
xmap gs <plug>(GrepperOperator)
Afterwards gs
in visual mode will simply pre-fill the prompt with the current
visual selection.
You can also use motions to prepopulate the prompt, e.g. gs$
or gsiw
.
NOTE: If you use the operator, Grepper assumes you want to search for the
exact selected text, so it gets properly escaped according to the used grep
tool. E.g. using the operator on .*
will actually search for these 2
characters instead of "everything".
Related help: :h grepper-operator
If you like my plugins, please star them on Github. It's a great way of getting feedback. Same goes for issues reports or feature requests.
Contact: Twitter
Get your Vim on!