How do you use vim's quickfix feature?
There are a lot of commands for quickfix as you have said, but I tend to find I only use a small subset of them:
:copen " Open the quickfix window
:ccl " Close it
:cw " Open it if there are "errors", close it otherwise (some people prefer this)
:cn " Go to the next error in the window
:cp " Go to the previous error in the window
:cnf " Go to the first error in the next file
:.cc " Go to error under cursor (if cursor is in quickfix window)
I tend to use this with :make
and :vimgrep
, so I can't comment on the Javascript lint checker, but this should give you something to get started.
Regarding the general use of JavascriptLint, I'm not a javascript programmer, but it looks like the script exposes a function called "JavascriptLint", so if you want to call it manually, you can use :call JavascriptLint()
. However, it works on the disk copy of the file, so it'll have to be saved first. If (and only if) the command line jsl
works on html files, you should be able to use :call JavascriptLint()
on an html file to check the internal javascript. You could also do:
autocmd BufWritePost,FileWritePost *.html call JavascriptLint()
to automate it. If jsl
doesn't support html files, then (short of patching the application or asking the author to change it), it's probably a lost cause...
The easiest way to navigate the quickfix list (or the location list, for that matter) is the unimpaired
plugin.
Once the quickfix window is populated, [q
and ]q
go forward and back (respectively) in the quickfix list. [Q
and ]Q
go to the beginning and end (which is especially handy if you only have one item in the list; this makes vim complain about [q
and ]q
). So the workflow is:
- Run whatever command populates the quickfix list
- Type
[Q
to go to the first item - Scroll through subsequent items (if any) with
[q
and]q
If you're using Syntastic, you'll get the location list instead of the quickfix list. No problem; just use [L
, ]L
, [l
, and ]l
in the same way.
unimpaired
has loads of other handy mappings too -- [e
and ]e
"bubble" lines up and down, [<Space>
and ]<Space>
insert blank lines above and below, etc. I was surprised nobody mentioned it here before; that's probably because it didn't exist until January 2010, though the question was asked in 2009.
Put the following two lines in your .vimrc file:
map <C-j> :cn<CR>
map <C-k> :cp<CR>
Now you can navigate through the errors using ctrl-j and ctrl-k, which mimics the standard down and up motion commands j and k.