0c33f9ea27
106c772b0 More detailed logging for version operations. 2d27fd93d Formatting: use the full name for execute. cb64516d4 Version handling: deal with errors. 1ba96436c Cleanup: handling versions. Minor optimisation. bcaf7cbcc Bump version number. 36ead6d75 Bump version number. 2073cee05 More safety checks. 38f46b6ac A (hopefully) safer "rm -rf". 5359f7f4e Python checker: new option g:syntastic_python_python_use_codec (@delfick). 4d1f2e23e Go checker: even more contortions. c60e440d0 Go checker: more contortions around "go_go_build_args" and "go_go_test_args". 8b97caa2d Rubocop: "--silent" was dropped in version 0.12. (@p0deje) 5429d24a5 Phpmd: fix broken regex used for syntax highlighting. 79007b01f Manual: minor additions. 74a071331 Go checker should work with go_go_build_args unset. be01caceb Phpcs: fix column handling. a18ccb40d Go checker: extra arguments for "go build" and "go test". 0da7a1e47 README: minor formatting. 6bea41bdf README: rephrase. 1eb493ef3 README: add a section about recommended settings. 1d2f8d514 Formatting: folding. c472ec139 Feature: extended syntax for `quiet_messages`. d1b401609 Bug fix: `glob()`, `globpath()`, and `expand()` should ignore `wildignore`. 50f6b47cb README: fix reference to pathogen#infect(). d97a43bfa Sparse checker: return code 1 is less meaningful these days. 79b04bdf4 Debug: if reading a config file fails, log the reason it failed. b340672bd Typo: remove a spurious quote. 2bb8d5996 Luacheck: highlighting patterns for version 0.7.1. 30257ef23 Luacheck: cleanup. d2c454963 Add luacheck checker for Lua 03f43ec55 Source uglification, part III. 6de1559f3 Make SyntasticInfo aware of b:syntastic_mode. 21f052ab0 Go and govet checkers: make go executable configurable. f583df730 Minor optimisation. 9caf33d5d If auto_jump is set to 3, jump to the first error if any. 6fdd39438 New option: b:syntastic_mode. 0c1dd2aa0 Safer closing of the error window. c74f28ace Merge pull request #1262 from powerman/fix-perl-DATA 65de58c3a fix file/line detection for perl d422c6d82 Flow checker: cleanup. 9dc6b6108 Updated formatting as per guidelines 55b535618 Added flow checker for javascript 9fe26f71a README: formatting. 38ba36073 README: minor cleanup. 6b9a34842 README: expand TOC. e18c41406 README: update FAQ about validator. 30b4ce341 Validator and w3 checkers: tell curl to ignore curlrc. 67ffe5881 Merge pull request #1255 from vincent-petithory/golint-warning 7f749fe35 make golint report warnings instead of errors 650c7368e Discourage people from looking at the sources for user docs. 4354e31f9 README: rephrase. 41d571944 FAQ: add a note about HTML Tidy for HTML5. 4ff440ccb Shut up vimlint. dbc7e39c1 Dartanalyzer can now return exit code 3. 4dba55828 Remove the avrgcc checker for Arduino. ec2b84b12 Reek checker: cleanup. 36bb32f88 Ruby: add reek style checker de5e025ef Scss-lint: syntax errors should have subtype syntax (@sds). ba7d1b40b Clisp: workaround to remove ciompiled files. 72e0593ea Bug fix: make sure directory returned by syntastic#util#tmpdir() exists. 47834c034 Slightly more meaningful messages for checkers disabled by Eclim and YCM. 412d3526a Try to detect checkers disabled by YouCompleteMe. 7b6734546 Try to detect filetypes abducted by Eclim. e4c94d67a First step towards exposing an API. c307dde8c ghc-mod: the pylint way of handling versions is way cool, man. 82ba62ce9 Minor cleanup: wrap the main commands in their own functions. c4c56716f More naming conventions. 64cce2083 Manual: better description of interaction with Eclim. 8e9ece214 Prospector: saner handling of errors. 83971066a Add legacy checker method setWantSort(). 57f1a0eb2 New user variables: `syntastic_<filetype>_<checker>_sort`. 1327780c5 Proscpector: all tools except pylint return 1-based column numbers. ba1b4606e Prospector: sort loclist. dd1560862 Prospector: version 0.7 can check individual files. 3fe6f2a84 Prospector: fix typos; add logging; better return checking. 71c9a7dd0 Don't run preprocess functions if checker returned an invalid code. 72a7cb389 New checker for python: prospector. 77c125170 Bashate: cleanup. d15590438 Merge remote-tracking branch 'aswna/add_bashate' 948202d04 Source uglification, part II. 4e9e08b50 Change case for constants' names. f180e28a3 Closurecompiler: allow running througha shell script (@bjpbakker). 54086304b Cache balloons' contents. Cleanup. 7ed52d1e4 README: rephrase. e9f930be0 README: expand the section about installation. 3d5d21952 SyntasticInfo: if the current file will not be checked, explain why. 75d56b209 Manual: add a note about vim-auto-save. 47df0a035 Add license. f4c7c5083 Add support for bashate. 008ac9829 Workaround for Vim changing the semantics of lockvar. 0bc8b2acb Don't change Vim's shell. d665fbf56 Solve chicken-and-egg problem with getting ghc-mod version. 038f6ff8f Disable bash_hack by default. 017d89a47 Minor autoload cleanup. aab197fb5 Formating. dce7234fd Merge remote-tracking branch 'remko/rnc-rnv' 4a0d88ad7 Cleanup. 7829ea2b3 rnc-rnv: Change license to WTFPL fe8054d2f Add RelaxNG (RNC) RNV checker 40776864c New checker for DocBook SGML, mdoc, and text: igor. 0e9ef6ec1 Eruby: fix logging. 19f885965 Filetype groff is actually nroff. 83d0d7fef Pylint: remove leftovers from the logging patch. ce8939680 Checker-specific logging. 21a25649b Markdown lint: vim-markdown sets filetype to mkd. acd02f61b Markdown lint: cleanup. 3a355fa4d Vim's filetype for Markdown is "markdown". a188d3ae6 combine improperly separated checkers a7e002cf4 Markdown: Added initial version of Markdown checkers a3cf0cb65 Bro: minor errorformat fix, and highlighting. 7246fac6c Better handling of temporary directories. 049718cc6 Bug fix: SyntasticToggleMode shouldn't trigger the checks. 2a077c90c Typo. f56742a48 Safer handling of temporary directories. 1e1c7086e README: rephrase of a FAQ question. aa3db4513 Mypy: cleanup. d9178ba4c Added mypy syntax plugin 0bfc328b0 The handlebars checker needs "guards". aea964703 New checker for Linux RPM spec files: rpmlint. ba6db9f16 New checker for Scala: scalastyle. fe6003c3b Checkstyle checker: cleanup. 2a88120b3 More grouping in errorformat. 2f7768407 Puppet: the "future" parser outputs column numbers. b8ca57de4 Puppet: fix errorformat. dc4f036a6 Expand b:syntastic_<checker>_exec. b639b007a New options. cc3328660 FAQ: add a note about empty error windows. 6ce9bf9ab Clear loclist when running lolder at the bottom of the loclist stack. bf2faa4d6 Manual: add a note about opening the error window. fa0290c55 PC-Lint: mark informational messages as "Style". 9321bc79e PC-Lint: add column numbers. Cleanup. 4f0fc20a1 Minor cleanup for text filetype. 53a321d0b README: clarifications about style checkers. d751d17ef PC-Lint: cleanup. 3476e4f1d Merge remote-tracking branch '2sb18/pc_lint' 19ee86712 - pc_lint seems to be working well now. fb6747c01 Grammar. 9d2800f9a README: add a note about style checkers. Minor cleanup. 7f08cdde6 working on pc_lint checker 18a7a9ff5 Pylint checker: more versioning delirium. 5c21c4d7f Bug fix: grouping in errorformat. 131563c37 Merge pull request #1187 from rradonic/enable-warnings e79015b0a enable warnings for eruby files e8afec011 SASS checker: fix errorformat. aac0775c3 Make `b:syntastic_skip_checks` suitable for general use. 7cdfd91c9 Merge pull request #1182 from russss/master d624e32b9 Erlang: correctly handle additional LibDirs 83b6d6a58 The php checkers needs "guards" postprocessing. 4aadf589b New postprocess function: `guards`. c2d73ffa3 Merge pull request #1177 from r3m0t/patch-1 82b2d3172 Bug fix: highlighting on python frosted checker b7b09af6b New global option `syntastic_exit_checks`. 0d0c4aa74 Bump version. c55384c0e Transform code using pmod_pt module before checking f88b5c74c Bump version number. 18a185be7 PHPLint: fix syntax highlighting. 0be8cdd63 New checker for PHP: PHPLint. 80db618c0 Cursor columns: fix redraw. d69858cc0 Merge pull request #1170 from blueyed/dont-call-expand-on-shellvar 3060c6b2e Do not `expand()` shell vars 9fb7b0d39 SCSS-Lint: new error codes. 82b274588 Don't assume loclists have vcol fields. 7b9b02954 README: typo. 4b7183b9d README: add a note about Python 3. 8e229e41a A cleaner way to kill default variables. 4cda4c3e0 Clang tools: check exit codes. 825b29a9b Clang tools: missing space. 009232652 Clang tools: work without a compilation database. Cleanup. 8e3482b9f Merge remote-tracking branch 'bbanier/t/clang_tools' into clang_tools e62fe0e6e Allow oclint to use cmake compilation databases. f6e38c8b9 Merge pull request #1161 from dtwitty/patch-1 e6bf829be Fix bad variable initialization d280dc78e Add new clang-tidy and clang-check checkers a27b435a1 OClint: slightly more robust regexps. 1fac6011e OClint: fix parsing. f62e0f661 New option: cursor_columns. 5c48b30c5 Fixes duplicate syntax checker for arduino files c2e7bf29c Escript: parseShebang() is more capable these days. e34079677 Bug fix: SyntasticReset didn't really reset. d795d4b16 Bug fix: forgotten return. 09f35e9f2 Try to prevent g:syntastic_mode_map from being modified. 3f963543d Manual: clarification about g:syntastic_mode_map. Minor cleanup. 95a57739e More detailed logging. c1479f980 Set default reuse_loc_lists to 0. d603ed4f3 Make sure version lists are formed of numbers. e34f421b3 Revert 1e3e0a8. The problem was placing signs on unloaded buffers. 190d9f5e9 Manual: add a note about canceling default arguments. 1d19dff70 Security: disable the elixir checker by default. 1e3e0a825 Defensive coding against stepping over other plugins' signs. 6c88bae55 JSHint checker: sort results. 5eb22bb0a Refresh optimisations: avoid floats. b222a31d5 Typo. 0f8d786b8 Check for +float. 9a26f1d58 SyntasticInfo: minor bug fix. 13bdf9e4b SyntasticInfo: more details about modes. Minor cleanup. 06e77c180 Manual: add a note about YouCompleteMe. e54f28e33 New redirect checker for arduino: avrgcc. 7b0d3f868 Don't check compressed files. d364f33a5 Refresh optimisations. 572d3e0eb README: nit pick about re-enabling the perl checker. af4988644 Vimlint: add g:syntastic_vimlint_options. 4c5ff4272 New option for SyntasticMake(): env. c325f6c81 Make syntastic#util#parseShebang() aware of /usr/bin/env. dd57547da Manual: add a note about netrw. 1ee4bcccc Error highlighting cleanup. 0bef7ef3f Bug fix: refresh notifiers in BufEnter, rather than BufWinEnter. ab79acbcc Cleanup. Deprecate a number of checker variables. 3ebdeabf6 Add a note about rustc's new home. bd7e34757 R lint and svtools: fix CWD for Windows. dd5ca1f78 Add a note about the removal of the rustc checker. 1383c0f50 Remove the rustc checket for Rust. c33303105 rustc: make arguments configurable. 17b624b86 Merge pull request #1113 from BurntSushi/makeprg-fname-param 931db14d9 filename -> fname 4004c021a ruby-lint: typo. 98b64fd7b ruby-lint: add version check for "analyze". b61fc8af0 ruby-lint: removed analyze sub-command 3e8637ec4 New checker for sass and scss: sassc. e058be3d0 Registry optimisation: lazy IsAvailable() calls. 284655357 Cabal checker: cleanup. cc72b0dc6 Rename cabal/check --> cabal/cabal. 02d9f710f Add syntax checker for Haskell .cabal files 101a32bb2 coffeelint: option `--csv` is deprecated (@greenify). b6a42d187 Vim no longer allows setting signs on line 0. 576b84e2b Update installation instructions. 50518b335 Add separate highlighting groups for style messages (@kovidgoyal). 45a36bf2f eslint: honour the exec parameter. 716038ea4 Output of pep257 has changed. e7d1519f5 Cleanup for bro. 6ea779673 Merge remote-tracking branch 'JustinAzoff/bro' 06d8037af Merge pull request #1074 from lucc/doc 79fde89e7 Fix broken tag in docs. 653a02a4c Some versions of phcs produce an extra column: fix errorformat. 02d07313a Merge branch 'multi' 8c1c13e94 Contributing guide: add TOC; formatting. dc02d6664 Update the contributing guide. Make `:SyntasticInfo` print version. 43e8cb955 More clisp fixes. 24eab0313 clisp: fix argument order. ad991127a New checker for less and css: recess (@pixelastic). b9f741e57 Attempt at making multiple buffers work properly. 75c439fc2 Manual: add a note about PowerShell. 2a770da3a GitHub has changed the addresses for user content. 30404b914 Merge pull request #1062 from benekastah/master 9d4b17349 README: minor update. 9facbb77c fixup 748046277 Added an errorformat for eslint's warning messages 092c1f742 Merge pull request #1060 from witchard/ghdl_argument_ordering 0ae26fd22 Updated argument ordering for ghdl. 4b00bf5b2 Python checkers: workaround for GNU readline brain damage. 3c07df5df Cleanup: lock some variables. 02cbebdfa Cleanup: fix two vimlint warnings. 125442f17 tslint: cleanup. eaa899a02 Merge remote-tracking branch 'swook/master' 54bb9b4b8 haxe and dartanalyzer: fix syntax highlighting. b9ee43989 tslint: A basic checker configuration 618b41428 Merge remote-tracking branch 'cww/master' ebbcdd0c1 Cleanup for java/javac. 177292caf Cleanup for the new aggregate_errors. b1b16500a javac: Allow users to specify Maven options 99cbe5d01 HTML Tidy: add a note about HTML Tidy for HTML5. 4dbb65276 New option: syntastic_sort_aggregated_errors. 68131a767 Bug fix: error sorting. b4320f19d oclint: option "-text" is obsolete. 4c18240e8 Formatting. 29843ed7f Minor cleanup. f161992c1 vimlint: a more efficient IsAvailable(). 4b9e87499 README: clarifications for calling multiple checkers. 41edfe34c New checker for plist XML: plutil. 81313611a Manual: minor cleanup. 9cf21436c New checker for haskell: scan. 62fde0051 Hdevtools: fix column calculations. Cleanup. 841087fab Hlint: fix column calculations. 30198e109 Manual: add a note about vim-virtualenv. 21c7234bb Merge pull request #1046 from dan-t/master 7bd9b9834 Always give absolute paths to syntax checkers 'hdevtools' and 'hlint' 9aa1a1969 Merge pull request #1044 from riobard/fix/jsxhint 2a1e0948b R svtools: disable the checker by default, for security reasons. e7662b946 New checker for R: svtools. 6ad57016c New checker for R: lint. d2c0d4d83 jsxhint can be used independently. 6d05d1735 README: add anchors for FAQ items. a62fc9eeb README: minor update. 82bff20b0 README: change address for YouCompleteMe. 8d2ac0682 Minor rephrase in the manual. 668a08bfa Add new checker for bro: bro. 0c557bfca jshint: require version 1.0.0 or later. a781914a1 Yet more pylint versioning delirium. f6d584bc6 splint: add errorformat sequences for Windows. 94e0e73c4 Add a note to the manual about Eclim. 4ded4f404 Expand a few config parameters. c8f562f0f ESLint: add version check; expand config parameter. 9b1c2aa05 fix javascript/eslint format 5e275c453 Merge pull request #1027 from jseabold/patch-1 6fe4db38b Fix link. dc6bb1121 Bump version number. 2850d4145 Minor cleanup. da6520c69 \V<pattern> regexps can spell trouble if <pattern> contains backslashes. 223d00a0f phpcs is slow as a css checker, remove it from the defaults. 013b425c2 Make "g:syntastic_<filetype>_checkers = []" work as expected. 4fa278afe Merge pull request #1018 from lavrin/search-apps-deps-libs 2eb60cb58 Version tracking. 1fcb6b89b Don't forget about ebin/ 2286363ad Properly add deps/*/include to header file path 105965c82 Simplify main/1 heads 0de089b85 Allow foreign checkers to call foreign preprocess and postprocess functions. 74121741f README: put examples in accord with the defaults. ae65cbac4 README: minor updates, rewording, and formatting. c18065ea5 Security: disable the perl checker by default. e677e0655 pyflakes: update errorformat. fb7151464 Move preprocess functions to their own file. f490cf6ec Merge branch 'registry_refactor' 0bb8c7e5f jscs: add exit code 2 as valid (new in JSCS 1.3.0). 4196dd30d jshint: check return code. e32343730 More preparations for the foreign checkers feature. 25271f89a Add buffer-local versions for auto_loc_list and loc_list_height. b0191a144 Refactor of quiet_message filters. 2940b0c72 Bug fix: checker ordering. Formatting. 47e5739f2 Formatting. 0f3a1bf45 Cleanup. ab136c5ae Merge branch 'master' into registry_refactor d12bc4f1d jsxhint: cleanup. de9a02127 Add jsxhint checker 09e6840d1 Fix debug output. c658ff15a Registry refactor. git-subtree-dir: vim/bundle/syntastic git-subtree-split: 106c772b055a7037f47c9ffdca01b53fa24ae6b6 |
10 years ago | |
---|---|---|
_assets | 11 years ago | |
autoload/syntastic | 10 years ago | |
doc | 10 years ago | |
plugin | 10 years ago | |
syntax_checkers | 10 years ago | |
.gitignore | 11 years ago | |
CONTRIBUTING.md | 10 years ago | |
LICENCE | 11 years ago | |
README.markdown | 10 years ago |
README.markdown
,
/ \,,_ .'|
,{{| /}}}}/_.' _____________________________________________
}}}}` '{{' '. / \
{{{{{ _ ;, \ / Ladies and Gentlemen, \
,}}}}}} /o`\ ` ;) | |
{{{{{{ / ( | this is ... |
}}}}}} | \ | |
{{{{{{{{ \ \ | |
}}}}}}}}} '.__ _ | | _____ __ __ _ |
{{{{{{{{ /`._ (_\ / | / ___/__ ______ / /_____ ______/ /_(_)____ |
}}}}}}' | //___/ --=: \__ \/ / / / __ \/ __/ __ `/ ___/ __/ / ___/ |
jgs `{{{{` | '--' | ___/ / /_/ / / / / /_/ /_/ (__ ) /_/ / /__ |
}}}` | /____/\__, /_/ /_/\__/\__,_/____/\__/_/\___/ |
| /____/ |
| /
\_____________________________________________/
- Introduction
- Installation
2.1. Requirements
2.2. Installing syntastic with Pathogen - Recommended settings
- FAQ
4.1. I installed syntastic but it isn't reporting any errors...
4.2. Thepython
checker complains about syntactically valid Python 3 constructs...
4.3. Are there any local checkers for HTML5 that I can use with syntastic?
4.4. Theperl
checker has stopped working...
4.5. What happened to therustc
checker?
4.6. I run a checker and the location list is not updated...
4.6. I run:lopen
or:lwindow
and the error window is empty...
4.7. How can I pass additional arguments to a checker?
4.8. Syntastic supports several checkers for my filetype - how do I tell which one(s) to use?
4.9. What is the difference between syntax checkers and style checkers?
4.10. I have enabled multiple checkers for the current filetype. How can I display all of the errors from all of the checkers together?
4.11. How can I jump between the different errors without using the location list at the bottom of the window?
4.12. The error window is closed automatically when I :quit the current buffer but not when I :bdelete it? - Resources
1. Introduction
Syntastic is a syntax checking plugin for Vim that runs files through external syntax checkers and displays any resulting errors to the user. This can be done on demand, or automatically as files are saved. If syntax errors are detected, the user is notified and is happy because they didn't have to compile their code or execute their script to find them.
At the time of this writing, syntax checking plugins exist for ActionScript, Ada, AppleScript, AsciiDoc, ASM, BEMHTML, Bro, Bourne shell, C, C++, C#, Cabal, Chef, CoffeeScript, Coco, Coq, CSS, Cucumber, CUDA, D, Dart, DocBook, Dust, Elixir, Erlang, eRuby, Fortran, Gentoo metadata, GLSL, Go, Haml, Haskell, Haxe, Handlebars, HSS, HTML, Java, JavaScript, JSON, JSX, LESS, Lex, Limbo, LISP, LLVM intermediate language, Lua, Markdown, MATLAB, NASM, Objective-C, Objective-C++, OCaml, Perl, Perl POD, PHP, gettext Portable Object, OS X and iOS property lists, Puppet, Python, R, Racket, Relax NG, reStructuredText, RPM spec, Ruby, SASS/SCSS, Scala, Slim, Tcl, TeX, Texinfo, Twig, TypeScript, Vala, Verilog, VHDL, VimL, xHtml, XML, XSLT, YACC, YAML, z80, Zope page templates, and zsh. See the wiki for details about the corresponding supported checkers.
Below is a screenshot showing the methods that Syntastic uses to display syntax errors. Note that, in practise, you will only have a subset of these methods enabled.
- Errors are loaded into the location list for the corresponding window.
- When the cursor is on a line containing an error, the error message is echoed in the command window.
- Signs are placed beside lines with errors - note that warnings are displayed in a different color.
- There is a configurable statusline flag you can include in your statusline config.
- Hover the mouse over a line containing an error and the error message is displayed as a balloon.
- (not shown) Highlighting errors with syntax highlighting. Erroneous parts of lines can be highlighted.
2. Installation
2.1. Requirements
Syntastic itself has rather relaxed requirements: it doesn't have any external
dependencies, and it needs a version of Vim compiled with a few common
features: autocmd
, eval
, file_in_path
, modify_fname
, quickfix
,
reltime
, and user_commands
. Not all possible combinations of features that
include the ones above make equal sense on all operating systems, but Vim
version 7 or later with the "normal", "big", or "huge" feature sets should be
fine.
Syntastic should work with any modern plugin managers for Vim, such as NeoBundle, Pathogen, Vim-Addon-Manager, Vim-Plug, or Vundle. Instructions for installing syntastic with Pathogen are included below for completeness.
Last but not least: syntastic doesn't know how to do any syntax checks by itself. In order to get meaningful results you need to install external checkers corresponding to the types of files you use. Please consult the wiki for a list of supported checkers.
2.2. Installing syntastic with Pathogen
If you already have Pathogen working then skip Step 1 and go to Step 2.
2.2.1. Step 1: Install pathogen.vim
First I'll show you how to install Tim Pope's Pathogen so that it's easy to
install syntastic. Do this in your terminal so that you get the pathogen.vim
file and the directories it needs:
mkdir -p ~/.vim/autoload ~/.vim/bundle && \
curl -LSso ~/.vim/autoload/pathogen.vim https://tpo.pe/pathogen.vim
Next you need to add this to your ~/.vimrc
:
execute pathogen#infect()
2.2.2. Step 2: Install syntastic as a Pathogen bundle
You now have pathogen installed and can put syntastic into ~/.vim/bundle
like
this:
cd ~/.vim/bundle && \
git clone https://github.com/scrooloose/syntastic.git
Quit vim and start it back up to reload it, then type:
:Helptags
If you get an error when you do this, then you probably didn't install Pathogen right. Go back to Step 1 and make sure you did the following:
- Created both the
~/.vim/autoload
and~/.vim/bundle
directories. - Added the
execute pathogen#infect()
line to your~/.vimrc
file - Did the
git clone
of syntastic inside~/.vim/bundle
- Have permissions to access all of these directories.
3. Recommended settings
Syntastic has a large number of options that can be configured, and the
defaults are not particularly well suitable for new users. It is recommended
that you start by adding the following lines to your vimrc
file, and return
to them after reading the manual (see :help syntastic
in Vim):
set statusline+=%#warningmsg#
set statusline+=%{SyntasticStatuslineFlag()}
set statusline+=%*
let g:syntastic_always_populate_loc_list = 1
let g:syntastic_auto_loc_list = 1
let g:syntastic_check_on_open = 1
let g:syntastic_check_on_wq = 0
4. FAQ
4.1. Q. I installed syntastic but it isn't reporting any errors...
A. The most likely reason is that none of the syntax checkers that it requires
is installed. For example: by default, python requires either flake8
or
pylint
to be installed and in your $PATH
. To see which executables are
supported, look at the wiki. Note that aliases do not work; the actual
executables must be available in your $PATH
. Symbolic links are okay though.
You can see syntastic's idea of available checkers by running :SyntasticInfo
.
Another reason it could fail is that either the command line options or the error output for a syntax checker may have changed. In this case, make sure you have the latest version of the syntax checker installed. If it still fails then create an issue - or better yet, create a pull request.
4.2. Q. The python
checker complains about syntactically valid Python 3 constructs...
A. Configure the python
checker to call a Python 3 interpreter rather than
Python 2, e.g:
let g:syntastic_python_python_exec = '/path/to/python3'
4.3. Q. Are there any local checkers for HTML5 that I can use with syntastic?
HTML Tidy has a fork named HTML Tidy for HTML5. It's a drop
in replacement, and syntastic can use it without changes. Just install it
somewhere and point g:syntastic_html_tidy_exec
to its executable.
Alternatively, you can install vnu.jar from the validator.nu project and run it as a HTTP server:
$ java -Xss512k -cp /path/to/vnu.jar nu.validator.servlet.Main 8888
Then you can configure syntastic to use it:
let g:syntastic_html_validator_api = 'http://localhost:8888/'
4.4. Q. The perl
checker has stopped working...
A. The perl
checker runs perl -c
against your file, which in turn
executes any BEGIN
, UNITCHECK
, and CHECK
blocks, and any use
statements in your file (cf. perlrun). This is probably fine if you
wrote the file yourself, but it's a security problem if you're checking third
party files. Since there is currently no way to disable this behaviour while
still producing useful results, the checker is now disabled by default. To
(re-)enable it, make sure the g:syntastic_perl_checkers
list includes perl
,
and set g:syntastic_enable_perl_checker
to 1 in your vimrc
:
let g:syntastic_enable_perl_checker = 1
4.5. Q. What happened to the rustc
checker?
A. It has been included in the Rust compiler package. If you have a recent version of the Rust compiler, the checker should be picked up automatically by syntastic.
4.6. Q. I run a checker and the location list is not updated...
4.6. Q. I run:lopen
or :lwindow
and the error window is empty...
A. By default the location list is changed only when you run the :Errors
command, in order to minimise conflicts with other plugins. If you want the
location list to always be updated when you run the checkers, add this line to
your vimrc
:
let g:syntastic_always_populate_loc_list = 1
4.7. Q. How can I pass additional arguments to a checker?
A. Almost all syntax checkers use the makeprgBuild()
function. Those checkers
that do can be configured using global variables. The general form of the
global args
variables is syntastic_<filetype>_<checker>_args
.
So, If you wanted to pass --my --args --here
to the ruby mri checker you
would add this line to your vimrc
:
let g:syntastic_ruby_mri_args = "--my --args --here"
See :help syntastic-checker-options
for more information.
4.8. Q. Syntastic supports several checkers for my filetype - how do I tell it which one(s) to use?
A. Stick a line like this in your vimrc
:
let g:syntastic_<filetype>_checkers = ['<checker-name>']
To see the list of supported checkers for your filetype look at the wiki.
e.g. Python has the following checkers, among others: flake8
, pyflakes
,
pylint
and a native python
checker.
To tell syntastic to use pylint
, you would use this setting:
let g:syntastic_python_checkers = ['pylint']
Checkers can be chained together like this:
let g:syntastic_php_checkers = ['php', 'phpcs', 'phpmd']
This is telling syntastic to run the php
checker first, and if no errors are
found, run phpcs
, and then phpmd
.
You can also run checkers explicitly by calling :SyntasticCheck <checker>
.
e.g. to run phpcs
and phpmd
:
:SyntasticCheck phpcs phpmd
This works for any checkers available for the current filetype, even if they
aren't listed in g:syntastic_<filetype>_checkers
. You can't run checkers for
"foreign" filetypes though (e.g. you can't run, say, a Python checker if the
filetype of the current file is php
).
4.9. Q. What is the difference between syntax checkers and style checkers?
A. The errors and warnings they produce are highlighted differently and can
be filtered by different rules, but otherwise the distinction is pretty much
arbitrary. There is an ongoing effort to keep things consistent, so you can
generally expect messages produced by syntax checkers to be mostly related
to syntax, and messages produced by style checkers to be mostly about style.
But there can be no formal guarantee that, say, a style checker that runs into
a syntax error wouldn't die with a fatal message, nor that a syntax checker
wouldn't give you warnings against using some constructs as being bad practice.
There is also no guarantee that messages marked as "style" are less severe than
the ones marked as "syntax" (whatever that might mean). And there are even a
few Frankenstein checkers (for example flake8
and pylama
) that, by their
nature, produce both kinds of messages. Syntastic is not smart enough to be
able to sort out these things by itself.
In fact it's more useful to look at this from the perspective of filtering unwanted messages, rather than as an indicator of severity levels. The distinction between syntax and style is orthogonal to the distinction between errors and warnings, and thus you can turn off messages based on level, on type, or both.
e.g. To disable all style messages:
let g:syntastic_quiet_messages = { "type": "style" }
See :help syntastic_quiet_messages
for details.
4.10. Q. I have enabled multiple checkers for the current filetype. How can I display all of the errors from all of the checkers together?
A. Set g:syntastic_aggregate_errors
to 1 in your vimrc
:
let g:syntastic_aggregate_errors = 1
See :help syntastic-aggregating-errors
for more details.
4.11. Q. How can I jump between the different errors without using the location list at the bottom of the window?
A. Vim provides several built-in commands for this. See :help :lnext
and
:help :lprevious
.
If you use these commands a lot then you may want to add shortcut mappings to
your vimrc
, or install something like unimpaired, which provides such
mappings (among other things).
4.12. Q. The error window is closed automatically when I :quit the current buffer but not when I :bdelete it?
A. There is no safe way to handle that situation automatically, but you can work around it:
nnoremap <silent> <C-d> :lclose<CR>:bdelete<CR>
cabbrev <silent> bd lclose\|bdelete
5. Resources
The preferred place for posting suggestions, reporting bugs, and general discussions related to syntastic is the issue tracker at GitHub. A guide for writing syntax checkers can be found in the wiki. There are also a dedicated google group, and a syntastic tag at StackOverflow.
Syntastic aims to provide a common interface to syntax checkers for as many languages as possible. For particular languages, there are, of course, other plugins that provide more functionality than syntastic. You might want to take a look at jedi-vim, python-mode, or YouCompleteMe.