2014-04-18 08:58:02 -04:00
|
|
|
# ack.vim
|
2012-08-16 23:41:25 -04:00
|
|
|
|
|
|
|
This plugin is a front for the Perl module
|
|
|
|
[App::Ack](http://search.cpan.org/~petdance/ack/ack). Ack can be used as a
|
|
|
|
replacement for 99% of the uses of _grep_. This plugin will allow you to run
|
|
|
|
ack from vim, and shows the results in a split window.
|
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
## Installation
|
2012-08-16 23:41:25 -04:00
|
|
|
|
|
|
|
### Ack
|
|
|
|
|
2014-07-02 07:18:18 -04:00
|
|
|
You will need the ack(>= 2.0), of course, to install it follow the
|
2014-04-18 08:58:02 -04:00
|
|
|
[manual](http://beyondgrep.com/install/)
|
2013-04-13 13:45:21 -04:00
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
### The Plugin
|
2013-04-13 13:45:21 -04:00
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
To install it is recommended to use one of the popular package managers for Vim,
|
|
|
|
rather than installing by drag and drop all required files into your `.vim` folder.
|
2012-08-16 23:41:25 -04:00
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
#### Manual (not recommended)
|
2012-08-16 23:41:25 -04:00
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
Just
|
|
|
|
[download](https://github.com/mileszs/ack.vim/archive/kb-improve-readme.zip) the
|
|
|
|
plugin and put it in your `~/.vim/`(or `%PROGRAMFILES%/Vim/vimfiles` on windows)
|
2012-08-16 23:41:25 -04:00
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
#### Vundle
|
2012-08-16 23:41:25 -04:00
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
Bundle 'mileszs/ack.vim'
|
2012-08-16 23:41:25 -04:00
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
#### NeoBundle
|
2012-08-16 23:41:25 -04:00
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
NeoBundle 'mileszs/ack.vim'
|
2012-08-16 23:41:25 -04:00
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
## Usage
|
2012-08-16 23:41:25 -04:00
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
:Ack [options] {pattern} [{directories}]
|
2012-08-16 23:41:25 -04:00
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
Search recursively in {directory} (which defaults to the current directory) for
|
|
|
|
the {pattern}.
|
2012-08-16 23:41:25 -04:00
|
|
|
|
|
|
|
Files containing the search term will be listed in the split window, along with
|
|
|
|
the line number of the occurrence, once for each occurrence. [Enter] on a line
|
|
|
|
in this window will open the file, and place the cursor on the matching line.
|
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
Just like where you use :grep, :grepadd, :lgrep, and :lgrepadd, you can use
|
|
|
|
`:Ack`, `:AckAdd`, `:LAck`, and `:LAckAdd` respectively.
|
|
|
|
(See `doc/ack.txt`, or install and `:h Ack` for more information.)
|
2012-08-16 23:41:25 -04:00
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
For more ack options see
|
|
|
|
[ack documentation](http://beyondgrep.com/documentation/)
|
2012-08-16 23:41:25 -04:00
|
|
|
|
2014-04-18 08:58:02 -04:00
|
|
|
### Keyboard Shortcuts
|
2012-08-16 23:41:25 -04:00
|
|
|
|
|
|
|
In the quickfix window, you can use:
|
|
|
|
|
|
|
|
o to open (same as enter)
|
2014-04-18 08:58:02 -04:00
|
|
|
O to open and close quickfix window
|
2012-08-16 23:41:25 -04:00
|
|
|
go to preview file (open but maintain focus on ack.vim results)
|
|
|
|
t to open in new tab
|
|
|
|
T to open in new tab silently
|
2013-04-13 13:45:21 -04:00
|
|
|
h to open in horizontal split
|
|
|
|
H to open in horizontal split silently
|
2012-08-16 23:41:25 -04:00
|
|
|
v to open in vertical split
|
|
|
|
gv to open in vertical split silently
|
|
|
|
q to close the quickfix window
|
|
|
|
|
|
|
|
This Vim plugin is derived (and by derived, I mean copied, essentially) from
|
2014-04-18 08:58:02 -04:00
|
|
|
Antoine Imbert's blog post
|
|
|
|
[Ack and Vim Integration](http://blog.ant0ine.com/typepad/2007/03/ack-and-vim-integration.html)
|
|
|
|
(in particular, the function at the bottom of the post). I added a help file that
|
2012-08-16 23:41:25 -04:00
|
|
|
provides just enough reference to get you going. I also highly recommend you
|
2014-04-18 08:58:02 -04:00
|
|
|
check out the docs for the Perl script 'ack', for obvious reasons:
|
|
|
|
[ack - grep-like text finder](http://beyondgrep.com/).
|
|
|
|
|
|
|
|
### Gotchas
|
|
|
|
|
|
|
|
Some characters have special meaning, and need to be escaped your search
|
2014-07-02 07:18:18 -04:00
|
|
|
pattern. For instance, '#'. You have to escape it like this `:Ack '\\\#define
|
|
|
|
foo'` to search for '#define foo'. (From blueyed in issue #5.)
|
2014-04-18 08:58:02 -04:00
|
|
|
|
|
|
|
## Changelog
|
|
|
|
|
|
|
|
### 1.0
|
|
|
|
|
|
|
|
* Remove support to ack 1.x
|
|
|
|
* Start to use a Changelog
|
|
|
|
* Use `autoload` directory to define functions, instead of `plugin`.
|
|
|
|
* Add option to auto fold the results(`g:ack_autofold_results`)
|
|
|
|
* Improve documentation, list all options and shortcuts
|
|
|
|
* Improve highlight option to work when passes directories or use quotes.
|
|
|
|
* Add g:ack_mapping
|
|
|
|
* Add g:ack_default_options
|
|
|
|
* Add a help toggle `?`(like NERDTree)
|
2014-07-02 07:18:18 -04:00
|
|
|
|
|
|
|
### 1.0.1
|
|
|
|
|
|
|
|
* Fixes #124. Bug with `g:ack_autofold_results`
|
|
|
|
|
|
|
|
### 1.0.2
|
|
|
|
|
|
|
|
* Add compatibility with [vim-dispatch](https://github.com/tpope/vim-dispatch)
|
|
|
|
|
|
|
|
### 1.0.3
|
|
|
|
|
|
|
|
* Fixes #127. Use `&l:hlsearch` instead of `v:hlsearch` to keep compatibility
|
|
|
|
with versions that does not have this variable.
|
|
|
|
|
|
|
|
### 1.0.4
|
|
|
|
|
|
|
|
* Fixes #128. Always apply mappings, even when using vim-dispatch.
|
|
|
|
|
|
|
|
### 1.0.5
|
|
|
|
|
|
|
|
* Fixes #128. Fixes the `errorformat` for ack when using vim-dispatch.
|
|
|
|
* Do not use vim-dispatch by default. To use vim-dispath must set
|
|
|
|
`g:ack_use_dispatch`
|
|
|
|
|
|
|
|
### 1.0.6
|
|
|
|
|
|
|
|
* Fixes highlight function to work when user passes options. Ex.: Ack -i test
|
|
|
|
Thank's @mannih. (#131, #134)
|
|
|
|
|
|
|
|
### 1.0.7
|
|
|
|
|
|
|
|
* Fixes highlight function to work when passes more than one option, or options
|
|
|
|
with double dashes(--option) Thank's to @MiguelLatorre and @mannih
|
|
|
|
|
|
|
|
### 1.0.8
|
|
|
|
|
|
|
|
* Fixes (again) highlight, now using negative look behind.
|
|
|
|
* Change mappings `o` and `O` to behave as documented
|