Cleaning deps.
This commit is contained in:
parent
4541dd93ef
commit
2deb035254
266 changed files with 26588 additions and 31 deletions
4
sources_non_forked/syntastic/.gitignore
vendored
Normal file
4
sources_non_forked/syntastic/.gitignore
vendored
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
*~
|
||||||
|
*.swp
|
||||||
|
tags
|
||||||
|
.DS_Store
|
105
sources_non_forked/syntastic/CONTRIBUTING.md
Normal file
105
sources_non_forked/syntastic/CONTRIBUTING.md
Normal file
|
@ -0,0 +1,105 @@
|
||||||
|
# CONTRIBUTING
|
||||||
|
- - -
|
||||||
|
1\. [Bug reports / GitHub issues](#bugreps)
|
||||||
|
2\. [Submitting a patch](#patches)
|
||||||
|
3\. [General style notes](#generalstyle)
|
||||||
|
4\. [Syntax checker notes](#checkerstyle)
|
||||||
|
- - -
|
||||||
|
|
||||||
|
<a name="bugreps"></a>
|
||||||
|
|
||||||
|
## 1. Bug reports / GitHub issues
|
||||||
|
|
||||||
|
Please note that the preferred channel for posting bug reports is the
|
||||||
|
[issue tracker at GitHub][0]. Reports posted elsewhere are less likely
|
||||||
|
to be seen by the core team.
|
||||||
|
|
||||||
|
When reporting a bug make sure you search the existing GitHub issues
|
||||||
|
for the same/similar issues. If you find one, feel free to add a `+1`
|
||||||
|
comment with any additional information that may help us solve the
|
||||||
|
issue.
|
||||||
|
|
||||||
|
When creating a new issue be sure to state the following:
|
||||||
|
|
||||||
|
* steps to reproduce the bug;
|
||||||
|
* the version of Vim you are using (run `:ver` to find out);
|
||||||
|
* the version of syntastic you are using (see `:SyntasticInfo`).
|
||||||
|
|
||||||
|
For syntax checker bugs also state the version of the checker executable
|
||||||
|
that you are using. Adding debugging information is typically useful
|
||||||
|
too:
|
||||||
|
|
||||||
|
* open a file handled by your checker;
|
||||||
|
* set `g:syntastic_debug` to 1 or 3;
|
||||||
|
* run the checker;
|
||||||
|
* copy the output of `:mes`.
|
||||||
|
|
||||||
|
<a name="patches"></a>
|
||||||
|
|
||||||
|
## 2. Submitting a patch
|
||||||
|
|
||||||
|
Before you consider adding features to syntastic, _please_ spend a few
|
||||||
|
minutes (re-)reading the latest version of the [manual][1]. Syntastic
|
||||||
|
is changing rapidly at times, and it's quite possible that some of the
|
||||||
|
features you want to add exist already.
|
||||||
|
|
||||||
|
To submit a patch:
|
||||||
|
|
||||||
|
* fork the [repo][2] on GitHub;
|
||||||
|
* make a [topic branch][3] and start hacking;
|
||||||
|
* submit a pull request based off your topic branch.
|
||||||
|
|
||||||
|
Small, focused patches are preferred.
|
||||||
|
|
||||||
|
Large changes to the code should be discussed with the core team first.
|
||||||
|
Create an issue and explain your plan and see what we say.
|
||||||
|
|
||||||
|
Also make sure to update the manual whenever applicable. Nobody can use
|
||||||
|
features that aren't documented.
|
||||||
|
|
||||||
|
<a name="generalstyle"></a>
|
||||||
|
|
||||||
|
## 3. General style notes
|
||||||
|
|
||||||
|
Follow the coding conventions/styles used in the syntastic core:
|
||||||
|
|
||||||
|
* use 4 space indents;
|
||||||
|
* don't use abbreviated keywords - e.g. use `endfunction`, not `endfun`
|
||||||
|
(there's always room for more fun!);
|
||||||
|
* don't use `l:` prefixes for variables unless actually required (i.e.
|
||||||
|
almost never);
|
||||||
|
* code for maintainability; we would rather a function be a couple of
|
||||||
|
lines longer and have (for example) some [explaining variables][4] to
|
||||||
|
aid readability.
|
||||||
|
|
||||||
|
<a name="checkerstyle"></a>
|
||||||
|
|
||||||
|
## 4. Syntax checker notes
|
||||||
|
|
||||||
|
Make sure to read the [guide][5] if you plan to add new syntax checkers.
|
||||||
|
|
||||||
|
Use the existing checkers as templates, rather than writing everything
|
||||||
|
from scratch.
|
||||||
|
|
||||||
|
The preferred style for error format strings is one "clause" per line.
|
||||||
|
E.g. (from the `coffee` checker):
|
||||||
|
|
||||||
|
```vim
|
||||||
|
let errorformat =
|
||||||
|
\ '%E%f:%l:%c: %trror: %m,' .
|
||||||
|
\ 'Syntax%trror: In %f\, %m on line %l,' .
|
||||||
|
\ '%EError: In %f\, Parse error on line %l: %m,' .
|
||||||
|
\ '%EError: In %f\, %m on line %l,' .
|
||||||
|
\ '%W%f(%l): lint warning: %m,' .
|
||||||
|
\ '%W%f(%l): warning: %m,' .
|
||||||
|
\ '%E%f(%l): SyntaxError: %m,' .
|
||||||
|
\ '%-Z%p^,' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
```
|
||||||
|
|
||||||
|
[0]: https://github.com/scrooloose/syntastic/issues
|
||||||
|
[1]: https://github.com/scrooloose/syntastic/blob/master/doc/syntastic.txt
|
||||||
|
[2]: https://github.com/scrooloose/syntastic
|
||||||
|
[3]: https://github.com/dchelimsky/rspec/wiki/Topic-Branches#using-topic-branches-when-contributing-patches
|
||||||
|
[4]: http://www.refactoring.com/catalog/extractVariable.html
|
||||||
|
[5]: https://github.com/scrooloose/syntastic/wiki/Syntax-Checker-Guide
|
13
sources_non_forked/syntastic/LICENCE
Normal file
13
sources_non_forked/syntastic/LICENCE
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE
|
||||||
|
Version 2, December 2004
|
||||||
|
|
||||||
|
Copyright (C) 2004 Sam Hocevar <sam@hocevar.net>
|
||||||
|
|
||||||
|
Everyone is permitted to copy and distribute verbatim or modified
|
||||||
|
copies of this license document, and changing it is allowed as long
|
||||||
|
as the name is changed.
|
||||||
|
|
||||||
|
DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE
|
||||||
|
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||||
|
|
||||||
|
0. You just DO WHAT THE FUCK YOU WANT TO.
|
305
sources_non_forked/syntastic/README.markdown
Normal file
305
sources_non_forked/syntastic/README.markdown
Normal file
|
@ -0,0 +1,305 @@
|
||||||
|
,
|
||||||
|
/ \,,_ .'|
|
||||||
|
,{{| /}}}}/_.' _____________________________________________
|
||||||
|
}}}}` '{{' '. / \
|
||||||
|
{{{{{ _ ;, \ / Ladies and Gentlemen, \
|
||||||
|
,}}}}}} /o`\ ` ;) | |
|
||||||
|
{{{{{{ / ( | this is ... |
|
||||||
|
}}}}}} | \ | |
|
||||||
|
{{{{{{{{ \ \ | |
|
||||||
|
}}}}}}}}} '.__ _ | | _____ __ __ _ |
|
||||||
|
{{{{{{{{ /`._ (_\ / | / ___/__ ______ / /_____ ______/ /_(_)____ |
|
||||||
|
}}}}}}' | //___/ --=: \__ \/ / / / __ \/ __/ __ `/ ___/ __/ / ___/ |
|
||||||
|
jgs `{{{{` | '--' | ___/ / /_/ / / / / /_/ /_/ (__ ) /_/ / /__ |
|
||||||
|
}}}` | /____/\__, /_/ /_/\__/\__,_/____/\__/_/\___/ |
|
||||||
|
| /____/ |
|
||||||
|
| /
|
||||||
|
\_____________________________________________/
|
||||||
|
|
||||||
|
|
||||||
|
- - -
|
||||||
|
1\. [Introduction](#introduction)
|
||||||
|
2\. [Installation](#installation)
|
||||||
|
3\. [FAQ](#faq)
|
||||||
|
4\. [Other resources](#otherresources)
|
||||||
|
- - -
|
||||||
|
|
||||||
|
<a name="introduction"></a>
|
||||||
|
|
||||||
|
## 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, Arduino, 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, MATLAB, NASM, Objective-C,
|
||||||
|
Objective-C++, OCaml, Perl, Perl POD, PHP, gettext Portable Object, OS X
|
||||||
|
and iOS property lists, Puppet, Python, Racket, R, reStructuredText, 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][3] 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.
|
||||||
|
|
||||||
|
![Screenshot 1][0]
|
||||||
|
|
||||||
|
1. Errors are loaded into the location list for the corresponding window.
|
||||||
|
2. When the cursor is on a line containing an error, the error message is echoed in the command window.
|
||||||
|
3. Signs are placed beside lines with errors - note that warnings are displayed in a different color.
|
||||||
|
4. There is a configurable statusline flag you can include in your statusline config.
|
||||||
|
5. Hover the mouse over a line containing an error and the error message is displayed as a balloon.
|
||||||
|
6. (not shown) Highlighting errors with syntax highlighting. Erroneous parts of lines can be highlighted.
|
||||||
|
|
||||||
|
<a name="installation"></a>
|
||||||
|
|
||||||
|
## 2\. Installation
|
||||||
|
|
||||||
|
Installing syntastic is easy but first you need to have the [pathogen][1]
|
||||||
|
plugin installed. If you already have [pathogen][1] working then skip
|
||||||
|
[Step 1](#step1) and go to [Step 2](#step2).
|
||||||
|
|
||||||
|
|
||||||
|
<a name="step1"></a>
|
||||||
|
|
||||||
|
### 2.1\. Step 1: Install pathogen.vim
|
||||||
|
|
||||||
|
First I'll show you how to install Tim Pope's [pathogen][1] 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:
|
||||||
|
```sh
|
||||||
|
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`:
|
||||||
|
```vim
|
||||||
|
execute pathogen#infect()
|
||||||
|
```
|
||||||
|
|
||||||
|
<a name="step2"></a>
|
||||||
|
|
||||||
|
### 2.2\. Step 2: Install syntastic as a pathogen bundle
|
||||||
|
|
||||||
|
You now have pathogen installed and can put syntastic into `~/.vim/bundle` like
|
||||||
|
this:
|
||||||
|
```sh
|
||||||
|
cd ~/.vim/bundle && \
|
||||||
|
git clone https://github.com/scrooloose/syntastic.git
|
||||||
|
```
|
||||||
|
Quit vim and start it back up to reload it, then type:
|
||||||
|
```vim
|
||||||
|
:Helptags
|
||||||
|
```
|
||||||
|
If you get an error when you do this, then you probably didn't install
|
||||||
|
[pathogen][1] right. Go back to [Step 1](#step1) and make sure you did the following:
|
||||||
|
|
||||||
|
1. Created both the `~/.vim/autoload` and `~/.vim/bundle` directories.
|
||||||
|
2. Added the `call pathogen#infect()` line to your `~/.vimrc` file
|
||||||
|
3. Did the `git clone` of syntastic inside `~/.vim/bundle`
|
||||||
|
4. Have permissions to access all of these directories.
|
||||||
|
|
||||||
|
|
||||||
|
<a name="faq"></a>
|
||||||
|
|
||||||
|
## 3\. FAQ
|
||||||
|
|
||||||
|
<a name="faqinfo"></a>
|
||||||
|
|
||||||
|
__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][3]. 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.
|
||||||
|
|
||||||
|
<a name="faqperl"></a>
|
||||||
|
|
||||||
|
__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][10]). 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:
|
||||||
|
```vim
|
||||||
|
let g:syntastic_enable_perl_checker = 1
|
||||||
|
```
|
||||||
|
|
||||||
|
<a name="faqrust"></a>
|
||||||
|
|
||||||
|
__Q. What happened to the `rustc` checker?__
|
||||||
|
|
||||||
|
A. It has been included in the [Rust compiler package][12]. If you have
|
||||||
|
a recent version of the Rust compiler, the checker should be picked up
|
||||||
|
automatically by syntastic.
|
||||||
|
|
||||||
|
<a name="faqloclist"></a>
|
||||||
|
|
||||||
|
__Q. I run a checker and the location list is not updated...__
|
||||||
|
|
||||||
|
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:
|
||||||
|
```vim
|
||||||
|
let g:syntastic_always_populate_loc_list = 1
|
||||||
|
```
|
||||||
|
|
||||||
|
<a name="faqargs"></a>
|
||||||
|
|
||||||
|
__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:
|
||||||
|
```vim
|
||||||
|
let g:syntastic_ruby_mri_args = "--my --args --here"
|
||||||
|
```
|
||||||
|
|
||||||
|
See `:help syntastic-checker-options` for more information.
|
||||||
|
|
||||||
|
<a name="faqcheckers"></a>
|
||||||
|
|
||||||
|
__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:
|
||||||
|
```vim
|
||||||
|
let g:syntastic_<filetype>_checkers = ['<checker-name>']
|
||||||
|
```
|
||||||
|
|
||||||
|
To see the list of supported checkers for your filetype look at the
|
||||||
|
[wiki][3].
|
||||||
|
|
||||||
|
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:
|
||||||
|
```vim
|
||||||
|
let g:syntastic_python_checkers = ['pylint']
|
||||||
|
```
|
||||||
|
|
||||||
|
Some filetypes, like PHP, have style checkers as well as syntax checkers. These
|
||||||
|
can be chained together like this:
|
||||||
|
```vim
|
||||||
|
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`:
|
||||||
|
```vim
|
||||||
|
: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
|
||||||
|
current filetype is `php`).
|
||||||
|
|
||||||
|
<a name="faqaggregate"></a>
|
||||||
|
|
||||||
|
__Q. How can I display together the errors found by all checkers enabled for
|
||||||
|
the current file?__
|
||||||
|
|
||||||
|
A. Set `g:syntastic_aggregate_errors` to 1 in your vimrc:
|
||||||
|
```vim
|
||||||
|
let g:syntastic_aggregate_errors = 1
|
||||||
|
```
|
||||||
|
|
||||||
|
See `:help syntastic-aggregating-errors` for more details.
|
||||||
|
|
||||||
|
<a name="faqlnext"></a>
|
||||||
|
|
||||||
|
__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 :lprev`.
|
||||||
|
|
||||||
|
If you use these commands a lot then you may want to add shortcut mappings to
|
||||||
|
your vimrc, or install something like [unimpaired][2], which provides such
|
||||||
|
mappings (among other things).
|
||||||
|
|
||||||
|
<a name="faqstyle"></a>
|
||||||
|
|
||||||
|
__Q. A syntax checker is giving me unwanted/strange style tips?__
|
||||||
|
|
||||||
|
A. Some filetypes (e.g. php) have style checkers as well as syntax
|
||||||
|
checkers. You can usually configure the options that are passed to the style
|
||||||
|
checkers, or just disable them. Take a look at the [wiki][3] to see what
|
||||||
|
options are available.
|
||||||
|
|
||||||
|
Alternatively, you can use `g:syntastic_quiet_messages` to filter out the
|
||||||
|
messages you don't want to see. e.g. To turn off all style messages:
|
||||||
|
```vim
|
||||||
|
let g:syntastic_quiet_messages = { "type": "style" }
|
||||||
|
```
|
||||||
|
See `:help syntastic_quiet_messages` for details.
|
||||||
|
|
||||||
|
<a name="faqbdelete"></a>
|
||||||
|
|
||||||
|
__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:
|
||||||
|
|
||||||
|
```vim
|
||||||
|
nnoremap <silent> <C-d> :lclose<CR>:bdelete<CR>
|
||||||
|
cabbrev <silent> bd lclose\|bdelete
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
<a name="otherresources"></a>
|
||||||
|
|
||||||
|
## 4\. Other resources
|
||||||
|
|
||||||
|
The preferred place for posting suggestions, reporting bugs, and general
|
||||||
|
discussions related to syntastic is the [issue tracker at GitHub][4].
|
||||||
|
A guide for writing syntax checkers can be found in the [wiki][11].
|
||||||
|
There are also a dedicated [google group][5], and a
|
||||||
|
[syntastic tag at StackOverflow][6].
|
||||||
|
|
||||||
|
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][7], [python-mode][8], or [YouCompleteMe][9].
|
||||||
|
|
||||||
|
[0]: https://github.com/scrooloose/syntastic/raw/master/_assets/screenshot_1.png
|
||||||
|
[1]: https://github.com/tpope/vim-pathogen
|
||||||
|
[2]: https://github.com/tpope/vim-unimpaired
|
||||||
|
[3]: https://github.com/scrooloose/syntastic/wiki/Syntax-Checkers
|
||||||
|
[4]: https://github.com/scrooloose/syntastic/issues
|
||||||
|
[5]: https://groups.google.com/group/vim-syntastic
|
||||||
|
[6]: http://stackoverflow.com/questions/tagged/syntastic
|
||||||
|
[7]: https://github.com/davidhalter/jedi-vim
|
||||||
|
[8]: https://github.com/klen/python-mode
|
||||||
|
[9]: http://valloric.github.io/YouCompleteMe/
|
||||||
|
[10]: http://perldoc.perl.org/perlrun.html#*-c*
|
||||||
|
[11]: https://github.com/scrooloose/syntastic/wiki/Syntax-Checker-Guide
|
||||||
|
[12]: https://github.com/rust-lang/rust/
|
BIN
sources_non_forked/syntastic/_assets/screenshot_1.png
Normal file
BIN
sources_non_forked/syntastic/_assets/screenshot_1.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 90 KiB |
332
sources_non_forked/syntastic/autoload/syntastic/c.vim
Normal file
332
sources_non_forked/syntastic/autoload/syntastic/c.vim
Normal file
|
@ -0,0 +1,332 @@
|
||||||
|
if exists("g:loaded_syntastic_c_autoload") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_c_autoload = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
" Public functions {{{1
|
||||||
|
|
||||||
|
" convenience function to determine the 'null device' parameter
|
||||||
|
" based on the current operating system
|
||||||
|
function! syntastic#c#NullOutput() " {{{2
|
||||||
|
let known_os = has('unix') || has('mac') || syntastic#util#isRunningWindows()
|
||||||
|
return known_os ? '-o ' . syntastic#util#DevNull() : ''
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" read additional compiler flags from the given configuration file
|
||||||
|
" the file format and its parsing mechanism is inspired by clang_complete
|
||||||
|
function! syntastic#c#ReadConfig(file) " {{{2
|
||||||
|
" search in the current file's directory upwards
|
||||||
|
let config = findfile(a:file, '.;')
|
||||||
|
if config == '' || !filereadable(config)
|
||||||
|
return ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
" convert filename into absolute path
|
||||||
|
let filepath = fnamemodify(config, ':p:h')
|
||||||
|
|
||||||
|
" try to read config file
|
||||||
|
try
|
||||||
|
let lines = readfile(config)
|
||||||
|
catch /\m^Vim\%((\a\+)\)\=:E48[45]/
|
||||||
|
return ''
|
||||||
|
endtry
|
||||||
|
|
||||||
|
" filter out empty lines and comments
|
||||||
|
call filter(lines, 'v:val !~ ''\v^(\s*#|$)''')
|
||||||
|
|
||||||
|
" remove leading and trailing spaces
|
||||||
|
call map(lines, 'substitute(v:val, ''\m^\s\+'', "", "")')
|
||||||
|
call map(lines, 'substitute(v:val, ''\m\s\+$'', "", "")')
|
||||||
|
|
||||||
|
let parameters = []
|
||||||
|
for line in lines
|
||||||
|
let matches = matchstr(line, '\m\C^\s*-I\s*\zs.\+')
|
||||||
|
if matches != ''
|
||||||
|
" this one looks like an absolute path
|
||||||
|
if match(matches, '\m^\%(/\|\a:\)') != -1
|
||||||
|
call add(parameters, '-I' . matches)
|
||||||
|
else
|
||||||
|
call add(parameters, '-I' . filepath . syntastic#util#Slash() . matches)
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
call add(parameters, line)
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return join(map(parameters, 'syntastic#util#shescape(v:val)'))
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" GetLocList() for C-like compilers
|
||||||
|
function! syntastic#c#GetLocList(filetype, subchecker, options) " {{{2
|
||||||
|
try
|
||||||
|
let flags = s:_getCflags(a:filetype, a:subchecker, a:options)
|
||||||
|
catch /\m\C^Syntastic: skip checks$/
|
||||||
|
return []
|
||||||
|
endtry
|
||||||
|
|
||||||
|
let makeprg = syntastic#util#shexpand(g:syntastic_{a:filetype}_compiler) .
|
||||||
|
\ ' ' . flags . ' ' . syntastic#util#shexpand('%')
|
||||||
|
|
||||||
|
let errorformat = s:_getCheckerVar('g', a:filetype, a:subchecker, 'errorformat', a:options['errorformat'])
|
||||||
|
|
||||||
|
let postprocess = s:_getCheckerVar('g', a:filetype, a:subchecker, 'remove_include_errors', 0) ?
|
||||||
|
\ ['filterForeignErrors'] : []
|
||||||
|
|
||||||
|
" process makeprg
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'postprocess': postprocess })
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private functions {{{1
|
||||||
|
|
||||||
|
" initialize c/cpp syntax checker handlers
|
||||||
|
function! s:_init() " {{{2
|
||||||
|
let s:handlers = []
|
||||||
|
let s:cflags = {}
|
||||||
|
|
||||||
|
call s:_regHandler('\m\<cairo', 'syntastic#c#checkPKG', ['cairo', 'cairo'])
|
||||||
|
call s:_regHandler('\m\<freetype', 'syntastic#c#checkPKG', ['freetype', 'freetype2', 'freetype'])
|
||||||
|
call s:_regHandler('\m\<glade', 'syntastic#c#checkPKG', ['glade', 'libglade-2.0', 'libglade'])
|
||||||
|
call s:_regHandler('\m\<glib', 'syntastic#c#checkPKG', ['glib', 'glib-2.0', 'glib'])
|
||||||
|
call s:_regHandler('\m\<gtk', 'syntastic#c#checkPKG', ['gtk', 'gtk+-2.0', 'gtk+', 'glib-2.0', 'glib'])
|
||||||
|
call s:_regHandler('\m\<libsoup', 'syntastic#c#checkPKG', ['libsoup', 'libsoup-2.4', 'libsoup-2.2'])
|
||||||
|
call s:_regHandler('\m\<libxml', 'syntastic#c#checkPKG', ['libxml', 'libxml-2.0', 'libxml'])
|
||||||
|
call s:_regHandler('\m\<pango', 'syntastic#c#checkPKG', ['pango', 'pango'])
|
||||||
|
call s:_regHandler('\m\<SDL', 'syntastic#c#checkPKG', ['sdl', 'sdl'])
|
||||||
|
call s:_regHandler('\m\<opengl', 'syntastic#c#checkPKG', ['opengl', 'gl'])
|
||||||
|
call s:_regHandler('\m\<webkit', 'syntastic#c#checkPKG', ['webkit', 'webkit-1.0'])
|
||||||
|
|
||||||
|
call s:_regHandler('\m\<php\.h\>', 'syntastic#c#checkPHP', [])
|
||||||
|
call s:_regHandler('\m\<Python\.h\>', 'syntastic#c#checkPython', [])
|
||||||
|
call s:_regHandler('\m\<ruby', 'syntastic#c#checkRuby', [])
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" return a handler dictionary object
|
||||||
|
function! s:_regHandler(regex, function, args) " {{{2
|
||||||
|
let handler = {}
|
||||||
|
let handler["regex"] = a:regex
|
||||||
|
let handler["func"] = function(a:function)
|
||||||
|
let handler["args"] = a:args
|
||||||
|
call add(s:handlers, handler)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" resolve checker-related user variables
|
||||||
|
function! s:_getCheckerVar(scope, filetype, subchecker, name, default) " {{{2
|
||||||
|
let prefix = a:scope . ':' . 'syntastic_'
|
||||||
|
if exists(prefix . a:filetype . '_' . a:subchecker . '_' . a:name)
|
||||||
|
return {a:scope}:syntastic_{a:filetype}_{a:subchecker}_{a:name}
|
||||||
|
elseif exists(prefix . a:filetype . '_' . a:name)
|
||||||
|
return {a:scope}:syntastic_{a:filetype}_{a:name}
|
||||||
|
else
|
||||||
|
return a:default
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" resolve user CFLAGS
|
||||||
|
function! s:_getCflags(ft, ck, opts) " {{{2
|
||||||
|
" determine whether to parse header files as well
|
||||||
|
if has_key(a:opts, 'header_names') && expand('%') =~? a:opts['header_names']
|
||||||
|
if s:_getCheckerVar('g', a:ft, a:ck, 'check_header', 0)
|
||||||
|
let flags = get(a:opts, 'header_flags', '') . ' -c ' . syntastic#c#NullOutput()
|
||||||
|
else
|
||||||
|
" checking headers when check_header is unset: bail out
|
||||||
|
throw 'Syntastic: skip checks'
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
let flags = get(a:opts, 'main_flags', '')
|
||||||
|
endif
|
||||||
|
|
||||||
|
let flags .= ' ' . s:_getCheckerVar('g', a:ft, a:ck, 'compiler_options', '') . ' ' . s:_getIncludeDirs(a:ft)
|
||||||
|
|
||||||
|
" check if the user manually set some cflags
|
||||||
|
let b_cflags = s:_getCheckerVar('b', a:ft, a:ck, 'cflags', '')
|
||||||
|
if b_cflags == ''
|
||||||
|
" check whether to search for include files at all
|
||||||
|
if !s:_getCheckerVar('g', a:ft, a:ck, 'no_include_search', 0)
|
||||||
|
if a:ft ==# 'c' || a:ft ==# 'cpp'
|
||||||
|
" refresh the include file search if desired
|
||||||
|
if s:_getCheckerVar('g', a:ft, a:ck, 'auto_refresh_includes', 0)
|
||||||
|
let flags .= ' ' . s:_searchHeaders()
|
||||||
|
else
|
||||||
|
" search for header includes if not cached already
|
||||||
|
if !exists('b:syntastic_' . a:ft . '_includes')
|
||||||
|
let b:syntastic_{a:ft}_includes = s:_searchHeaders()
|
||||||
|
endif
|
||||||
|
let flags .= ' ' . b:syntastic_{a:ft}_includes
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
" user-defined cflags
|
||||||
|
let flags .= ' ' . b_cflags
|
||||||
|
endif
|
||||||
|
|
||||||
|
" add optional config file parameters
|
||||||
|
let config_file = s:_getCheckerVar('g', a:ft, a:ck, 'config_file', '.syntastic_' . a:ft . '_config')
|
||||||
|
let flags .= ' ' . syntastic#c#ReadConfig(config_file)
|
||||||
|
|
||||||
|
return flags
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" get the gcc include directory argument depending on the default
|
||||||
|
" includes and the optional user-defined 'g:syntastic_c_include_dirs'
|
||||||
|
function! s:_getIncludeDirs(filetype) " {{{2
|
||||||
|
let include_dirs = []
|
||||||
|
|
||||||
|
if a:filetype =~# '\v^%(c|cpp|objc|objcpp)$' &&
|
||||||
|
\ (!exists('g:syntastic_'.a:filetype.'_no_default_include_dirs') ||
|
||||||
|
\ !g:syntastic_{a:filetype}_no_default_include_dirs)
|
||||||
|
let include_dirs = copy(s:default_includes)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if exists('g:syntastic_'.a:filetype.'_include_dirs')
|
||||||
|
call extend(include_dirs, g:syntastic_{a:filetype}_include_dirs)
|
||||||
|
endif
|
||||||
|
|
||||||
|
return join(map(syntastic#util#unique(include_dirs), 'syntastic#util#shescape("-I" . v:val)'))
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" search the first 100 lines for include statements that are
|
||||||
|
" given in the handlers dictionary
|
||||||
|
function! s:_searchHeaders() " {{{2
|
||||||
|
let includes = ''
|
||||||
|
let files = []
|
||||||
|
let found = []
|
||||||
|
let lines = filter(getline(1, 100), 'v:val =~# ''\m^\s*#\s*include''')
|
||||||
|
|
||||||
|
" search current buffer
|
||||||
|
for line in lines
|
||||||
|
let file = matchstr(line, '\m"\zs\S\+\ze"')
|
||||||
|
if file != ''
|
||||||
|
call add(files, file)
|
||||||
|
continue
|
||||||
|
endif
|
||||||
|
|
||||||
|
for handler in s:handlers
|
||||||
|
if line =~# handler["regex"]
|
||||||
|
let includes .= call(handler["func"], handler["args"])
|
||||||
|
call add(found, handler["regex"])
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
endfor
|
||||||
|
|
||||||
|
" search included headers
|
||||||
|
for hfile in files
|
||||||
|
if hfile != ''
|
||||||
|
let filename = expand('%:p:h') . syntastic#util#Slash() . hfile
|
||||||
|
|
||||||
|
try
|
||||||
|
let lines = readfile(filename, '', 100)
|
||||||
|
catch /\m^Vim\%((\a\+)\)\=:E484/
|
||||||
|
continue
|
||||||
|
endtry
|
||||||
|
|
||||||
|
call filter(lines, 'v:val =~# ''\m^\s*#\s*include''')
|
||||||
|
|
||||||
|
for handler in s:handlers
|
||||||
|
if index(found, handler["regex"]) != -1
|
||||||
|
continue
|
||||||
|
endif
|
||||||
|
|
||||||
|
for line in lines
|
||||||
|
if line =~# handler["regex"]
|
||||||
|
let includes .= call(handler["func"], handler["args"])
|
||||||
|
call add(found, handler["regex"])
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return includes
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" try to find library with 'pkg-config'
|
||||||
|
" search possible libraries from first to last given
|
||||||
|
" argument until one is found
|
||||||
|
function! syntastic#c#checkPKG(name, ...) " {{{2
|
||||||
|
if executable('pkg-config')
|
||||||
|
if !has_key(s:cflags, a:name)
|
||||||
|
for pkg in a:000
|
||||||
|
let pkg_flags = system('pkg-config --cflags ' . pkg)
|
||||||
|
" since we cannot necessarily trust the pkg-config exit code
|
||||||
|
" we have to check for an error output as well
|
||||||
|
if v:shell_error == 0 && pkg_flags !~? 'not found'
|
||||||
|
let pkg_flags = ' ' . substitute(pkg_flags, "\n", '', '')
|
||||||
|
let s:cflags[a:name] = pkg_flags
|
||||||
|
return pkg_flags
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
else
|
||||||
|
return s:cflags[a:name]
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
return ''
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" try to find PHP includes with 'php-config'
|
||||||
|
function! syntastic#c#checkPHP() " {{{2
|
||||||
|
if executable('php-config')
|
||||||
|
if !has_key(s:cflags, 'php')
|
||||||
|
let s:cflags['php'] = system('php-config --includes')
|
||||||
|
let s:cflags['php'] = ' ' . substitute(s:cflags['php'], "\n", '', '')
|
||||||
|
endif
|
||||||
|
return s:cflags['php']
|
||||||
|
endif
|
||||||
|
return ''
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" try to find the ruby headers with 'rbconfig'
|
||||||
|
function! syntastic#c#checkRuby() " {{{2
|
||||||
|
if executable('ruby')
|
||||||
|
if !has_key(s:cflags, 'ruby')
|
||||||
|
let s:cflags['ruby'] = system('ruby -r rbconfig -e ' .
|
||||||
|
\ '''puts RbConfig::CONFIG["rubyhdrdir"] || RbConfig::CONFIG["archdir"]''')
|
||||||
|
let s:cflags['ruby'] = substitute(s:cflags['ruby'], "\n", '', '')
|
||||||
|
let s:cflags['ruby'] = ' -I' . s:cflags['ruby']
|
||||||
|
endif
|
||||||
|
return s:cflags['ruby']
|
||||||
|
endif
|
||||||
|
return ''
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" try to find the python headers with distutils
|
||||||
|
function! syntastic#c#checkPython() " {{{2
|
||||||
|
if executable('python')
|
||||||
|
if !has_key(s:cflags, 'python')
|
||||||
|
let s:cflags['python'] = system('python -c ''from distutils import ' .
|
||||||
|
\ 'sysconfig; import sys; sys.stdout.write(sysconfig.get_python_inc())''')
|
||||||
|
let s:cflags['python'] = substitute(s:cflags['python'], "\n", '', '')
|
||||||
|
let s:cflags['python'] = ' -I' . s:cflags['python']
|
||||||
|
endif
|
||||||
|
return s:cflags['python']
|
||||||
|
endif
|
||||||
|
return ''
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" default include directories
|
||||||
|
let s:default_includes = [
|
||||||
|
\ '.',
|
||||||
|
\ '..',
|
||||||
|
\ 'include',
|
||||||
|
\ 'includes',
|
||||||
|
\ '..' . syntastic#util#Slash() . 'include',
|
||||||
|
\ '..' . syntastic#util#Slash() . 'includes' ]
|
||||||
|
|
||||||
|
call s:_init()
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
178
sources_non_forked/syntastic/autoload/syntastic/log.vim
Normal file
178
sources_non_forked/syntastic/autoload/syntastic/log.vim
Normal file
|
@ -0,0 +1,178 @@
|
||||||
|
if exists("g:loaded_syntastic_log_autoload") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_log_autoload = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
let s:one_time_notices_issued = []
|
||||||
|
|
||||||
|
" Public functions {{{1
|
||||||
|
|
||||||
|
function! syntastic#log#info(msg) " {{{2
|
||||||
|
echomsg "syntastic: info: " . a:msg
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#log#warn(msg) " {{{2
|
||||||
|
echohl WarningMsg
|
||||||
|
echomsg "syntastic: warning: " . a:msg
|
||||||
|
echohl None
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#log#error(msg) " {{{2
|
||||||
|
execute "normal \<Esc>"
|
||||||
|
echohl ErrorMsg
|
||||||
|
echomsg "syntastic: error: " . a:msg
|
||||||
|
echohl None
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#log#oneTimeWarn(msg) " {{{2
|
||||||
|
if index(s:one_time_notices_issued, a:msg) >= 0
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
call add(s:one_time_notices_issued, a:msg)
|
||||||
|
call syntastic#log#warn(a:msg)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" @vimlint(EVL102, 1, l:OLD_VAR)
|
||||||
|
function! syntastic#log#deprecationWarn(old, new, ...) " {{{2
|
||||||
|
if exists('g:syntastic_' . a:old) && !exists('g:syntastic_' . a:new)
|
||||||
|
let msg = 'variable g:syntastic_' . a:old . ' is deprecated, please use '
|
||||||
|
|
||||||
|
if a:0
|
||||||
|
let OLD_VAR = g:syntastic_{a:old}
|
||||||
|
try
|
||||||
|
let NEW_VAR = eval(a:1)
|
||||||
|
let msg .= 'in its stead: let g:syntastic_' . a:new . ' = ' . string(NEW_VAR)
|
||||||
|
let g:syntastic_{a:new} = NEW_VAR
|
||||||
|
catch
|
||||||
|
let msg .= 'g:syntastic_' . a:new . ' instead'
|
||||||
|
endtry
|
||||||
|
else
|
||||||
|
let msg .= 'g:syntastic_' . a:new . ' instead'
|
||||||
|
let g:syntastic_{a:new} = g:syntastic_{a:old}
|
||||||
|
endif
|
||||||
|
|
||||||
|
call syntastic#log#oneTimeWarn(msg)
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
" @vimlint(EVL102, 0, l:OLD_VAR)
|
||||||
|
|
||||||
|
function! syntastic#log#debug(level, msg, ...) " {{{2
|
||||||
|
if !s:isDebugEnabled(a:level)
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
let leader = s:_logTimestamp()
|
||||||
|
call s:_logRedirect(1)
|
||||||
|
|
||||||
|
if a:0 > 0
|
||||||
|
" filter out dictionary functions
|
||||||
|
echomsg leader . a:msg . ' ' .
|
||||||
|
\ strtrans(string(type(a:1) == type({}) || type(a:1) == type([]) ?
|
||||||
|
\ filter(copy(a:1), 'type(v:val) != type(function("tr"))') : a:1))
|
||||||
|
else
|
||||||
|
echomsg leader . a:msg
|
||||||
|
endif
|
||||||
|
|
||||||
|
call s:_logRedirect(0)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#log#debugShowOptions(level, names) " {{{2
|
||||||
|
if !s:isDebugEnabled(a:level)
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
let leader = s:_logTimestamp()
|
||||||
|
call s:_logRedirect(1)
|
||||||
|
|
||||||
|
let vlist = copy(type(a:names) == type("") ? [a:names] : a:names)
|
||||||
|
if !empty(vlist)
|
||||||
|
call map(vlist, "'&' . v:val . ' = ' . strtrans(string(eval('&' . v:val)))")
|
||||||
|
echomsg leader . join(vlist, ', ')
|
||||||
|
endif
|
||||||
|
call s:_logRedirect(0)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#log#debugShowVariables(level, names) " {{{2
|
||||||
|
if !s:isDebugEnabled(a:level)
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
let leader = s:_logTimestamp()
|
||||||
|
call s:_logRedirect(1)
|
||||||
|
|
||||||
|
let vlist = type(a:names) == type("") ? [a:names] : a:names
|
||||||
|
for name in vlist
|
||||||
|
let msg = s:_formatVariable(name)
|
||||||
|
if msg != ''
|
||||||
|
echomsg leader . msg
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
call s:_logRedirect(0)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#log#debugDump(level) " {{{2
|
||||||
|
if !s:isDebugEnabled(a:level)
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
call syntastic#log#debugShowVariables( a:level, sort(keys(g:syntastic_defaults)) )
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private functions {{{1
|
||||||
|
|
||||||
|
function! s:_isDebugEnabled_smart(level) " {{{2
|
||||||
|
return and(g:syntastic_debug, a:level)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:_isDebugEnabled_dumb(level) " {{{2
|
||||||
|
" poor man's bit test for bit N, assuming a:level == 2**N
|
||||||
|
return (g:syntastic_debug / a:level) % 2
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
let s:isDebugEnabled = function(exists('*and') ? 's:_isDebugEnabled_smart' : 's:_isDebugEnabled_dumb')
|
||||||
|
lockvar s:isDebugEnabled
|
||||||
|
|
||||||
|
function! s:_logRedirect(on) " {{{2
|
||||||
|
if exists("g:syntastic_debug_file")
|
||||||
|
if a:on
|
||||||
|
try
|
||||||
|
execute 'redir >> ' . fnameescape(expand(g:syntastic_debug_file))
|
||||||
|
catch /\m^Vim\%((\a\+)\)\=:/
|
||||||
|
silent! redir END
|
||||||
|
unlet g:syntastic_debug_file
|
||||||
|
endtry
|
||||||
|
else
|
||||||
|
silent! redir END
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:_logTimestamp() " {{{2
|
||||||
|
return 'syntastic: ' . split(reltimestr(reltime(g:syntastic_start)))[0] . ': '
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:_formatVariable(name) " {{{2
|
||||||
|
let vals = []
|
||||||
|
if exists('g:syntastic_' . a:name)
|
||||||
|
call add(vals, 'g:syntastic_' . a:name . ' = ' . strtrans(string(g:syntastic_{a:name})))
|
||||||
|
endif
|
||||||
|
if exists('b:syntastic_' . a:name)
|
||||||
|
call add(vals, 'b:syntastic_' . a:name . ' = ' . strtrans(string(b:syntastic_{a:name})))
|
||||||
|
endif
|
||||||
|
|
||||||
|
return join(vals, ', ')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -0,0 +1,54 @@
|
||||||
|
if exists("g:loaded_syntastic_postprocess_autoload") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_postprocess_autoload = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
" Public functions {{{1
|
||||||
|
|
||||||
|
" merge consecutive blanks
|
||||||
|
function! syntastic#postprocess#compressWhitespace(errors) " {{{2
|
||||||
|
for e in a:errors
|
||||||
|
let e['text'] = substitute(e['text'], "\001", '', 'g')
|
||||||
|
let e['text'] = substitute(e['text'], '\n', ' ', 'g')
|
||||||
|
let e['text'] = substitute(e['text'], '\m\s\{2,}', ' ', 'g')
|
||||||
|
let e['text'] = substitute(e['text'], '\m^\s\+', '', '')
|
||||||
|
let e['text'] = substitute(e['text'], '\m\s\+$', '', '')
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return a:errors
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" remove spurious CR under Cygwin
|
||||||
|
function! syntastic#postprocess#cygwinRemoveCR(errors) " {{{2
|
||||||
|
if has('win32unix')
|
||||||
|
for e in a:errors
|
||||||
|
let e['text'] = substitute(e['text'], '\r', '', 'g')
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
|
||||||
|
return a:errors
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" decode XML entities
|
||||||
|
function! syntastic#postprocess#decodeXMLEntities(errors) " {{{2
|
||||||
|
for e in a:errors
|
||||||
|
let e['text'] = syntastic#util#decodeXMLEntities(e['text'])
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return a:errors
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" filter out errors referencing other files
|
||||||
|
function! syntastic#postprocess#filterForeignErrors(errors) " {{{2
|
||||||
|
return filter(copy(a:errors), 'get(v:val, "bufnr") == ' . bufnr(''))
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
142
sources_non_forked/syntastic/autoload/syntastic/preprocess.vim
Normal file
142
sources_non_forked/syntastic/autoload/syntastic/preprocess.vim
Normal file
|
@ -0,0 +1,142 @@
|
||||||
|
if exists("g:loaded_syntastic_preprocess_autoload") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_preprocess_autoload = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
" Public functions {{{1
|
||||||
|
|
||||||
|
function! syntastic#preprocess#cabal(errors) " {{{2
|
||||||
|
let out = []
|
||||||
|
let star = 0
|
||||||
|
for err in a:errors
|
||||||
|
if star
|
||||||
|
if err == ''
|
||||||
|
let star = 0
|
||||||
|
else
|
||||||
|
let out[-1] .= ' ' . err
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
call add(out, err)
|
||||||
|
if err =~ '\m^*\s'
|
||||||
|
let star = 1
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
return out
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#preprocess#checkstyle(errors) " {{{2
|
||||||
|
let out = []
|
||||||
|
let fname = expand('%')
|
||||||
|
for err in a:errors
|
||||||
|
if match(err, '\m<error\>') > -1
|
||||||
|
let line = str2nr(matchstr(err, '\m\<line="\zs\d\+\ze"'))
|
||||||
|
if line == 0
|
||||||
|
continue
|
||||||
|
endif
|
||||||
|
|
||||||
|
let col = str2nr(matchstr(err, '\m\<column="\zs\d\+\ze"'))
|
||||||
|
|
||||||
|
let type = matchstr(err, '\m\<severity="\zs.\ze')
|
||||||
|
if type !~? '^[EW]'
|
||||||
|
let type = 'E'
|
||||||
|
endif
|
||||||
|
|
||||||
|
let message = syntastic#util#decodeXMLEntities(matchstr(err, '\m\<message="\zs[^"]\+\ze"'))
|
||||||
|
|
||||||
|
call add(out, join([fname, type, line, col, message], ':'))
|
||||||
|
elseif match(err, '\m<file name="') > -1
|
||||||
|
let fname = syntastic#util#decodeXMLEntities(matchstr(err, '\v\<file name\="\zs[^"]+\ze"'))
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
return out
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#preprocess#cppcheck(errors) " {{{2
|
||||||
|
return map(copy(a:errors), 'substitute(v:val, ''\v^\[[^]]+\]\zs( -\> \[[^]]+\])+\ze:'', "", "")')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#preprocess#killEmpty(errors) " {{{2
|
||||||
|
return filter(copy(a:errors), 'v:val != ""')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#preprocess#perl(errors) " {{{2
|
||||||
|
let out = []
|
||||||
|
|
||||||
|
for e in a:errors
|
||||||
|
let parts = matchlist(e, '\v^(.*)\sat\s(.*)\sline\s(\d+)(.*)$')
|
||||||
|
if !empty(parts)
|
||||||
|
call add(out, parts[2] . ':' . parts[3] . ':' . parts[1] . parts[4])
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return syntastic#util#unique(out)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#preprocess#rparse(errors) " {{{2
|
||||||
|
let errlist = copy(a:errors)
|
||||||
|
|
||||||
|
" remove uninteresting lines and handle continuations
|
||||||
|
let i = 0
|
||||||
|
while i < len(errlist)
|
||||||
|
if i > 0 && errlist[i][:1] == ' ' && errlist[i] !~ '\m\s\+\^$'
|
||||||
|
let errlist[i-1] .= errlist[i][1:]
|
||||||
|
call remove(errlist, i)
|
||||||
|
elseif errlist[i] !~ '\m^\(Lint:\|Lint checking:\|Error in\) '
|
||||||
|
call remove(errlist, i)
|
||||||
|
else
|
||||||
|
let i += 1
|
||||||
|
endif
|
||||||
|
endwhile
|
||||||
|
|
||||||
|
let out = []
|
||||||
|
let fname = ''
|
||||||
|
for e in errlist
|
||||||
|
if match(e, '\m^Lint: ') == 0
|
||||||
|
let parts = matchlist(e, '\m^Lint: \(.*\): found on lines \([0-9, ]\+\)\(+\(\d\+\) more\)\=')
|
||||||
|
if len(parts) >= 3
|
||||||
|
for line in split(parts[2], '\m,\s*')
|
||||||
|
call add(out, 'E:' . fname . ':' . line . ': ' . parts[1])
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
if len(parts) >= 5 && parts[4] != ''
|
||||||
|
call add(out, 'E:' . fname . ':0: ' . parts[1] . ' - ' . parts[4] . ' messages not shown')
|
||||||
|
endif
|
||||||
|
elseif match(e, '\m^Lint checking: ') == 0
|
||||||
|
let fname = matchstr(e, '\m^Lint checking: \zs.*')
|
||||||
|
elseif match(e, '\m^Error in ') == 0
|
||||||
|
call add(out, substitute(e, '\m^Error in .\+ : .\+\ze:\d\+:\d\+: ', 'E:' . fname, ''))
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return out
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#preprocess#tslint(errors) " {{{2
|
||||||
|
return map(copy(a:errors), 'substitute(v:val, ''\m^\(([^)]\+)\)\s\(.\+\)$'', ''\2 \1'', "")')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#preprocess#validator(errors) " {{{2
|
||||||
|
let out = []
|
||||||
|
for e in a:errors
|
||||||
|
let parts = matchlist(e, '\v^"([^"]+)"(.+)')
|
||||||
|
if len(parts) >= 3
|
||||||
|
" URL decode, except leave alone any "+"
|
||||||
|
let parts[1] = substitute(parts[1], '\m%\(\x\x\)', '\=nr2char("0x".submatch(1))', 'g')
|
||||||
|
let parts[1] = substitute(parts[1], '\m\\"', '"', 'g')
|
||||||
|
let parts[1] = substitute(parts[1], '\m\\\\', '\\', 'g')
|
||||||
|
call add(out, '"' . parts[1] . '"' . parts[2])
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
return out
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
286
sources_non_forked/syntastic/autoload/syntastic/util.vim
Normal file
286
sources_non_forked/syntastic/autoload/syntastic/util.vim
Normal file
|
@ -0,0 +1,286 @@
|
||||||
|
if exists('g:loaded_syntastic_util_autoload') || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_util_autoload = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
" Public functions {{{1
|
||||||
|
|
||||||
|
function! syntastic#util#isRunningWindows() " {{{2
|
||||||
|
return has('win16') || has('win32') || has('win64')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#util#DevNull() " {{{2
|
||||||
|
if syntastic#util#isRunningWindows()
|
||||||
|
return 'NUL'
|
||||||
|
endif
|
||||||
|
return '/dev/null'
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Get directory separator
|
||||||
|
function! syntastic#util#Slash() abort " {{{2
|
||||||
|
return (!exists("+shellslash") || &shellslash) ? '/' : '\'
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
"search the first 5 lines of the file for a magic number and return a map
|
||||||
|
"containing the args and the executable
|
||||||
|
"
|
||||||
|
"e.g.
|
||||||
|
"
|
||||||
|
"#!/usr/bin/perl -f -bar
|
||||||
|
"
|
||||||
|
"returns
|
||||||
|
"
|
||||||
|
"{'exe': '/usr/bin/perl', 'args': ['-f', '-bar']}
|
||||||
|
function! syntastic#util#parseShebang() " {{{2
|
||||||
|
for lnum in range(1, 5)
|
||||||
|
let line = getline(lnum)
|
||||||
|
if line =~ '^#!'
|
||||||
|
let line = substitute(line, '\v^#!\s*(\S+/env(\s+-\S+)*\s+)?', '', '')
|
||||||
|
let exe = matchstr(line, '\m^\S*\ze')
|
||||||
|
let args = split(matchstr(line, '\m^\S*\zs.*'))
|
||||||
|
return { 'exe': exe, 'args': args }
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return { 'exe': '', 'args': [] }
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Get the value of a variable. Allow local variables to override global ones.
|
||||||
|
function! syntastic#util#var(name, ...) " {{{2
|
||||||
|
return
|
||||||
|
\ exists('b:syntastic_' . a:name) ? b:syntastic_{a:name} :
|
||||||
|
\ exists('g:syntastic_' . a:name) ? g:syntastic_{a:name} :
|
||||||
|
\ a:0 > 0 ? a:1 : ''
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Parse a version string. Return an array of version components.
|
||||||
|
function! syntastic#util#parseVersion(version) " {{{2
|
||||||
|
return map(split(matchstr( a:version, '\v^\D*\zs\d+(\.\d+)+\ze' ), '\m\.'), 'str2nr(v:val)')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Run 'command' in a shell and parse output as a version string.
|
||||||
|
" Returns an array of version components.
|
||||||
|
function! syntastic#util#getVersion(command) " {{{2
|
||||||
|
return syntastic#util#parseVersion(system(a:command))
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Verify that the 'installed' version is at least the 'required' version.
|
||||||
|
"
|
||||||
|
" 'installed' and 'required' must be arrays. If they have different lengths,
|
||||||
|
" the "missing" elements will be assumed to be 0 for the purposes of checking.
|
||||||
|
"
|
||||||
|
" See http://semver.org for info about version numbers.
|
||||||
|
function! syntastic#util#versionIsAtLeast(installed, required) " {{{2
|
||||||
|
return syntastic#util#compareLexi(a:installed, a:required) >= 0
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Almost lexicographic comparison of two lists of integers. :) If lists
|
||||||
|
" have different lengths, the "missing" elements are assumed to be 0.
|
||||||
|
function! syntastic#util#compareLexi(a, b) " {{{2
|
||||||
|
for idx in range(max([len(a:a), len(a:b)]))
|
||||||
|
let a_element = str2nr(get(a:a, idx, 0))
|
||||||
|
let b_element = str2nr(get(a:b, idx, 0))
|
||||||
|
if a_element != b_element
|
||||||
|
return a_element > b_element ? 1 : -1
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
" Everything matched, so it is at least the required version.
|
||||||
|
return 0
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" strwidth() was added in Vim 7.3; if it doesn't exist, we use strlen()
|
||||||
|
" and hope for the best :)
|
||||||
|
let s:width = function(exists('*strwidth') ? 'strwidth' : 'strlen')
|
||||||
|
lockvar s:width
|
||||||
|
|
||||||
|
function! syntastic#util#screenWidth(str, tabstop) " {{{2
|
||||||
|
let chunks = split(a:str, "\t", 1)
|
||||||
|
let width = s:width(chunks[-1])
|
||||||
|
for c in chunks[:-2]
|
||||||
|
let cwidth = s:width(c)
|
||||||
|
let width += cwidth + a:tabstop - cwidth % a:tabstop
|
||||||
|
endfor
|
||||||
|
return width
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
"print as much of a:msg as possible without "Press Enter" prompt appearing
|
||||||
|
function! syntastic#util#wideMsg(msg) " {{{2
|
||||||
|
let old_ruler = &ruler
|
||||||
|
let old_showcmd = &showcmd
|
||||||
|
|
||||||
|
"This is here because it is possible for some error messages to
|
||||||
|
"begin with \n which will cause a "press enter" prompt.
|
||||||
|
let msg = substitute(a:msg, "\n", "", "g")
|
||||||
|
|
||||||
|
"convert tabs to spaces so that the tabs count towards the window
|
||||||
|
"width as the proper amount of characters
|
||||||
|
let chunks = split(msg, "\t", 1)
|
||||||
|
let msg = join(map(chunks[:-2], 'v:val . repeat(" ", &tabstop - s:width(v:val) % &tabstop)'), '') . chunks[-1]
|
||||||
|
let msg = strpart(msg, 0, &columns - 1)
|
||||||
|
|
||||||
|
set noruler noshowcmd
|
||||||
|
call syntastic#util#redraw(0)
|
||||||
|
|
||||||
|
echo msg
|
||||||
|
|
||||||
|
let &ruler = old_ruler
|
||||||
|
let &showcmd = old_showcmd
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Check whether a buffer is loaded, listed, and not hidden
|
||||||
|
function! syntastic#util#bufIsActive(buffer) " {{{2
|
||||||
|
" convert to number, or hell breaks loose
|
||||||
|
let buf = str2nr(a:buffer)
|
||||||
|
|
||||||
|
if !bufloaded(buf) || !buflisted(buf)
|
||||||
|
return 0
|
||||||
|
endif
|
||||||
|
|
||||||
|
" get rid of hidden buffers
|
||||||
|
for tab in range(1, tabpagenr('$'))
|
||||||
|
if index(tabpagebuflist(tab), buf) >= 0
|
||||||
|
return 1
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return 0
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" start in directory a:where and walk up the parent folders until it
|
||||||
|
" finds a file matching a:what; return path to that file
|
||||||
|
function! syntastic#util#findInParent(what, where) " {{{2
|
||||||
|
let here = fnamemodify(a:where, ':p')
|
||||||
|
|
||||||
|
let root = syntastic#util#Slash()
|
||||||
|
if syntastic#util#isRunningWindows() && here[1] == ':'
|
||||||
|
" The drive letter is an ever-green source of fun. That's because
|
||||||
|
" we don't care about running syntastic on Amiga these days. ;)
|
||||||
|
let root = fnamemodify(root, ':p')
|
||||||
|
let root = here[0] . root[1:]
|
||||||
|
endif
|
||||||
|
|
||||||
|
let old = ''
|
||||||
|
while here != ''
|
||||||
|
let p = split(globpath(here, a:what), '\n')
|
||||||
|
|
||||||
|
if !empty(p)
|
||||||
|
return fnamemodify(p[0], ':p')
|
||||||
|
elseif here ==? root || here ==? old
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
|
||||||
|
let old = here
|
||||||
|
|
||||||
|
" we use ':h:h' rather than ':h' since ':p' adds a trailing '/'
|
||||||
|
" if 'here' is a directory
|
||||||
|
let here = fnamemodify(here, ':p:h:h')
|
||||||
|
endwhile
|
||||||
|
|
||||||
|
return ''
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Returns unique elements in a list
|
||||||
|
function! syntastic#util#unique(list) " {{{2
|
||||||
|
let seen = {}
|
||||||
|
let uniques = []
|
||||||
|
for e in a:list
|
||||||
|
if !has_key(seen, e)
|
||||||
|
let seen[e] = 1
|
||||||
|
call add(uniques, e)
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
return uniques
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" A less noisy shellescape()
|
||||||
|
function! syntastic#util#shescape(string) " {{{2
|
||||||
|
return a:string =~ '\m^[A-Za-z0-9_/.-]\+$' ? a:string : shellescape(a:string)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" A less noisy shellescape(expand())
|
||||||
|
function! syntastic#util#shexpand(string) " {{{2
|
||||||
|
return syntastic#util#shescape(expand(a:string))
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" decode XML entities
|
||||||
|
function! syntastic#util#decodeXMLEntities(string) " {{{2
|
||||||
|
let str = a:string
|
||||||
|
let str = substitute(str, '\m<', '<', 'g')
|
||||||
|
let str = substitute(str, '\m>', '>', 'g')
|
||||||
|
let str = substitute(str, '\m"', '"', 'g')
|
||||||
|
let str = substitute(str, '\m'', "'", 'g')
|
||||||
|
let str = substitute(str, '\m&', '\&', 'g')
|
||||||
|
return str
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#util#redraw(full) " {{{2
|
||||||
|
if a:full
|
||||||
|
redraw!
|
||||||
|
else
|
||||||
|
redraw
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! syntastic#util#dictFilter(errors, filter) " {{{2
|
||||||
|
let rules = s:_translateFilter(a:filter)
|
||||||
|
" call syntastic#log#debug(g:SyntasticDebugFilters, "applying filter:", rules)
|
||||||
|
try
|
||||||
|
call filter(a:errors, rules)
|
||||||
|
catch /\m^Vim\%((\a\+)\)\=:E/
|
||||||
|
let msg = matchstr(v:exception, '\m^Vim\%((\a\+)\)\=:\zs.*')
|
||||||
|
call syntastic#log#error('quiet_messages: ' . msg)
|
||||||
|
endtry
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Return a [high, low] list of integers, representing the time
|
||||||
|
" (hopefully high resolution) since program start
|
||||||
|
" TODO: This assumes reltime() returns a list of integers.
|
||||||
|
function! syntastic#util#stamp() " {{{2
|
||||||
|
return reltime(g:syntastic_start)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private functions {{{1
|
||||||
|
|
||||||
|
function! s:_translateFilter(filters) " {{{2
|
||||||
|
let conditions = []
|
||||||
|
for k in keys(a:filters)
|
||||||
|
if type(a:filters[k]) == type([])
|
||||||
|
call extend(conditions, map(copy(a:filters[k]), 's:_translateElement(k, v:val)'))
|
||||||
|
else
|
||||||
|
call add(conditions, s:_translateElement(k, a:filters[k]))
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
if conditions == []
|
||||||
|
let conditions = ["1"]
|
||||||
|
endif
|
||||||
|
return len(conditions) == 1 ? conditions[0] : join(map(conditions, '"(" . v:val . ")"'), ' && ')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:_translateElement(key, term) " {{{2
|
||||||
|
if a:key ==? 'level'
|
||||||
|
let ret = 'v:val["type"] !=? ' . string(a:term[0])
|
||||||
|
elseif a:key ==? 'type'
|
||||||
|
let ret = a:term ==? 'style' ? 'get(v:val, "subtype", "") !=? "style"' : 'has_key(v:val, "subtype")'
|
||||||
|
elseif a:key ==? 'regex'
|
||||||
|
let ret = 'v:val["text"] !~? ' . string(a:term)
|
||||||
|
elseif a:key ==? 'file'
|
||||||
|
let ret = 'bufname(str2nr(v:val["bufnr"])) !~# ' . string(a:term)
|
||||||
|
else
|
||||||
|
call syntastic#log#warn('quiet_messages: ignoring invalid key ' . strtrans(string(a:key)))
|
||||||
|
let ret = "1"
|
||||||
|
endif
|
||||||
|
return ret
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
770
sources_non_forked/syntastic/doc/syntastic.txt
Normal file
770
sources_non_forked/syntastic/doc/syntastic.txt
Normal file
|
@ -0,0 +1,770 @@
|
||||||
|
*syntastic.txt* Syntax checking on the fly has never been so pimp.
|
||||||
|
*syntastic*
|
||||||
|
|
||||||
|
|
||||||
|
It's a bird! It's a plane! ZOMG It's ... ~
|
||||||
|
|
||||||
|
_____ __ __ _ ~
|
||||||
|
/ ___/__ ______ / /_____ ______/ /_(_)____ ~
|
||||||
|
\__ \/ / / / __ \/ __/ __ `/ ___/ __/ / ___/ ~
|
||||||
|
___/ / /_/ / / / / /_/ /_/ (__ ) /_/ / /__ ~
|
||||||
|
/____/\__, /_/ /_/\__/\__,_/____/\__/_/\___/ ~
|
||||||
|
/____/ ~
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Reference Manual~
|
||||||
|
|
||||||
|
|
||||||
|
==============================================================================
|
||||||
|
CONTENTS *syntastic-contents*
|
||||||
|
|
||||||
|
1.Intro........................................|syntastic-intro|
|
||||||
|
1.1.Quick start............................|syntastic-quickstart|
|
||||||
|
2.Functionality provided.......................|syntastic-functionality|
|
||||||
|
2.1.The statusline flag....................|syntastic-statusline-flag|
|
||||||
|
2.2.Error signs............................|syntastic-error-signs|
|
||||||
|
2.3.Error window...........................|syntastic-error-window|
|
||||||
|
2.4.Error highlighting.....................|syntastic-highlighting|
|
||||||
|
2.5.Aggregating errors.....................|syntastic-aggregating-errors|
|
||||||
|
2.6.Filtering errors.......................|syntastic-filtering-errors|
|
||||||
|
3.Commands.....................................|syntastic-commands|
|
||||||
|
4.Global Options...............................|syntastic-global-options|
|
||||||
|
5.Checker Options..............................|syntastic-checker-options|
|
||||||
|
5.1.Choosing which checkers to use.........|syntastic-filetype-checkers|
|
||||||
|
5.2.Choosing the executable................|syntastic-config-exec|
|
||||||
|
5.3.Configuring specific checkers..........|syntastic-config-makeprg|
|
||||||
|
6.Notes........................................|syntastic-notes|
|
||||||
|
6.1.Handling of composite filetypes........|syntastic-composite|
|
||||||
|
6.2.Editing files over network.............|syntastic-netrw|
|
||||||
|
6.3.Interaction with python-mode...........|syntastic-pymode|
|
||||||
|
6.4.Interaction with YouCompleteMe.........|syntastic-ycm|
|
||||||
|
6.5.Interaction with the fish shell........|syntastic-fish|
|
||||||
|
6.6.Interaction with PowerShell............|syntastic-powershell|
|
||||||
|
6.7.Using syntastic with the fizsh shell...|syntastic-fizsh|
|
||||||
|
6.8.Interaction with Eclim.................|syntastic-eclim|
|
||||||
|
6.9.Interaction with vim-virtualenv........|syntastic-vim-virtualenv|
|
||||||
|
7.About........................................|syntastic-about|
|
||||||
|
8.License......................................|syntastic-license|
|
||||||
|
|
||||||
|
|
||||||
|
==============================================================================
|
||||||
|
1. Intro *syntastic-intro*
|
||||||
|
|
||||||
|
Syntastic is a syntax checking plugin that runs files through external syntax
|
||||||
|
checkers. This can be done on demand, or automatically as files are saved and
|
||||||
|
opened. 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.
|
||||||
|
|
||||||
|
Syntastic comes in two parts: the syntax checker plugins, and the core. The
|
||||||
|
syntax checker plugins are defined on a per-filetype basis where each one wraps
|
||||||
|
up an external syntax checking program. The core script delegates off to these
|
||||||
|
plugins and uses their output to provide the syntastic functionality.
|
||||||
|
|
||||||
|
Take a look at the wiki for a list of supported filetypes and checkers:
|
||||||
|
|
||||||
|
https://github.com/scrooloose/syntastic/wiki/Syntax-Checkers
|
||||||
|
|
||||||
|
Note: This doc only deals with using syntastic. To learn how to write syntax
|
||||||
|
checker integrations, see the guide on the github wiki:
|
||||||
|
|
||||||
|
https://github.com/scrooloose/syntastic/wiki/Syntax-Checker-Guide
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
1.1. Quick start *syntastic-quickstart*
|
||||||
|
|
||||||
|
Syntastic comes preconfigured with a default list of enabled checkers per
|
||||||
|
filetype. This list is kept reasonably short to prevent slowing down Vim or
|
||||||
|
trying to use conflicting checkers.
|
||||||
|
|
||||||
|
You can see the list checkers available for the current filetype with the
|
||||||
|
|:SyntasticInfo| command.
|
||||||
|
|
||||||
|
If you want to override the configured list of checkers for a filetype then
|
||||||
|
see |syntastic-checker-options| for details. You can also change the arguments
|
||||||
|
passed to a specific checker as well.
|
||||||
|
|
||||||
|
Use |:SyntasticCheck| to manually check right now. Use |:SyntasticToggleMode|
|
||||||
|
to switch between active (checking on writing the buffer) and passive (manual)
|
||||||
|
checking.
|
||||||
|
|
||||||
|
==============================================================================
|
||||||
|
2. Functionality provided *syntastic-functionality*
|
||||||
|
|
||||||
|
Syntax checking can be done automatically or on demand (see
|
||||||
|
|'syntastic_mode_map'| and |:SyntasticToggleMode| for configuring this).
|
||||||
|
|
||||||
|
When syntax checking is done, the features below can be used to notify the
|
||||||
|
user of errors. See |syntastic-global-options| for how to configure and
|
||||||
|
activate/deactivate these features.
|
||||||
|
|
||||||
|
* A statusline flag
|
||||||
|
* Signs beside lines with errors
|
||||||
|
* The |location-list| can be populated with the errors for the associated
|
||||||
|
buffer
|
||||||
|
* Erroneous parts of lines can be highlighted (this functionality is only
|
||||||
|
provided by some syntax checkers)
|
||||||
|
* Balloons (if the |+balloon_eval| feature is compiled in) can be used to
|
||||||
|
display error messages for erroneous lines when hovering the mouse over
|
||||||
|
them
|
||||||
|
* Error messages from multiple checkers can be aggregated in a single list
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
2.1. The statusline flag *syntastic-statusline-flag*
|
||||||
|
|
||||||
|
To use the statusline flag, this must appear in your |'statusline'| setting >
|
||||||
|
%{SyntasticStatuslineFlag()}
|
||||||
|
<
|
||||||
|
Something like this could be more useful: >
|
||||||
|
set statusline+=%#warningmsg#
|
||||||
|
set statusline+=%{SyntasticStatuslineFlag()}
|
||||||
|
set statusline+=%*
|
||||||
|
<
|
||||||
|
When syntax errors are detected a flag will be shown. The content of the flag
|
||||||
|
is derived from the |syntastic_stl_format| option.
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
2.2. Error signs *syntastic-error-signs*
|
||||||
|
|
||||||
|
Syntastic uses the |:sign| commands to mark lines with errors and warnings in
|
||||||
|
the sign column. To enable this feature, use the |'syntastic_enable_signs'|
|
||||||
|
option.
|
||||||
|
|
||||||
|
Signs are colored using the Error and Todo syntax highlight groups by default.
|
||||||
|
If you wish to customize the colors for the signs, you can use the following
|
||||||
|
groups:
|
||||||
|
SyntasticErrorSign - For syntax errors, links to 'error' by default
|
||||||
|
SyntasticWarningSign - For syntax warnings, links to 'todo' by default
|
||||||
|
SyntasticStyleErrorSign - For style errors, links to 'SyntasticErrorSign'
|
||||||
|
by default
|
||||||
|
SyntasticStyleWarningSign - For style warnings, links to
|
||||||
|
'SyntasticWarningSign' by default
|
||||||
|
|
||||||
|
Example: >
|
||||||
|
highlight SyntasticErrorSign guifg=white guibg=red
|
||||||
|
<
|
||||||
|
To set up highlighting for the line where a sign resides, you can use the
|
||||||
|
following highlight groups:
|
||||||
|
SyntasticErrorLine
|
||||||
|
SyntasticWarningLine
|
||||||
|
SyntasticStyleErrorLine - Links to 'SyntasticErrorLine' by default
|
||||||
|
SyntasticStyleWarningLine - Links to 'SyntasticWarningLine' by default
|
||||||
|
|
||||||
|
Example: >
|
||||||
|
highlight SyntasticErrorLine guibg=#2f0000
|
||||||
|
<
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
2.3. The error window *:Errors* *syntastic-error-window*
|
||||||
|
|
||||||
|
You can use the :Errors command to display the errors for the current buffer
|
||||||
|
in the |location-list|.
|
||||||
|
|
||||||
|
Note that when you use :Errors, the current location list is overwritten with
|
||||||
|
Syntastic's own location list.
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
2.4. Error highlighting *syntastic-highlighting*
|
||||||
|
|
||||||
|
Some checkers provide enough information for syntastic to be able to highlight
|
||||||
|
errors. By default the SpellBad syntax highlight group is used to color errors,
|
||||||
|
and the SpellCap group is used for warnings. If you wish to customize the
|
||||||
|
colors for highlighting you can use the following groups:
|
||||||
|
SyntasticError - Links to 'SpellBad' by default
|
||||||
|
SyntasticWarning - Links to 'SpellCap' by default
|
||||||
|
SyntasticStyleError - Links to SyntasticError by default
|
||||||
|
SyntasticStyleWarning - Links to SyntasticWarning by default
|
||||||
|
|
||||||
|
Example: >
|
||||||
|
highlight SyntasticError guibg=#2f0000
|
||||||
|
<
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
2.5. Aggregating errors *syntastic-aggregating-errors*
|
||||||
|
|
||||||
|
By default, namely if |'syntastic_aggregate_errors'| is unset, syntastic runs
|
||||||
|
in turn the checkers corresponding to the filetype of the current file (see
|
||||||
|
|syntastic-filetype-checkers|), and stops as soon as a checker reports any
|
||||||
|
errors. It then notifies you of the errors using the notification mechanisms
|
||||||
|
above. In this mode error lists are always produced by a single checker, and,
|
||||||
|
if you open the error window, the name of the checker that generated the errors
|
||||||
|
is shown on the statusline of the error window.
|
||||||
|
|
||||||
|
If |'syntastic_aggregate_errors'| is set, syntastic runs all checkers that
|
||||||
|
apply (still cf. |syntastic-filetype-checkers|), then aggregates errors found
|
||||||
|
by all checkers in a single list, and notifies you. In this mode each error
|
||||||
|
message is labeled with the name of the checker that generated it, but you can
|
||||||
|
disable generation of these labels by turning off '|syntastic_id_checkers|'.
|
||||||
|
|
||||||
|
If |'syntastic_sort_aggregated_errors'| is set (which is the default), messages
|
||||||
|
in the aggregated list are grouped by file, then sorted by line number, then
|
||||||
|
type, then column number. Otherwise messages produced by the same checker are
|
||||||
|
grouped together.
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
2.6 Filtering errors *syntastic-filtering-errors*
|
||||||
|
|
||||||
|
You can selectively disable some of the errors found by checkers either
|
||||||
|
using |'syntastic_quiet_messages'|, or by specifying a list of patterns in
|
||||||
|
|'syntastic_ignore_files'|.
|
||||||
|
|
||||||
|
See also: |'syntastic_<filetype>_<checker>_quiet_messages'|.
|
||||||
|
|
||||||
|
==============================================================================
|
||||||
|
3. Commands *syntastic-commands*
|
||||||
|
|
||||||
|
:Errors *:SyntasticErrors*
|
||||||
|
|
||||||
|
When errors have been detected, use this command to pop up the |location-list|
|
||||||
|
and display the error messages.
|
||||||
|
|
||||||
|
:SyntasticToggleMode *:SyntasticToggleMode*
|
||||||
|
|
||||||
|
Toggles syntastic between active and passive mode. See |'syntastic_mode_map'|
|
||||||
|
for more info.
|
||||||
|
|
||||||
|
:SyntasticCheck *:SyntasticCheck*
|
||||||
|
|
||||||
|
Manually cause a syntax check to be done. By default the checkers in the
|
||||||
|
|'g:syntastic_<filetype>_checkers'| or |'b:syntastic_checkers'| lists are run,
|
||||||
|
cf. |syntastic-filetype-checkers|. If |syntastic_aggregate_errors| is unset
|
||||||
|
(which is the default), checking stops the first time a checker reports any
|
||||||
|
errors; if |syntastic_aggregate_errors| is set, all checkers that apply are run
|
||||||
|
in turn, and all errors found are aggregated in a single list.
|
||||||
|
|
||||||
|
The command may be followed by a (space separated) list of checkers. In this
|
||||||
|
case |'g:syntastic_<filetype>_checkers'| and |'b:syntastic_checkers'| are
|
||||||
|
ignored, and the checkers named by the command's arguments are run instead, in
|
||||||
|
the order specified. The rules of |syntastic_aggregate_errors| still apply.
|
||||||
|
|
||||||
|
Example: >
|
||||||
|
:SyntasticCheck flake8 pylint
|
||||||
|
<
|
||||||
|
:SyntasticInfo *:SyntasticInfo*
|
||||||
|
|
||||||
|
The command takes an optional argument, and outputs information about the
|
||||||
|
checkers available for the filetype named by said argument, or for the current
|
||||||
|
filetype if no argument was provided.
|
||||||
|
|
||||||
|
:SyntasticReset *:SyntasticReset*
|
||||||
|
|
||||||
|
Resets the list of errors and turns off all error notifiers.
|
||||||
|
|
||||||
|
:SyntasticSetLoclist *:SyntasticSetLoclist*
|
||||||
|
|
||||||
|
If |'syntastic_always_populate_loc_list'| is not set, the |location-list| is
|
||||||
|
not filled in automatically with the list of errors detected by the checkers.
|
||||||
|
This is useful if you run syntastic along with other plugins that use location
|
||||||
|
lists. The |:SyntasticSetLoclist| command allows you to stick the errors into
|
||||||
|
the location list explicitly.
|
||||||
|
|
||||||
|
==============================================================================
|
||||||
|
4. Global Options *syntastic-global-options*
|
||||||
|
|
||||||
|
|
||||||
|
*'syntastic_check_on_open'*
|
||||||
|
Default: 0
|
||||||
|
If enabled, syntastic will do syntax checks when buffers are first loaded as
|
||||||
|
well as on saving >
|
||||||
|
let g:syntastic_check_on_open = 1
|
||||||
|
<
|
||||||
|
*'syntastic_check_on_wq'*
|
||||||
|
Default: 1
|
||||||
|
Normally syntastic runs syntax checks whenever buffers are written to disk.
|
||||||
|
If you want to skip these checks when you issue |:wq|, |:x|, and |:ZZ|, set this
|
||||||
|
variable to 0. >
|
||||||
|
let g:syntastic_check_on_wq = 0
|
||||||
|
<
|
||||||
|
*'syntastic_aggregate_errors'*
|
||||||
|
Default: 0
|
||||||
|
When enabled, syntastic runs all checkers that apply to the current filetype,
|
||||||
|
then aggregates errors found by all checkers and displays them. When disabled,
|
||||||
|
syntastic runs each checker in turn, and stops to display the results the first
|
||||||
|
time a checker finds any errors. >
|
||||||
|
let g:syntastic_aggregate_errors = 1
|
||||||
|
<
|
||||||
|
*'syntastic_id_checkers'*
|
||||||
|
Default: 1
|
||||||
|
When results from multiple checkers are aggregated in a single error list
|
||||||
|
(that is either when |syntastic_aggregate_errors| is enabled, or when checking
|
||||||
|
a file with a composite filetype), it might not be immediately obvious which
|
||||||
|
checker has produced a given error message. This variable instructs syntastic
|
||||||
|
to label error messages with the names of the checkers that created them. >
|
||||||
|
let g:syntastic_id_checkers = 0
|
||||||
|
<
|
||||||
|
*'syntastic_sort_aggregated_errors'*
|
||||||
|
Default: 1
|
||||||
|
By default, when results from multiple checkers are aggregated in a single
|
||||||
|
error list (that is either when |syntastic_aggregate_errors| is enabled, or
|
||||||
|
when checking a file with a composite filetype), errors are grouped by file,
|
||||||
|
then sorted by line number, then grouped by type (namely errors take precedence
|
||||||
|
over warnings), then they are sorted by column number. If you want to leave
|
||||||
|
messages grouped by checker output, set this variable to 0. >
|
||||||
|
let g:syntastic_sort_aggregated_errors = 0
|
||||||
|
<
|
||||||
|
*'syntastic_echo_current_error'*
|
||||||
|
Default: 1
|
||||||
|
If enabled, syntastic will echo current error to the command window. If
|
||||||
|
multiple errors are found on the same line, |syntastic_cursor_columns| is used
|
||||||
|
to decide which one is shown. >
|
||||||
|
let g:syntastic_echo_current_error = 1
|
||||||
|
<
|
||||||
|
*'syntastic_cursor_columns'*
|
||||||
|
Default: 1
|
||||||
|
This option controls which errors are echoed to the command window if
|
||||||
|
|syntastic_echo_current_error| is set and multiple errors are found on the same
|
||||||
|
line. When the option is enabled, the first error corresponding to the current
|
||||||
|
column is show. Otherwise, the first error on the current line is echoed,
|
||||||
|
regardless of the cursor position on the current line.
|
||||||
|
|
||||||
|
When dealing with very large lists of errors, disabling this option can speed
|
||||||
|
up navigation significantly: >
|
||||||
|
let g:syntastic_cursor_column = 0
|
||||||
|
<
|
||||||
|
*'syntastic_enable_signs'*
|
||||||
|
Default: 1
|
||||||
|
Use this option to tell syntastic whether to use the |:sign| interface to mark
|
||||||
|
syntax errors: >
|
||||||
|
let g:syntastic_enable_signs = 1
|
||||||
|
<
|
||||||
|
*'syntastic_error_symbol'* *'syntastic_style_error_symbol'*
|
||||||
|
*'syntastic_warning_symbol'* *'syntastic_style_warning_symbol'*
|
||||||
|
Use this option to control what the syntastic |:sign| text contains. Several
|
||||||
|
error symbols can be customized:
|
||||||
|
syntastic_error_symbol - For syntax errors, defaults to '>>'
|
||||||
|
syntastic_style_error_symbol - For style errors, defaults to 'S>'
|
||||||
|
syntastic_warning_symbol - For syntax warnings, defaults to '>>'
|
||||||
|
syntastic_style_warning_symbol - For style warnings, defaults to 'S>'
|
||||||
|
|
||||||
|
Example: >
|
||||||
|
let g:syntastic_error_symbol = "✗"
|
||||||
|
let g:syntastic_warning_symbol = "⚠"
|
||||||
|
<
|
||||||
|
*'syntastic_enable_balloons'*
|
||||||
|
Default: 1
|
||||||
|
Use this option to tell syntastic whether to display error messages in balloons
|
||||||
|
when the mouse is hovered over erroneous lines: >
|
||||||
|
let g:syntastic_enable_balloons = 1
|
||||||
|
<
|
||||||
|
Note that Vim must be compiled with |+balloon_eval|.
|
||||||
|
|
||||||
|
*'syntastic_enable_highlighting'*
|
||||||
|
Default: 1
|
||||||
|
Use this option to tell syntastic whether to use syntax highlighting to mark
|
||||||
|
errors (where possible). Highlighting can be turned off with the following >
|
||||||
|
let g:syntastic_enable_highlighting = 0
|
||||||
|
<
|
||||||
|
*'syntastic_always_populate_loc_list'*
|
||||||
|
Default: 0
|
||||||
|
Enable this option to tell syntastic to always stick any detected errors into
|
||||||
|
the |location-list|: >
|
||||||
|
let g:syntastic_always_populate_loc_list = 1
|
||||||
|
<
|
||||||
|
*'syntastic_auto_jump'*
|
||||||
|
Default: 0
|
||||||
|
Enable this option if you want the cursor to jump to the first detected issue
|
||||||
|
when saving or opening a file.
|
||||||
|
|
||||||
|
When set to 0 the cursor won't jump automatically. >
|
||||||
|
let g:syntastic_auto_jump = 0
|
||||||
|
<
|
||||||
|
When set to 1 the cursor will always jump to the first issue detected. >
|
||||||
|
let g:syntastic_auto_jump = 1
|
||||||
|
<
|
||||||
|
When set to 2 the cursor will jump to the first issue detected, but only if
|
||||||
|
this issue is an error. >
|
||||||
|
let g:syntastic_auto_jump = 2
|
||||||
|
<
|
||||||
|
*'syntastic_auto_loc_list'*
|
||||||
|
Default: 2
|
||||||
|
Use this option to tell syntastic to automatically open and/or close the
|
||||||
|
|location-list| (see |syntastic-error-window|).
|
||||||
|
|
||||||
|
When set to 0 the error window will not be opened or closed automatically. >
|
||||||
|
let g:syntastic_auto_loc_list = 0
|
||||||
|
<
|
||||||
|
When set to 1 the error window will be automatically opened when errors are
|
||||||
|
detected, and closed when none are detected. >
|
||||||
|
let g:syntastic_auto_loc_list = 1
|
||||||
|
<
|
||||||
|
When set to 2 the error window will be automatically closed when no errors are
|
||||||
|
detected, but not opened automatically. >
|
||||||
|
let g:syntastic_auto_loc_list = 2
|
||||||
|
<
|
||||||
|
*'syntastic_loc_list_height'*
|
||||||
|
Default: 10
|
||||||
|
Use this option to specify the height of the location lists that syntastic
|
||||||
|
opens. >
|
||||||
|
let g:syntastic_loc_list_height = 5
|
||||||
|
<
|
||||||
|
*'syntastic_ignore_files'*
|
||||||
|
Default: []
|
||||||
|
Use this option to specify files that syntastic should never check. It's a
|
||||||
|
list of |regular-expression| patterns. The full paths of files (see |::p|) are
|
||||||
|
matched against these patterns, and the matches are case sensitive. Use |\c|
|
||||||
|
to specify case insensitive patterns. Example: >
|
||||||
|
let g:syntastic_ignore_files = ['\m^/usr/include/', '\m\c\.h$']
|
||||||
|
<
|
||||||
|
*'syntastic_filetype_map'*
|
||||||
|
Default: {}
|
||||||
|
Use this option to map non-standard filetypes to standard ones. Corresponding
|
||||||
|
checkers are mapped accordingly, which allows syntastic to check files with
|
||||||
|
non-standard filetypes: >
|
||||||
|
let g:syntastic_filetype_map = { "latex": "tex",
|
||||||
|
\ "gentoo-metadata": "xml" }
|
||||||
|
<
|
||||||
|
Composite filetypes can also be mapped to simple types, which disables the
|
||||||
|
default behaviour of running both checkers against the input file: >
|
||||||
|
let g:syntastic_filetype_map = { "handlebars.html": "handlebars" }
|
||||||
|
<
|
||||||
|
*'syntastic_mode_map'*
|
||||||
|
Default: { "mode": "active",
|
||||||
|
"active_filetypes": [],
|
||||||
|
"passive_filetypes": [] }
|
||||||
|
|
||||||
|
Use this option to fine tune when automatic syntax checking is done (or not
|
||||||
|
done).
|
||||||
|
|
||||||
|
The option should be set to something like: >
|
||||||
|
|
||||||
|
let g:syntastic_mode_map = { "mode": "active",
|
||||||
|
\ "active_filetypes": ["ruby", "php"],
|
||||||
|
\ "passive_filetypes": ["puppet"] }
|
||||||
|
<
|
||||||
|
"mode" can be mapped to one of two values - "active" or "passive". When set
|
||||||
|
to "active", syntastic does automatic checking whenever a buffer is saved or
|
||||||
|
initially opened. When set to "passive" syntastic only checks when the user
|
||||||
|
calls |:SyntasticCheck|.
|
||||||
|
|
||||||
|
The exceptions to these rules are defined with "active_filetypes" and
|
||||||
|
"passive_filetypes". In passive mode, automatic checks are still done for
|
||||||
|
filetypes in the "active_filetypes" array (and "passive_filetypes" is
|
||||||
|
ignored). In active mode, automatic checks are not done for any filetypes in
|
||||||
|
the "passive_filetypes" array ("active_filetypes" is ignored).
|
||||||
|
|
||||||
|
If any of "mode", "active_filetypes", or "passive_filetypes" are left
|
||||||
|
unspecified, they default to values above.
|
||||||
|
|
||||||
|
At runtime, the |:SyntasticToggleMode| command can be used to switch between
|
||||||
|
active and passive modes.
|
||||||
|
|
||||||
|
*'syntastic_quiet_messages'*
|
||||||
|
Default: {}
|
||||||
|
|
||||||
|
Use this option to filter out some of the messages produced by checkers. The
|
||||||
|
option should be set to something like: >
|
||||||
|
let g:syntastic_quiet_messages = { "level": "warnings",
|
||||||
|
\ "type": "style",
|
||||||
|
\ "regex": '\m\[C03\d\d\]',
|
||||||
|
\ "file": ['\m^/usr/include/', '\m\c\.h$'] }
|
||||||
|
<
|
||||||
|
Each element turns off messages matching the patterns specified by the
|
||||||
|
corresponding value. Values are lists, but if a list consist of a single
|
||||||
|
element you can omit adding the brackets (e.g. you can write "style" instead
|
||||||
|
of ["style"]). Elements with values [] or '' are ignored (this is useful for
|
||||||
|
overriding filters, cf. |filter-overrides|).
|
||||||
|
|
||||||
|
"level" - takes one of two values, "warnings" or "errors"
|
||||||
|
"type" - can be either "syntax" or "style"
|
||||||
|
"regex" - is matched against the messages' text as a case insensitive
|
||||||
|
|regular-expression|
|
||||||
|
"file" - is matched against the filename the error refers to, as a case
|
||||||
|
sensitive |regular-expression|.
|
||||||
|
|
||||||
|
If |'syntastic_id_checkers'| is set, filters are applied before error messages
|
||||||
|
are labeled with the names of the checkers that created them.
|
||||||
|
|
||||||
|
There are also checker-specific variants of this option, providing finer
|
||||||
|
control. They are named |'syntastic_<filetype>_<checker>_quiet_messages'|.
|
||||||
|
|
||||||
|
For a particular checker, if both a |'syntastic_quiet_messages'| filter and
|
||||||
|
a checker-specific filter are present, they are both applied (to the list of
|
||||||
|
errors produced by the said checker). In case of conflicting values for the
|
||||||
|
same keys, the values of the checker-specific filters take precedence.
|
||||||
|
|
||||||
|
*filter-overrides*
|
||||||
|
Since filter elements with values [] or '' are ignored, you can disable global
|
||||||
|
filters for particular checkers, by setting the values of the corresponding
|
||||||
|
elements in |'syntastic_<filetype>_<checker>_quiet_messages'| to [] or ''. For
|
||||||
|
example, the following setting will silence all warnings, except for the
|
||||||
|
ones produced by "pylint": >
|
||||||
|
let g:syntastic_quiet_messages = { "level": "warnings" }
|
||||||
|
let g:syntastic_python_pylint_quiet_messages = { "level" : [] }
|
||||||
|
<
|
||||||
|
*'syntastic_stl_format'*
|
||||||
|
Default: [Syntax: line:%F (%t)]
|
||||||
|
Use this option to control what the syntastic statusline text contains. Several
|
||||||
|
magic flags are available to insert information:
|
||||||
|
%e - number of errors
|
||||||
|
%w - number of warnings
|
||||||
|
%t - total number of warnings and errors
|
||||||
|
%fe - line number of first error
|
||||||
|
%fw - line number of first warning
|
||||||
|
%F - line number of first warning or error
|
||||||
|
|
||||||
|
Several additional flags are available to hide text under certain conditions:
|
||||||
|
%E{...} - hide the text in the brackets unless there are errors
|
||||||
|
%W{...} - hide the text in the brackets unless there are warnings
|
||||||
|
%B{...} - hide the text in the brackets unless there are both warnings AND
|
||||||
|
errors
|
||||||
|
These flags can't be nested.
|
||||||
|
|
||||||
|
Example: >
|
||||||
|
let g:syntastic_stl_format = '[%E{Err: %fe #%e}%B{, }%W{Warn: %fw #%w}]'
|
||||||
|
<
|
||||||
|
If this format is used and the current buffer has 5 errors and 1 warning
|
||||||
|
starting on lines 20 and 10 respectively then this would appear on the
|
||||||
|
statusline: >
|
||||||
|
[Err: 20 #5, Warn: 10 #1]
|
||||||
|
<
|
||||||
|
If the buffer had 2 warnings, starting on line 5 then this would appear: >
|
||||||
|
[Warn: 5 #2]
|
||||||
|
<
|
||||||
|
*'syntastic_full_redraws'*
|
||||||
|
Default: 0 in GUI Vim and MacVim, 1 otherwise
|
||||||
|
Controls whether syntastic calls |:redraw| or |:redraw!| for screen redraws.
|
||||||
|
Changing it can in principle make screen redraws smoother, but it can also
|
||||||
|
cause screen to flicker, or cause ghost characters. Leaving it to the default
|
||||||
|
should be safe.
|
||||||
|
|
||||||
|
*'syntastic_debug'*
|
||||||
|
Default: 0
|
||||||
|
Set this to the sum of one or more of the following flags to enable
|
||||||
|
debugging:
|
||||||
|
|
||||||
|
1 - trace checker calls
|
||||||
|
2 - dump location lists
|
||||||
|
4 - trace notifiers
|
||||||
|
8 - trace autocommands
|
||||||
|
16 - dump options
|
||||||
|
|
||||||
|
Example: >
|
||||||
|
let g:syntastic_debug = 1
|
||||||
|
<
|
||||||
|
Syntastic will then add debugging messages to Vim's |message-history|. You can
|
||||||
|
examine these messages with |:mes|.
|
||||||
|
|
||||||
|
*'syntastic_debug_file'*
|
||||||
|
Default: unset
|
||||||
|
When set, debugging messages are written to the file named by its value, in
|
||||||
|
addition to being added to Vim's |message-history|: >
|
||||||
|
let g:syntastic_debug_file = '~/syntastic.log'
|
||||||
|
<
|
||||||
|
*'syntastic_extra_filetypes'*
|
||||||
|
Default: []
|
||||||
|
List of filetypes handled by checkers external to syntastic. If you have a Vim
|
||||||
|
plugin that adds a checker for syntastic, and if the said checker deals with a
|
||||||
|
filetype that is unknown to syntastic, you might consider adding that filetype
|
||||||
|
to this list: >
|
||||||
|
let g:syntastic_extra_filetypes = [ "make", "gitcommit" ]
|
||||||
|
<
|
||||||
|
This will allow |:SyntasticInfo| to do proper tab completion for the new
|
||||||
|
filetypes.
|
||||||
|
|
||||||
|
==============================================================================
|
||||||
|
5. Checker Options *syntastic-checker-options*
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
5.1 Choosing which checkers to use *syntastic-filetype-checkers*
|
||||||
|
|
||||||
|
*'g:syntastic_<filetype>_checkers'*
|
||||||
|
You can tell syntastic which checkers to run for a given filetype by setting a
|
||||||
|
variable 'g:syntastic_<filetype>_checkers' to a list of checkers, e.g. >
|
||||||
|
let g:syntastic_php_checkers = ["php", "phpcs", "phpmd"]
|
||||||
|
<
|
||||||
|
*'b:syntastic_checkers'*
|
||||||
|
There is also a per-buffer version of this setting, 'b:syntastic_checkers'.
|
||||||
|
When set, it takes precedence over |'g:syntastic_<filetype>_checkers'|. You can
|
||||||
|
use this in an autocmd to configure specific checkers for particular paths: >
|
||||||
|
autocmd FileType python if stridx(expand("%:p"), "/some/path/") == 0 |
|
||||||
|
\ let b:syntastic_checkers = ["pylint"] | endif
|
||||||
|
<
|
||||||
|
If neither |'g:syntastic_<filetype>_checkers'| nor |'b:syntastic_checkers'|
|
||||||
|
is set, a default list of checker is used. Beware however that this list
|
||||||
|
deliberately kept minimal, for performance reasons.
|
||||||
|
|
||||||
|
Take a look at the wiki to find out what checkers and filetypes are supported
|
||||||
|
by syntastic:
|
||||||
|
|
||||||
|
https://github.com/scrooloose/syntastic/wiki/Syntax-Checkers
|
||||||
|
|
||||||
|
Use |:SyntasticInfo| to see which checkers are available for a given filetype.
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
5.2 Choosing the executable *syntastic-config-exec*
|
||||||
|
|
||||||
|
*'syntastic_<filetype>_<checker>_exec'*
|
||||||
|
The executable used by a checker is normally defined automatically, when the
|
||||||
|
checkers is registered. You can however override it by setting the variable
|
||||||
|
'g:syntastic_<filetype>_<checker>_exec': >
|
||||||
|
let g:syntastic_ruby_mri_exec = '~/bin/ruby2'
|
||||||
|
<
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
5.3 Configuring specific checkers *syntastic-config-makeprg*
|
||||||
|
|
||||||
|
Most checkers use the 'makeprgBuild()' function and provide many options by
|
||||||
|
default - in fact you can customise every part of the command that gets called.
|
||||||
|
|
||||||
|
*'syntastic_<filetype>_<checker>_<option>'*
|
||||||
|
Checkers that use 'makeprgBuild()' construct a 'makeprg' like this: >
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ "exe": self.getExec(),
|
||||||
|
\ "args": "-a -b -c",
|
||||||
|
\ "post_args": "--more --args",
|
||||||
|
\ "tail": "2>/dev/null" })
|
||||||
|
<
|
||||||
|
The result is a 'makeprg' of the form: >
|
||||||
|
<exe> <args> <fname> <post_args> <tail>
|
||||||
|
<
|
||||||
|
All arguments above are optional, and can be overridden by setting global
|
||||||
|
variables 'g:syntastic_<filetype>_<checker-name>_<option-name>' - even
|
||||||
|
parameters not specified in the call to makeprgBuild(). These variables also
|
||||||
|
have local versions 'b:syntastic_<filetype>_<checker-name>_<option-name>',
|
||||||
|
which take precedence over the global ones in the corresponding buffers.
|
||||||
|
|
||||||
|
If one of these variables has a non-empty default and you want it to be empty,
|
||||||
|
you can set it to a space, e.g.: >
|
||||||
|
let g:syntastic_javascript_jslint_args = " "
|
||||||
|
<
|
||||||
|
(setting it to an empty string doesn't work, for implementation reasons).
|
||||||
|
|
||||||
|
*'syntastic_<filetype>_<checker>_exe'*
|
||||||
|
The 'exe' is normally the same as the 'exec' attribute described above, in
|
||||||
|
which case it may be omitted. However, you can use it to add environment
|
||||||
|
variables or additional parameters, e.g. to tell the mri checker to use KANJI
|
||||||
|
encoding you could do something like this: >
|
||||||
|
let g:syntastic_ruby_mri_exe = 'RUBYOPT="-Ke" ruby'
|
||||||
|
<
|
||||||
|
To override the args and the tail: >
|
||||||
|
let g:syntastic_ruby_mri_args = "--my --args --here"
|
||||||
|
let g:syntastic_ruby_mri_tail = "> /tmp/my-output-file-biatch"
|
||||||
|
<
|
||||||
|
The general form of the override options is: >
|
||||||
|
syntastic_<filetype>_<checker>_<option-name>
|
||||||
|
<
|
||||||
|
For checkers that do not use the 'makeprgBuild()' function you will have to
|
||||||
|
look at the source code of the checker in question. If there are specific
|
||||||
|
options that can be set, these are usually documented in the wiki:
|
||||||
|
|
||||||
|
https://github.com/scrooloose/syntastic/wiki/Syntax-Checkers
|
||||||
|
|
||||||
|
*'syntastic_<filetype>_<checker>_quiet_messages'*
|
||||||
|
In the same vein, 'g:syntastic_<filetype>_<checker-name>_quiet_messages' can
|
||||||
|
be used to restrict message filters to messages produced by specific checkers.
|
||||||
|
Example: >
|
||||||
|
let g:syntastic_python_pylama_quiet_messages = { "type": "style",
|
||||||
|
\ "regex": '\m\[C03\d\d\]' }
|
||||||
|
<
|
||||||
|
See |syntastic_quiet_messages| for the syntax.
|
||||||
|
|
||||||
|
==============================================================================
|
||||||
|
6. Notes *syntastic-notes*
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
6.1. Handling of composite filetypes *syntastic-composite*
|
||||||
|
|
||||||
|
Some Vim plugins use composite filetypes, such as "django.python" or
|
||||||
|
"handlebars.html". Normally, syntastic deals with this situation by splitting
|
||||||
|
the filetype in its simple components, and calling all checkers that apply.
|
||||||
|
If this behaviour is not desirable, you can disable it by mapping the
|
||||||
|
composite filetypes to a simple ones using |syntastic_filetype_map|, e.g.: >
|
||||||
|
let g:syntastic_filetype_map = { "handlebars.html": "handlebars" }
|
||||||
|
<
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
6.2 Editing files over network *syntastic-netrw*
|
||||||
|
|
||||||
|
The standard plugin |netrw| allows Vim to transparently edit files over
|
||||||
|
network and inside archives. Currently syntastic doesn't support this mode
|
||||||
|
of operation. It can only check files that can be accessed directly by local
|
||||||
|
checkers, without any translation or conversion.
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
6.3 Interaction with python-mode *syntastic-pymode*
|
||||||
|
|
||||||
|
Syntastic can be used along with the 'python-mode' Vim plugin (see
|
||||||
|
https://github.com/klen/python-mode). However, they both run syntax checks by
|
||||||
|
default when you save buffers to disk, and this is probably not what you want.
|
||||||
|
To avoid both plugins opening error windows, you can either set passive mode
|
||||||
|
for python in syntastic (see |syntastic_mode_map|), or disable lint checks in
|
||||||
|
'python-mode', by setting |pymode_lint_write| to 0. E.g.: >
|
||||||
|
let g:pymode_lint_write = 0
|
||||||
|
<
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
6.4 Interaction with YouCompleteMe *syntastic-ycm*
|
||||||
|
|
||||||
|
Syntastic can be used together with the 'YouCompleteMe' Vim plugin (see
|
||||||
|
http://valloric.github.io/YouCompleteMe/). However, by default 'YouCompleteMe'
|
||||||
|
disables syntastic"s checkers for the "c", "cpp", "objc", and "objcpp"
|
||||||
|
filetypes, in order to allow its own checkers to run. If you want to use YCM's
|
||||||
|
identifier completer but still run syntastic's checkers for those filetypes you
|
||||||
|
have to set |ycm_show_diagnostics_ui| to 0. E.g.: >
|
||||||
|
let g:ycm_show_diagnostics_ui = 0
|
||||||
|
<
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
6.5 Interaction with the fish shell *syntastic-fish*
|
||||||
|
|
||||||
|
At the time of this writing the 'fish' shell (see http://fishshell.com/)
|
||||||
|
doesn't support the standard UNIX syntax for file redirections, and thus it
|
||||||
|
can't be used together with syntastic. You don't need to change your login
|
||||||
|
shell to address this problem, but you do have to point Vim's 'shell' to a more
|
||||||
|
traditional shell, such as "zsh", "bash", "ksh", or even the original Bourne
|
||||||
|
"sh": >
|
||||||
|
set shell=bash
|
||||||
|
<
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
6.6. Interaction with PowerShell *syntastic-powershell*
|
||||||
|
|
||||||
|
At the time of this writing, syntastic is not compatible with using 'Windows
|
||||||
|
PowerShell' (http://technet.microsoft.com/en-us/library/bb978526.aspx) as Vim's
|
||||||
|
'shell'. You may still run Vim from 'PowerShell', but you do have to point
|
||||||
|
Vim's 'shell' to a more traditional program, such as 'cmd.exe': >
|
||||||
|
set shell=cmd.exe
|
||||||
|
<
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
6.7. Using syntastic with the fizsh shell *syntastic-fizsh*
|
||||||
|
|
||||||
|
Using syntastic with the 'fizsh' shell (see https://github.com/zsh-users/fizsh)
|
||||||
|
is possible, but potentially problematic. In order to do it you'll need to set
|
||||||
|
'shellredir' like this: >
|
||||||
|
set shellredir=>%s\ 2>&1
|
||||||
|
<
|
||||||
|
Please keep in mind however that Vim can't take advantage of any of the
|
||||||
|
interactive features of 'fizsh'. Using a more traditional shell such as "zsh",
|
||||||
|
"bash", "ksh", or the original Bourne "sh" might be a better choice: >
|
||||||
|
set shell=zsh
|
||||||
|
<
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
6.8. Interaction with Eclim *syntastic-eclim*
|
||||||
|
|
||||||
|
As far as syntastic is concerned there shouldn't be any compatibility problems
|
||||||
|
with the 'Eclim' Vim plugin (see http://eclim.org/). However, at the time of
|
||||||
|
this writing there are several reports that 'Eclim' triggers a bug in Vim that
|
||||||
|
makes syntastic forget some of its configuration parameters. No solutions or
|
||||||
|
workarounds are known for now.
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
6.9. Interaction with vim-virtualenv *syntastic-vim-virtualenv*
|
||||||
|
|
||||||
|
At the time of this writing, syntastic can't run checkers installed
|
||||||
|
in Python virtual environments activated by 'vim-virtualenv' (see
|
||||||
|
https://github.com/jmcantrell/vim-virtualenv). This is a limitation of
|
||||||
|
'vim-virtualenv'.
|
||||||
|
|
||||||
|
==============================================================================
|
||||||
|
7. About *syntastic-about*
|
||||||
|
|
||||||
|
The core maintainers of syntastic are:
|
||||||
|
Martin Grenfell (github: scrooloose)
|
||||||
|
Gregor Uhlenheuer (github: kongo2002)
|
||||||
|
LCD 047 (github: lcd047)
|
||||||
|
|
||||||
|
Find the latest version of syntastic at:
|
||||||
|
|
||||||
|
http://github.com/scrooloose/syntastic
|
||||||
|
|
||||||
|
==============================================================================
|
||||||
|
8. License *syntastic-license*
|
||||||
|
|
||||||
|
Syntastic is released under the wtfpl.
|
||||||
|
See http://sam.zoy.org/wtfpl/COPYING.
|
||||||
|
|
||||||
|
vim:tw=78:sw=4:ft=help:norl:
|
610
sources_non_forked/syntastic/plugin/syntastic.vim
Normal file
610
sources_non_forked/syntastic/plugin/syntastic.vim
Normal file
|
@ -0,0 +1,610 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: syntastic.vim
|
||||||
|
"Description: Vim plugin for on the fly syntax checking.
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_plugin = 1
|
||||||
|
|
||||||
|
if has('reltime')
|
||||||
|
let g:syntastic_start = reltime()
|
||||||
|
lockvar! g:syntastic_start
|
||||||
|
endif
|
||||||
|
|
||||||
|
let g:syntastic_version = '3.4.0-117'
|
||||||
|
lockvar g:syntastic_version
|
||||||
|
|
||||||
|
" Sanity checks {{{1
|
||||||
|
|
||||||
|
for s:feature in ['autocmd', 'eval', 'modify_fname', 'quickfix', 'reltime', 'user_commands']
|
||||||
|
if !has(s:feature)
|
||||||
|
call syntastic#log#error("need Vim compiled with feature " . s:feature)
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
let s:running_windows = syntastic#util#isRunningWindows()
|
||||||
|
lockvar s:running_windows
|
||||||
|
|
||||||
|
if !s:running_windows && executable('uname')
|
||||||
|
try
|
||||||
|
let s:uname = system('uname')
|
||||||
|
catch /\m^Vim\%((\a\+)\)\=:E484/
|
||||||
|
call syntastic#log#error("your shell " . &shell . " doesn't use traditional UNIX syntax for redirections")
|
||||||
|
finish
|
||||||
|
endtry
|
||||||
|
lockvar s:uname
|
||||||
|
endif
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Defaults {{{1
|
||||||
|
|
||||||
|
let g:syntastic_defaults = {
|
||||||
|
\ 'aggregate_errors': 0,
|
||||||
|
\ 'always_populate_loc_list': 0,
|
||||||
|
\ 'auto_jump': 0,
|
||||||
|
\ 'auto_loc_list': 2,
|
||||||
|
\ 'bash_hack': 1,
|
||||||
|
\ 'check_on_open': 0,
|
||||||
|
\ 'check_on_wq': 1,
|
||||||
|
\ 'cursor_columns': 1,
|
||||||
|
\ 'debug': 0,
|
||||||
|
\ 'echo_current_error': 1,
|
||||||
|
\ 'enable_balloons': 1,
|
||||||
|
\ 'enable_highlighting': 1,
|
||||||
|
\ 'enable_signs': 1,
|
||||||
|
\ 'error_symbol': '>>',
|
||||||
|
\ 'filetype_map': {},
|
||||||
|
\ 'full_redraws': !(has('gui_running') || has('gui_macvim')),
|
||||||
|
\ 'id_checkers': 1,
|
||||||
|
\ 'ignore_extensions': '\c\v^([gx]?z|lzma|bz2)$',
|
||||||
|
\ 'ignore_files': [],
|
||||||
|
\ 'loc_list_height': 10,
|
||||||
|
\ 'quiet_messages': {},
|
||||||
|
\ 'reuse_loc_lists': 0,
|
||||||
|
\ 'sort_aggregated_errors': 1,
|
||||||
|
\ 'stl_format': '[Syntax: line:%F (%t)]',
|
||||||
|
\ 'style_error_symbol': 'S>',
|
||||||
|
\ 'style_warning_symbol': 'S>',
|
||||||
|
\ 'warning_symbol': '>>'
|
||||||
|
\ }
|
||||||
|
lockvar! g:syntastic_defaults
|
||||||
|
|
||||||
|
for s:key in keys(g:syntastic_defaults)
|
||||||
|
if !exists('g:syntastic_' . s:key)
|
||||||
|
let g:syntastic_{s:key} = g:syntastic_defaults[s:key]
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
if exists("g:syntastic_quiet_warnings")
|
||||||
|
call syntastic#log#oneTimeWarn("variable g:syntastic_quiet_warnings is deprecated, please use let g:syntastic_quiet_messages = {'level': 'warnings'} instead")
|
||||||
|
if g:syntastic_quiet_warnings
|
||||||
|
let s:quiet_warnings = get(g:syntastic_quiet_messages, 'type', [])
|
||||||
|
if type(s:quiet_warnings) != type([])
|
||||||
|
let s:quiet_warnings = [s:quiet_warnings]
|
||||||
|
endif
|
||||||
|
call add(s:quiet_warnings, 'warnings')
|
||||||
|
let g:syntastic_quiet_messages['type'] = s:quiet_warnings
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Debug {{{1
|
||||||
|
|
||||||
|
let s:debug_dump_options = [
|
||||||
|
\ 'shell',
|
||||||
|
\ 'shellcmdflag',
|
||||||
|
\ 'shellpipe',
|
||||||
|
\ 'shellquote',
|
||||||
|
\ 'shellredir',
|
||||||
|
\ 'shellslash',
|
||||||
|
\ 'shelltemp',
|
||||||
|
\ 'shellxquote'
|
||||||
|
\ ]
|
||||||
|
if v:version > 703 || (v:version == 703 && has('patch446'))
|
||||||
|
call add(s:debug_dump_options, 'shellxescape')
|
||||||
|
endif
|
||||||
|
lockvar! s:debug_dump_options
|
||||||
|
|
||||||
|
" debug constants
|
||||||
|
let g:SyntasticDebugTrace = 1
|
||||||
|
lockvar g:SyntasticDebugTrace
|
||||||
|
let g:SyntasticDebugLoclist = 2
|
||||||
|
lockvar g:SyntasticDebugLoclist
|
||||||
|
let g:SyntasticDebugNotifications = 4
|
||||||
|
lockvar g:SyntasticDebugNotifications
|
||||||
|
let g:SyntasticDebugAutocommands = 8
|
||||||
|
lockvar g:SyntasticDebugAutocommands
|
||||||
|
let g:SyntasticDebugVariables = 16
|
||||||
|
lockvar g:SyntasticDebugVariables
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
runtime! plugin/syntastic/*.vim
|
||||||
|
|
||||||
|
let s:registry = g:SyntasticRegistry.Instance()
|
||||||
|
let s:notifiers = g:SyntasticNotifiers.Instance()
|
||||||
|
let s:modemap = g:SyntasticModeMap.Instance()
|
||||||
|
|
||||||
|
" Commands {{{1
|
||||||
|
|
||||||
|
" @vimlint(EVL103, 1, a:cursorPos)
|
||||||
|
" @vimlint(EVL103, 1, a:cmdLine)
|
||||||
|
" @vimlint(EVL103, 1, a:argLead)
|
||||||
|
function! s:CompleteCheckerName(argLead, cmdLine, cursorPos) " {{{2
|
||||||
|
let checker_names = []
|
||||||
|
for ft in s:resolveFiletypes()
|
||||||
|
call extend(checker_names, s:registry.getNamesOfAvailableCheckers(ft))
|
||||||
|
endfor
|
||||||
|
return join(checker_names, "\n")
|
||||||
|
endfunction " }}}2
|
||||||
|
" @vimlint(EVL103, 0, a:cursorPos)
|
||||||
|
" @vimlint(EVL103, 0, a:cmdLine)
|
||||||
|
" @vimlint(EVL103, 0, a:argLead)
|
||||||
|
|
||||||
|
|
||||||
|
" @vimlint(EVL103, 1, a:cursorPos)
|
||||||
|
" @vimlint(EVL103, 1, a:cmdLine)
|
||||||
|
" @vimlint(EVL103, 1, a:argLead)
|
||||||
|
function! s:CompleteFiletypes(argLead, cmdLine, cursorPos) " {{{2
|
||||||
|
return join(s:registry.getKnownFiletypes(), "\n")
|
||||||
|
endfunction " }}}2
|
||||||
|
" @vimlint(EVL103, 0, a:cursorPos)
|
||||||
|
" @vimlint(EVL103, 0, a:cmdLine)
|
||||||
|
" @vimlint(EVL103, 0, a:argLead)
|
||||||
|
|
||||||
|
command! SyntasticToggleMode call s:ToggleMode()
|
||||||
|
command! -nargs=* -complete=custom,s:CompleteCheckerName SyntasticCheck
|
||||||
|
\ call s:UpdateErrors(0, <f-args>) <bar>
|
||||||
|
\ call syntastic#util#redraw(g:syntastic_full_redraws)
|
||||||
|
command! Errors call s:ShowLocList()
|
||||||
|
command! -nargs=? -complete=custom,s:CompleteFiletypes SyntasticInfo
|
||||||
|
\ call s:modemap.modeInfo(<f-args>) |
|
||||||
|
\ call s:registry.echoInfoFor(s:resolveFiletypes(<f-args>))
|
||||||
|
command! SyntasticReset
|
||||||
|
\ call s:ClearCache() |
|
||||||
|
\ call s:notifiers.refresh(g:SyntasticLoclist.New([]))
|
||||||
|
command! SyntasticSetLoclist call g:SyntasticLoclist.current().setloclist()
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Autocommands and hooks {{{1
|
||||||
|
|
||||||
|
augroup syntastic
|
||||||
|
autocmd BufReadPost * call s:BufReadPostHook()
|
||||||
|
autocmd BufWritePost * call s:BufWritePostHook()
|
||||||
|
autocmd BufEnter * call s:BufEnterHook()
|
||||||
|
augroup END
|
||||||
|
|
||||||
|
if v:version > 703 || (v:version == 703 && has('patch544'))
|
||||||
|
" QuitPre was added in Vim 7.3.544
|
||||||
|
augroup syntastic
|
||||||
|
autocmd QuitPre * call s:QuitPreHook()
|
||||||
|
augroup END
|
||||||
|
endif
|
||||||
|
|
||||||
|
function! s:BufReadPostHook() " {{{2
|
||||||
|
if g:syntastic_check_on_open
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugAutocommands,
|
||||||
|
\ 'autocmd: BufReadPost, buffer ' . bufnr("") . ' = ' . string(bufname(str2nr(bufnr("")))))
|
||||||
|
call s:UpdateErrors(1)
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:BufWritePostHook() " {{{2
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugAutocommands,
|
||||||
|
\ 'autocmd: BufWritePost, buffer ' . bufnr("") . ' = ' . string(bufname(str2nr(bufnr("")))))
|
||||||
|
call s:UpdateErrors(1)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:BufEnterHook() " {{{2
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugAutocommands,
|
||||||
|
\ 'autocmd: BufEnter, buffer ' . bufnr("") . ' = ' . string(bufname(str2nr(bufnr("")))) .
|
||||||
|
\ ', &buftype = ' . string(&buftype))
|
||||||
|
if &buftype == ''
|
||||||
|
call s:notifiers.refresh(g:SyntasticLoclist.current())
|
||||||
|
elseif &buftype == 'quickfix'
|
||||||
|
" TODO: this is needed because in recent versions of Vim lclose
|
||||||
|
" can no longer be called from BufWinLeave
|
||||||
|
" TODO: at this point there is no b:syntastic_loclist
|
||||||
|
let loclist = filter(copy(getloclist(0)), 'v:val["valid"] == 1')
|
||||||
|
let owner = str2nr(getbufvar(bufnr(""), 'syntastic_owner_buffer'))
|
||||||
|
let buffers = syntastic#util#unique(map(loclist, 'v:val["bufnr"]') + (owner ? [owner] : []))
|
||||||
|
if !empty(loclist) && empty(filter( buffers, 'syntastic#util#bufIsActive(v:val)' ))
|
||||||
|
call SyntasticLoclistHide()
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:QuitPreHook() " {{{2
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugAutocommands,
|
||||||
|
\ 'autocmd: QuitPre, buffer ' . bufnr("") . ' = ' . string(bufname(str2nr(bufnr("")))))
|
||||||
|
let b:syntastic_skip_checks = !g:syntastic_check_on_wq
|
||||||
|
call SyntasticLoclistHide()
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Main {{{1
|
||||||
|
|
||||||
|
"refresh and redraw all the error info for this buf when saving or reading
|
||||||
|
function! s:UpdateErrors(auto_invoked, ...) " {{{2
|
||||||
|
call syntastic#log#debugShowVariables(g:SyntasticDebugTrace, 'version')
|
||||||
|
call syntastic#log#debugShowOptions(g:SyntasticDebugTrace, s:debug_dump_options)
|
||||||
|
call syntastic#log#debugDump(g:SyntasticDebugVariables)
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugTrace, 'UpdateErrors' . (a:auto_invoked ? ' (auto)' : '') .
|
||||||
|
\ ': ' . (a:0 ? join(a:000) : 'default checkers'))
|
||||||
|
if s:skipFile()
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
call s:modemap.synch()
|
||||||
|
let run_checks = !a:auto_invoked || s:modemap.allowsAutoChecking(&filetype)
|
||||||
|
if run_checks
|
||||||
|
call s:CacheErrors(a:000)
|
||||||
|
endif
|
||||||
|
|
||||||
|
let loclist = g:SyntasticLoclist.current()
|
||||||
|
|
||||||
|
" populate loclist and jump {{{3
|
||||||
|
let do_jump = syntastic#util#var('auto_jump')
|
||||||
|
if do_jump == 2
|
||||||
|
let first = loclist.getFirstIssue()
|
||||||
|
let type = get(first, 'type', '')
|
||||||
|
let do_jump = type ==? 'E'
|
||||||
|
endif
|
||||||
|
|
||||||
|
let w:syntastic_loclist_set = 0
|
||||||
|
if syntastic#util#var('always_populate_loc_list') || do_jump
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'loclist: setloclist (new)')
|
||||||
|
call setloclist(0, loclist.getRaw())
|
||||||
|
let w:syntastic_loclist_set = 1
|
||||||
|
if run_checks && do_jump && !loclist.isEmpty()
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'loclist: jump')
|
||||||
|
silent! lrewind
|
||||||
|
|
||||||
|
" XXX: Vim doesn't call autocmd commands in a predictible
|
||||||
|
" order, which can lead to missing filetype when jumping
|
||||||
|
" to a new file; the following is a workaround for the
|
||||||
|
" resulting brain damage
|
||||||
|
if &filetype == ''
|
||||||
|
silent! filetype detect
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
" }}}3
|
||||||
|
|
||||||
|
call s:notifiers.refresh(loclist)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
"clear the loc list for the buffer
|
||||||
|
function! s:ClearCache() " {{{2
|
||||||
|
call s:notifiers.reset(g:SyntasticLoclist.current())
|
||||||
|
call b:syntastic_loclist.destroy()
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
"detect and cache all syntax errors in this buffer
|
||||||
|
function! s:CacheErrors(checker_names) " {{{2
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugTrace, 'CacheErrors: ' .
|
||||||
|
\ (len(a:checker_names) ? join(a:checker_names) : 'default checkers'))
|
||||||
|
call s:ClearCache()
|
||||||
|
let newLoclist = g:SyntasticLoclist.New([])
|
||||||
|
|
||||||
|
if !s:skipFile()
|
||||||
|
" debug logging {{{3
|
||||||
|
call syntastic#log#debugShowVariables(g:SyntasticDebugTrace, 'aggregate_errors')
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugTrace, 'getcwd() = ' . getcwd())
|
||||||
|
" }}}3
|
||||||
|
|
||||||
|
let filetypes = s:resolveFiletypes()
|
||||||
|
let aggregate_errors = syntastic#util#var('aggregate_errors') || len(filetypes) > 1
|
||||||
|
let decorate_errors = aggregate_errors && syntastic#util#var('id_checkers')
|
||||||
|
let sort_aggregated_errors = aggregate_errors && syntastic#util#var('sort_aggregated_errors')
|
||||||
|
|
||||||
|
let clist = []
|
||||||
|
for type in filetypes
|
||||||
|
call extend(clist, s:registry.getCheckers(type, a:checker_names))
|
||||||
|
endfor
|
||||||
|
|
||||||
|
let names = []
|
||||||
|
let unavailable_checkers = 0
|
||||||
|
for checker in clist
|
||||||
|
let cname = checker.getFiletype() . '/' . checker.getName()
|
||||||
|
if !checker.isAvailable()
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugTrace, 'CacheErrors: Checker ' . cname . ' is not available')
|
||||||
|
let unavailable_checkers += 1
|
||||||
|
continue
|
||||||
|
endif
|
||||||
|
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugTrace, 'CacheErrors: Invoking checker: ' . cname)
|
||||||
|
|
||||||
|
let loclist = checker.getLocList()
|
||||||
|
|
||||||
|
if !loclist.isEmpty()
|
||||||
|
if decorate_errors
|
||||||
|
call loclist.decorate(cname)
|
||||||
|
endif
|
||||||
|
call add(names, cname)
|
||||||
|
if checker.getWantSort() && !sort_aggregated_errors
|
||||||
|
call loclist.sort()
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugLoclist, 'sorted:', loclist)
|
||||||
|
endif
|
||||||
|
|
||||||
|
let newLoclist = newLoclist.extend(loclist)
|
||||||
|
|
||||||
|
if !aggregate_errors
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
" set names {{{3
|
||||||
|
if !empty(names)
|
||||||
|
if len(syntastic#util#unique(map( copy(names), 'substitute(v:val, "\\m/.*", "", "")' ))) == 1
|
||||||
|
let type = substitute(names[0], '\m/.*', '', '')
|
||||||
|
let name = join(map( names, 'substitute(v:val, "\\m.\\{-}/", "", "")' ), ', ')
|
||||||
|
call newLoclist.setName( name . ' ('. type . ')' )
|
||||||
|
else
|
||||||
|
" checkers from mixed types
|
||||||
|
call newLoclist.setName(join(names, ', '))
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
" }}}3
|
||||||
|
|
||||||
|
" issue warning about no active checkers {{{3
|
||||||
|
if len(clist) == unavailable_checkers
|
||||||
|
if !empty(a:checker_names)
|
||||||
|
if len(a:checker_names) == 1
|
||||||
|
call syntastic#log#warn('checker ' . a:checker_names[0] . ' is not available')
|
||||||
|
else
|
||||||
|
call syntastic#log#warn('checkers ' . join(a:checker_names, ', ') . ' are not available')
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugTrace, 'CacheErrors: no checkers available for ' . &filetype)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
" }}}3
|
||||||
|
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugLoclist, 'aggregated:', newLoclist)
|
||||||
|
if sort_aggregated_errors
|
||||||
|
call newLoclist.sort()
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugLoclist, 'sorted:', newLoclist)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
call newLoclist.deploy()
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:ToggleMode() " {{{2
|
||||||
|
call s:modemap.toggleMode()
|
||||||
|
call s:ClearCache()
|
||||||
|
call s:UpdateErrors(1)
|
||||||
|
call s:modemap.echoMode()
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
"display the cached errors for this buf in the location list
|
||||||
|
function! s:ShowLocList() " {{{2
|
||||||
|
call g:SyntasticLoclist.current().show()
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
"Emulates the :lmake command. Sets up the make environment according to the
|
||||||
|
"options given, runs make, resets the environment, returns the location list
|
||||||
|
"
|
||||||
|
"a:options can contain the following keys:
|
||||||
|
" 'makeprg'
|
||||||
|
" 'errorformat'
|
||||||
|
"
|
||||||
|
"The corresponding options are set for the duration of the function call. They
|
||||||
|
"are set with :let, so dont escape spaces.
|
||||||
|
"
|
||||||
|
"a:options may also contain:
|
||||||
|
" 'defaults' - a dict containing default values for the returned errors
|
||||||
|
" 'subtype' - all errors will be assigned the given subtype
|
||||||
|
" 'preprocess' - a function to be applied to the error file before parsing errors
|
||||||
|
" 'postprocess' - a list of functions to be applied to the error list
|
||||||
|
" 'cwd' - change directory to the given path before running the checker
|
||||||
|
" 'env' - environment variables to set before running the checker
|
||||||
|
" 'returns' - a list of valid exit codes for the checker
|
||||||
|
" @vimlint(EVL102, 1, l:env_save)
|
||||||
|
function! SyntasticMake(options) " {{{2
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugTrace, 'SyntasticMake: called with options:', a:options)
|
||||||
|
|
||||||
|
" save options and locale env variables {{{3
|
||||||
|
let old_shell = &shell
|
||||||
|
let old_shellredir = &shellredir
|
||||||
|
let old_local_errorformat = &l:errorformat
|
||||||
|
let old_errorformat = &errorformat
|
||||||
|
let old_cwd = getcwd()
|
||||||
|
let old_lc_messages = $LC_MESSAGES
|
||||||
|
let old_lc_all = $LC_ALL
|
||||||
|
" }}}3
|
||||||
|
|
||||||
|
call s:bashHack()
|
||||||
|
|
||||||
|
if has_key(a:options, 'errorformat')
|
||||||
|
let &errorformat = a:options['errorformat']
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has_key(a:options, 'cwd')
|
||||||
|
execute 'lcd ' . fnameescape(a:options['cwd'])
|
||||||
|
endif
|
||||||
|
|
||||||
|
" set environment variables {{{3
|
||||||
|
let env_save = {}
|
||||||
|
if has_key(a:options, 'env') && len(a:options['env'])
|
||||||
|
for key in keys(a:options['env'])
|
||||||
|
if key =~? '\m^[a-z_]\+$'
|
||||||
|
exec 'let env_save[' . string(key) . '] = $' . key
|
||||||
|
exec 'let $' . key . ' = ' . string(a:options['env'][key])
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
let $LC_MESSAGES = 'C'
|
||||||
|
let $LC_ALL = ''
|
||||||
|
" }}}3
|
||||||
|
|
||||||
|
let err_lines = split(system(a:options['makeprg']), "\n", 1)
|
||||||
|
|
||||||
|
" restore environment variables {{{3
|
||||||
|
let $LC_ALL = old_lc_all
|
||||||
|
let $LC_MESSAGES = old_lc_messages
|
||||||
|
if len(env_save)
|
||||||
|
for key in keys(env_save)
|
||||||
|
exec 'let $' . key . ' = ' . string(env_save[key])
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
" }}}3
|
||||||
|
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugLoclist, 'checker output:', err_lines)
|
||||||
|
|
||||||
|
if has_key(a:options, 'Preprocess')
|
||||||
|
let err_lines = call(a:options['Preprocess'], [err_lines])
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugLoclist, 'preprocess (external):', err_lines)
|
||||||
|
elseif has_key(a:options, 'preprocess')
|
||||||
|
let err_lines = call('syntastic#preprocess#' . a:options['preprocess'], [err_lines])
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugLoclist, 'preprocess:', err_lines)
|
||||||
|
endif
|
||||||
|
lgetexpr err_lines
|
||||||
|
|
||||||
|
let errors = deepcopy(getloclist(0))
|
||||||
|
|
||||||
|
if has_key(a:options, 'cwd')
|
||||||
|
execute 'lcd ' . fnameescape(old_cwd)
|
||||||
|
endif
|
||||||
|
|
||||||
|
silent! lolder
|
||||||
|
|
||||||
|
" restore options {{{3
|
||||||
|
let &errorformat = old_errorformat
|
||||||
|
let &l:errorformat = old_local_errorformat
|
||||||
|
let &shellredir = old_shellredir
|
||||||
|
let &shell = old_shell
|
||||||
|
" }}}3
|
||||||
|
|
||||||
|
if !s:running_windows && (s:uname() =~ "FreeBSD" || s:uname() =~ "OpenBSD")
|
||||||
|
call syntastic#util#redraw(g:syntastic_full_redraws)
|
||||||
|
endif
|
||||||
|
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugLoclist, 'raw loclist:', errors)
|
||||||
|
|
||||||
|
if has_key(a:options, 'returns') && index(a:options['returns'], v:shell_error) == -1
|
||||||
|
throw 'Syntastic: checker error'
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has_key(a:options, 'defaults')
|
||||||
|
call s:addToErrors(errors, a:options['defaults'])
|
||||||
|
endif
|
||||||
|
|
||||||
|
" Add subtype info if present.
|
||||||
|
if has_key(a:options, 'subtype')
|
||||||
|
call s:addToErrors(errors, { 'subtype': a:options['subtype'] })
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has_key(a:options, 'Postprocess') && !empty(a:options['Postprocess'])
|
||||||
|
for rule in a:options['Postprocess']
|
||||||
|
let errors = call(rule, [errors])
|
||||||
|
endfor
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugLoclist, 'postprocess (external):', errors)
|
||||||
|
elseif has_key(a:options, 'postprocess') && !empty(a:options['postprocess'])
|
||||||
|
for rule in a:options['postprocess']
|
||||||
|
let errors = call('syntastic#postprocess#' . rule, [errors])
|
||||||
|
endfor
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugLoclist, 'postprocess:', errors)
|
||||||
|
endif
|
||||||
|
|
||||||
|
return errors
|
||||||
|
endfunction " }}}2
|
||||||
|
" @vimlint(EVL102, 0, l:env_save)
|
||||||
|
|
||||||
|
"return a string representing the state of buffer according to
|
||||||
|
"g:syntastic_stl_format
|
||||||
|
"
|
||||||
|
"return '' if no errors are cached for the buffer
|
||||||
|
function! SyntasticStatuslineFlag() " {{{2
|
||||||
|
return g:SyntasticLoclist.current().getStatuslineFlag()
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Utilities {{{1
|
||||||
|
|
||||||
|
function! s:resolveFiletypes(...) " {{{2
|
||||||
|
let type = a:0 ? a:1 : &filetype
|
||||||
|
return split( get(g:syntastic_filetype_map, type, type), '\m\.' )
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:ignoreFile(filename) " {{{2
|
||||||
|
let fname = fnamemodify(a:filename, ':p')
|
||||||
|
for pattern in g:syntastic_ignore_files
|
||||||
|
if fname =~# pattern
|
||||||
|
return 1
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
return 0
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Skip running in special buffers
|
||||||
|
function! s:skipFile() " {{{2
|
||||||
|
let fname = expand('%')
|
||||||
|
let skip = (exists('b:syntastic_skip_checks') ? b:syntastic_skip_checks : 0) ||
|
||||||
|
\ (&buftype != '') || !filereadable(fname) || getwinvar(0, '&diff') ||
|
||||||
|
\ s:ignoreFile(fname) || fnamemodify(fname, ':e') =~? g:syntastic_ignore_extensions
|
||||||
|
if skip
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugTrace, 'skipFile: skipping')
|
||||||
|
endif
|
||||||
|
return skip
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Take a list of errors and add default values to them from a:options
|
||||||
|
function! s:addToErrors(errors, options) " {{{2
|
||||||
|
for err in a:errors
|
||||||
|
for key in keys(a:options)
|
||||||
|
if !has_key(err, key) || empty(err[key])
|
||||||
|
let err[key] = a:options[key]
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return a:errors
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" The script changes &shellredir and &shell to stop the screen flicking when
|
||||||
|
" shelling out to syntax checkers. Not all OSs support the hacks though.
|
||||||
|
function! s:bashHack() " {{{2
|
||||||
|
if !exists('s:bash')
|
||||||
|
if !s:running_windows && (s:uname() !~# "FreeBSD") && (s:uname() !~# "OpenBSD")
|
||||||
|
let s:bash =
|
||||||
|
\ executable('/usr/local/bin/bash') ? '/usr/local/bin/bash' :
|
||||||
|
\ executable('/bin/bash') ? '/bin/bash' : ''
|
||||||
|
else
|
||||||
|
let s:bash = ''
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
if g:syntastic_bash_hack && s:bash != ''
|
||||||
|
let &shell = s:bash
|
||||||
|
let &shellredir = '&>'
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:uname() " {{{2
|
||||||
|
if !exists('s:uname')
|
||||||
|
let s:uname = system('uname')
|
||||||
|
lockvar s:uname
|
||||||
|
endif
|
||||||
|
return s:uname
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -0,0 +1,38 @@
|
||||||
|
if exists("g:loaded_syntastic_notifier_autoloclist") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_notifier_autoloclist = 1
|
||||||
|
|
||||||
|
let g:SyntasticAutoloclistNotifier = {}
|
||||||
|
|
||||||
|
" Public methods {{{1
|
||||||
|
"
|
||||||
|
function! g:SyntasticAutoloclistNotifier.New() " {{{2
|
||||||
|
let newObj = copy(self)
|
||||||
|
return newObj
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticAutoloclistNotifier.refresh(loclist) " {{{2
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'autoloclist: refresh')
|
||||||
|
call g:SyntasticAutoloclistNotifier.AutoToggle(a:loclist)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticAutoloclistNotifier.AutoToggle(loclist) " {{{2
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'autoloclist: toggle')
|
||||||
|
if !a:loclist.isEmpty()
|
||||||
|
if syntastic#util#var('auto_loc_list') == 1
|
||||||
|
call a:loclist.show()
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
if syntastic#util#var('auto_loc_list') > 0
|
||||||
|
|
||||||
|
"TODO: this will close the loc list window if one was opened by
|
||||||
|
"something other than syntastic
|
||||||
|
lclose
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
67
sources_non_forked/syntastic/plugin/syntastic/balloons.vim
Normal file
67
sources_non_forked/syntastic/plugin/syntastic/balloons.vim
Normal file
|
@ -0,0 +1,67 @@
|
||||||
|
if exists("g:loaded_syntastic_notifier_balloons") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_notifier_balloons = 1
|
||||||
|
|
||||||
|
if !has('balloon_eval')
|
||||||
|
let g:syntastic_enable_balloons = 0
|
||||||
|
endif
|
||||||
|
|
||||||
|
let g:SyntasticBalloonsNotifier = {}
|
||||||
|
|
||||||
|
" Public methods {{{1
|
||||||
|
|
||||||
|
function! g:SyntasticBalloonsNotifier.New() " {{{2
|
||||||
|
let newObj = copy(self)
|
||||||
|
return newObj
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticBalloonsNotifier.enabled() " {{{2
|
||||||
|
return has('balloon_eval') && syntastic#util#var('enable_balloons')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Update the error balloons
|
||||||
|
function! g:SyntasticBalloonsNotifier.refresh(loclist) " {{{2
|
||||||
|
let b:syntastic_balloons = {}
|
||||||
|
if self.enabled() && !a:loclist.isEmpty()
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'balloons: refresh')
|
||||||
|
let buf = bufnr('')
|
||||||
|
let issues = filter(a:loclist.copyRaw(), 'v:val["bufnr"] == buf')
|
||||||
|
if !empty(issues)
|
||||||
|
for i in issues
|
||||||
|
if has_key(b:syntastic_balloons, i['lnum'])
|
||||||
|
let b:syntastic_balloons[i['lnum']] .= "\n" . i['text']
|
||||||
|
else
|
||||||
|
let b:syntastic_balloons[i['lnum']] = i['text']
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
set beval bexpr=SyntasticBalloonsExprNotifier()
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Reset the error balloons
|
||||||
|
" @vimlint(EVL103, 1, a:loclist)
|
||||||
|
function! g:SyntasticBalloonsNotifier.reset(loclist) " {{{2
|
||||||
|
let b:syntastic_balloons = {}
|
||||||
|
if has('balloon_eval')
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'balloons: reset')
|
||||||
|
set nobeval
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
" @vimlint(EVL103, 0, a:loclist)
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private functions {{{1
|
||||||
|
|
||||||
|
function! SyntasticBalloonsExprNotifier() " {{{2
|
||||||
|
if !exists('b:syntastic_balloons')
|
||||||
|
return ''
|
||||||
|
endif
|
||||||
|
return get(b:syntastic_balloons, v:beval_lnum, '')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
179
sources_non_forked/syntastic/plugin/syntastic/checker.vim
Normal file
179
sources_non_forked/syntastic/plugin/syntastic/checker.vim
Normal file
|
@ -0,0 +1,179 @@
|
||||||
|
if exists("g:loaded_syntastic_checker") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_checker = 1
|
||||||
|
|
||||||
|
let g:SyntasticChecker = {}
|
||||||
|
|
||||||
|
" Public methods {{{1
|
||||||
|
|
||||||
|
function! g:SyntasticChecker.New(args) " {{{2
|
||||||
|
let newObj = copy(self)
|
||||||
|
|
||||||
|
let newObj._filetype = a:args['filetype']
|
||||||
|
let newObj._name = a:args['name']
|
||||||
|
let newObj._exec = get(a:args, 'exec', newObj._name)
|
||||||
|
let newObj._sort = 0
|
||||||
|
|
||||||
|
if has_key(a:args, 'redirect')
|
||||||
|
let [filetype, name] = split(a:args['redirect'], '/')
|
||||||
|
let prefix = 'SyntaxCheckers_' . filetype . '_' . name . '_'
|
||||||
|
else
|
||||||
|
let prefix = 'SyntaxCheckers_' . newObj._filetype . '_' . newObj._name . '_'
|
||||||
|
endif
|
||||||
|
|
||||||
|
let newObj._locListFunc = function(prefix . 'GetLocList')
|
||||||
|
|
||||||
|
if exists('*' . prefix . 'IsAvailable')
|
||||||
|
let newObj._isAvailableFunc = function(prefix . 'IsAvailable')
|
||||||
|
else
|
||||||
|
let newObj._isAvailableFunc = function('SyntasticCheckerIsAvailableDefault')
|
||||||
|
endif
|
||||||
|
|
||||||
|
if exists('*' . prefix . 'GetHighlightRegex')
|
||||||
|
let newObj._highlightRegexFunc = function(prefix . 'GetHighlightRegex')
|
||||||
|
endif
|
||||||
|
|
||||||
|
return newObj
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticChecker.getFiletype() " {{{2
|
||||||
|
return self._filetype
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticChecker.getName() " {{{2
|
||||||
|
return self._name
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticChecker.getExec() " {{{2
|
||||||
|
if exists('g:syntastic_' . self._filetype . '_' . self._name . '_exec')
|
||||||
|
return expand(g:syntastic_{self._filetype}_{self._name}_exec)
|
||||||
|
endif
|
||||||
|
|
||||||
|
return self._exec
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticChecker.getExecEscaped() " {{{2
|
||||||
|
return syntastic#util#shescape(self.getExec())
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticChecker.getLocListRaw() " {{{2
|
||||||
|
let name = self._filetype . '/' . self._name
|
||||||
|
try
|
||||||
|
let list = self._locListFunc()
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugTrace, 'getLocList: checker ' . name . ' returned ' . v:shell_error)
|
||||||
|
catch /\m\C^Syntastic: checker error$/
|
||||||
|
let list = []
|
||||||
|
call syntastic#log#error('checker ' . name . ' returned abnormal status ' . v:shell_error)
|
||||||
|
endtry
|
||||||
|
call self._populateHighlightRegexes(list)
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugLoclist, name . ' raw:', list)
|
||||||
|
call self._quietMessages(list)
|
||||||
|
return list
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticChecker.getLocList() " {{{2
|
||||||
|
return g:SyntasticLoclist.New(self.getLocListRaw())
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticChecker.getWantSort() " {{{2
|
||||||
|
return self._sort
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticChecker.setWantSort(val) " {{{2
|
||||||
|
let self._sort = a:val
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticChecker.makeprgBuild(opts) " {{{2
|
||||||
|
let basename = self._filetype . '_' . self._name . '_'
|
||||||
|
|
||||||
|
let parts = []
|
||||||
|
call extend(parts, self._getOpt(a:opts, basename, 'exe', self.getExecEscaped()))
|
||||||
|
call extend(parts, self._getOpt(a:opts, basename, 'args', ''))
|
||||||
|
call extend(parts, self._getOpt(a:opts, basename, 'fname', syntastic#util#shexpand('%')))
|
||||||
|
call extend(parts, self._getOpt(a:opts, basename, 'post_args', ''))
|
||||||
|
call extend(parts, self._getOpt(a:opts, basename, 'tail', ''))
|
||||||
|
|
||||||
|
return join(parts)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticChecker.isAvailable() " {{{2
|
||||||
|
if !has_key(self, '_available')
|
||||||
|
let self._available = self._isAvailableFunc()
|
||||||
|
endif
|
||||||
|
return self._available
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private methods {{{1
|
||||||
|
|
||||||
|
function! g:SyntasticChecker._quietMessages(errors) " {{{2
|
||||||
|
" wildcard quiet_messages
|
||||||
|
let quiet_filters = copy(syntastic#util#var('quiet_messages', {}))
|
||||||
|
if type(quiet_filters) != type({})
|
||||||
|
call syntastic#log#warn('ignoring invalid syntastic_quiet_messages')
|
||||||
|
unlet quiet_filters
|
||||||
|
let quiet_filters = {}
|
||||||
|
endif
|
||||||
|
|
||||||
|
" per checker quiet_messages
|
||||||
|
let name = self._filetype . '_' . self._name
|
||||||
|
try
|
||||||
|
call extend( quiet_filters, copy(syntastic#util#var(name . '_quiet_messages', {})), 'force' )
|
||||||
|
catch /\m^Vim\%((\a\+)\)\=:E712/
|
||||||
|
call syntastic#log#warn('ignoring invalid syntastic_' . name . '_quiet_messages')
|
||||||
|
endtry
|
||||||
|
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugLoclist, 'quiet_messages filter:', quiet_filters)
|
||||||
|
|
||||||
|
if !empty(quiet_filters)
|
||||||
|
call syntastic#util#dictFilter(a:errors, quiet_filters)
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugLoclist, 'filtered by quiet_messages:', a:errors)
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticChecker._populateHighlightRegexes(errors) " {{{2
|
||||||
|
if has_key(self, '_highlightRegexFunc')
|
||||||
|
for e in a:errors
|
||||||
|
if e['valid']
|
||||||
|
let term = self._highlightRegexFunc(e)
|
||||||
|
if term != ''
|
||||||
|
let e['hl'] = term
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticChecker._getOpt(opts, basename, name, default) " {{{2
|
||||||
|
let user_val = syntastic#util#var(a:basename . a:name)
|
||||||
|
let ret = []
|
||||||
|
call extend( ret, self._shescape(get(a:opts, a:name . '_before', '')) )
|
||||||
|
call extend( ret, self._shescape(user_val != '' ? user_val : get(a:opts, a:name, a:default)) )
|
||||||
|
call extend( ret, self._shescape(get(a:opts, a:name . '_after', '')) )
|
||||||
|
|
||||||
|
return ret
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticChecker._shescape(opt) " {{{2
|
||||||
|
if type(a:opt) == type('') && a:opt != ''
|
||||||
|
return [a:opt]
|
||||||
|
elseif type(a:opt) == type([])
|
||||||
|
return map(copy(a:opt), 'syntastic#util#shescape(v:val)')
|
||||||
|
endif
|
||||||
|
|
||||||
|
return []
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Non-method functions {{{1
|
||||||
|
|
||||||
|
function! SyntasticCheckerIsAvailableDefault() dict " {{{2
|
||||||
|
return executable(self.getExec())
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
138
sources_non_forked/syntastic/plugin/syntastic/cursor.vim
Normal file
138
sources_non_forked/syntastic/plugin/syntastic/cursor.vim
Normal file
|
@ -0,0 +1,138 @@
|
||||||
|
if exists("g:loaded_syntastic_notifier_cursor") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_notifier_cursor = 1
|
||||||
|
|
||||||
|
let g:SyntasticCursorNotifier = {}
|
||||||
|
|
||||||
|
" Public methods {{{1
|
||||||
|
|
||||||
|
function! g:SyntasticCursorNotifier.New() " {{{2
|
||||||
|
let newObj = copy(self)
|
||||||
|
return newObj
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticCursorNotifier.enabled() " {{{2
|
||||||
|
return syntastic#util#var('echo_current_error')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticCursorNotifier.refresh(loclist) " {{{2
|
||||||
|
if self.enabled() && !a:loclist.isEmpty()
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'cursor: refresh')
|
||||||
|
let b:syntastic_messages = copy(a:loclist.messages(bufnr('')))
|
||||||
|
let b:syntastic_line = -1
|
||||||
|
let b:syntastic_cursor_columns = a:loclist.getCursorColumns()
|
||||||
|
autocmd! syntastic CursorMoved
|
||||||
|
autocmd syntastic CursorMoved * call SyntasticRefreshCursor()
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" @vimlint(EVL103, 1, a:loclist)
|
||||||
|
function! g:SyntasticCursorNotifier.reset(loclist) " {{{2
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'cursor: reset')
|
||||||
|
autocmd! syntastic CursorMoved
|
||||||
|
unlet! b:syntastic_messages
|
||||||
|
let b:syntastic_line = -1
|
||||||
|
endfunction " }}}2
|
||||||
|
" @vimlint(EVL103, 0, a:loclist)
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private methods {{{1
|
||||||
|
|
||||||
|
function! SyntasticRefreshCursor() " {{{2
|
||||||
|
if !exists('b:syntastic_messages') || empty(b:syntastic_messages)
|
||||||
|
" file not checked
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('b:syntastic_line')
|
||||||
|
let b:syntastic_line = -1
|
||||||
|
endif
|
||||||
|
let l = line('.')
|
||||||
|
let current_messages = get(b:syntastic_messages, l, {})
|
||||||
|
|
||||||
|
if !exists('b:syntastic_cursor_columns')
|
||||||
|
let b:syntastic_cursor_columns = g:syntastic_cursor_columns
|
||||||
|
endif
|
||||||
|
|
||||||
|
if b:syntastic_cursor_columns
|
||||||
|
let c = virtcol('.')
|
||||||
|
if !exists('b:syntastic_idx')
|
||||||
|
let b:syntastic_idx = -1
|
||||||
|
endif
|
||||||
|
|
||||||
|
if s:_isSameIndex(l, b:syntastic_line, c, b:syntastic_idx, current_messages)
|
||||||
|
return
|
||||||
|
else
|
||||||
|
let b:syntastic_line = l
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !empty(current_messages)
|
||||||
|
let b:syntastic_idx = s:_findIndex(c, current_messages)
|
||||||
|
call syntastic#util#wideMsg(current_messages[b:syntastic_idx].text)
|
||||||
|
else
|
||||||
|
let b:syntastic_idx = -1
|
||||||
|
echo
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
if l == b:syntastic_line
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
let b:syntastic_line = l
|
||||||
|
|
||||||
|
if !empty(current_messages)
|
||||||
|
call syntastic#util#wideMsg(current_messages[0].text)
|
||||||
|
else
|
||||||
|
echo
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private functions {{{1
|
||||||
|
|
||||||
|
function! s:_isSameIndex(line, old_line, column, idx, messages) " {{{2
|
||||||
|
if a:old_line >= 0 && a:line == a:old_line && a:idx >= 0
|
||||||
|
if len(a:messages) <= 1
|
||||||
|
return 1
|
||||||
|
endif
|
||||||
|
|
||||||
|
if a:messages[a:idx].scol <= a:column
|
||||||
|
if a:idx == len(a:messages) - 1 || a:column < a:messages[a:idx + 1].scol
|
||||||
|
return 1
|
||||||
|
else
|
||||||
|
return 0
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
return 0
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
return 0
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:_findIndex(column, messages) " {{{2
|
||||||
|
let max = len(a:messages) - 1
|
||||||
|
if max == 0
|
||||||
|
return 0
|
||||||
|
endif
|
||||||
|
let min = 0
|
||||||
|
|
||||||
|
" modified binary search: assign index 0 to columns to the left of the first error
|
||||||
|
while min < max - 1
|
||||||
|
let mid = (min + max) / 2
|
||||||
|
if a:column < a:messages[mid].scol
|
||||||
|
let max = mid
|
||||||
|
else
|
||||||
|
let min = mid
|
||||||
|
endif
|
||||||
|
endwhile
|
||||||
|
|
||||||
|
return a:column < a:messages[max].scol ? min : max
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
104
sources_non_forked/syntastic/plugin/syntastic/highlighting.vim
Normal file
104
sources_non_forked/syntastic/plugin/syntastic/highlighting.vim
Normal file
|
@ -0,0 +1,104 @@
|
||||||
|
if exists("g:loaded_syntastic_notifier_highlighting") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_notifier_highlighting = 1
|
||||||
|
|
||||||
|
" Highlighting requires getmatches introduced in 7.1.040
|
||||||
|
let s:has_highlighting = v:version > 701 || (v:version == 701 && has('patch040'))
|
||||||
|
lockvar s:has_highlighting
|
||||||
|
|
||||||
|
let g:SyntasticHighlightingNotifier = {}
|
||||||
|
|
||||||
|
let s:setup_done = 0
|
||||||
|
|
||||||
|
" Public methods {{{1
|
||||||
|
|
||||||
|
function! g:SyntasticHighlightingNotifier.New() " {{{2
|
||||||
|
let newObj = copy(self)
|
||||||
|
|
||||||
|
if !s:setup_done
|
||||||
|
call self._setup()
|
||||||
|
let s:setup_done = 1
|
||||||
|
lockvar s:setup_done
|
||||||
|
endif
|
||||||
|
|
||||||
|
return newObj
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticHighlightingNotifier.enabled() " {{{2
|
||||||
|
return s:has_highlighting && syntastic#util#var('enable_highlighting')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Sets error highlights in the cuirrent window
|
||||||
|
function! g:SyntasticHighlightingNotifier.refresh(loclist) " {{{2
|
||||||
|
if self.enabled()
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'highlighting: refresh')
|
||||||
|
call self._reset()
|
||||||
|
let buf = bufnr('')
|
||||||
|
let issues = filter(a:loclist.copyRaw(), 'v:val["bufnr"] == buf')
|
||||||
|
for item in issues
|
||||||
|
let group = 'Syntastic' . get(item, 'subtype', '') . ( item['type'] ==? 'E' ? 'Error' : 'Warning' )
|
||||||
|
|
||||||
|
" The function `Syntastic_{filetype}_{checker}_GetHighlightRegex` is
|
||||||
|
" used to override default highlighting.
|
||||||
|
if has_key(item, 'hl')
|
||||||
|
call matchadd(group, '\%' . item['lnum'] . 'l' . item['hl'])
|
||||||
|
elseif get(item, 'col', 0)
|
||||||
|
if get(item, 'vcol', 0)
|
||||||
|
let lastcol = virtcol([item['lnum'], '$'])
|
||||||
|
let coltype = 'v'
|
||||||
|
else
|
||||||
|
let lastcol = col([item['lnum'], '$'])
|
||||||
|
let coltype = 'c'
|
||||||
|
endif
|
||||||
|
let lcol = min([lastcol, item['col']])
|
||||||
|
|
||||||
|
call matchadd(group, '\%' . item['lnum'] . 'l\%' . lcol . coltype)
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Remove all error highlights from the window
|
||||||
|
" @vimlint(EVL103, 1, a:loclist)
|
||||||
|
function! g:SyntasticHighlightingNotifier.reset(loclist) " {{{2
|
||||||
|
if s:has_highlighting
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'highlighting: reset')
|
||||||
|
call self._reset()
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
" @vimlint(EVL103, 0, a:loclist)
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private methods {{{1
|
||||||
|
|
||||||
|
" One time setup: define our own highlighting
|
||||||
|
function! g:SyntasticHighlightingNotifier._setup() " {{{2
|
||||||
|
if s:has_highlighting
|
||||||
|
if !hlexists('SyntasticError')
|
||||||
|
highlight link SyntasticError SpellBad
|
||||||
|
endif
|
||||||
|
if !hlexists('SyntasticWarning')
|
||||||
|
highlight link SyntasticWarning SpellCap
|
||||||
|
endif
|
||||||
|
if !hlexists('SyntasticStyleError')
|
||||||
|
highlight link SyntasticStyleError SyntasticError
|
||||||
|
endif
|
||||||
|
if !hlexists('SyntasticStyleWarning')
|
||||||
|
highlight link SyntasticStyleWarning SyntasticWarning
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticHighlightingNotifier._reset() " {{{2
|
||||||
|
for match in getmatches()
|
||||||
|
if stridx(match['group'], 'Syntastic') == 0
|
||||||
|
call matchdelete(match['id'])
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
400
sources_non_forked/syntastic/plugin/syntastic/loclist.vim
Normal file
400
sources_non_forked/syntastic/plugin/syntastic/loclist.vim
Normal file
|
@ -0,0 +1,400 @@
|
||||||
|
if exists("g:loaded_syntastic_loclist") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_loclist = 1
|
||||||
|
|
||||||
|
let g:SyntasticLoclist = {}
|
||||||
|
|
||||||
|
" Public methods {{{1
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.New(rawLoclist) " {{{2
|
||||||
|
let newObj = copy(self)
|
||||||
|
|
||||||
|
let llist = filter(copy(a:rawLoclist), 'v:val["valid"] == 1')
|
||||||
|
|
||||||
|
for e in llist
|
||||||
|
if get(e, 'type', '') == ''
|
||||||
|
let e['type'] = 'E'
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
let newObj._rawLoclist = llist
|
||||||
|
let newObj._name = ''
|
||||||
|
let newObj._owner = bufnr('')
|
||||||
|
let newObj._sorted = 0
|
||||||
|
let newObj._columns = g:syntastic_cursor_columns
|
||||||
|
|
||||||
|
return newObj
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.current() " {{{2
|
||||||
|
if !exists("b:syntastic_loclist") || empty(b:syntastic_loclist)
|
||||||
|
let b:syntastic_loclist = g:SyntasticLoclist.New([])
|
||||||
|
endif
|
||||||
|
return b:syntastic_loclist
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.extend(other) " {{{2
|
||||||
|
let list = self.copyRaw()
|
||||||
|
call extend(list, a:other.copyRaw())
|
||||||
|
return g:SyntasticLoclist.New(list)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.sort() " {{{2
|
||||||
|
if !self._sorted
|
||||||
|
for e in self._rawLoclist
|
||||||
|
call s:_setScreenColumn(e)
|
||||||
|
endfor
|
||||||
|
|
||||||
|
call sort(self._rawLoclist, self._columns ? 's:_compareErrorItemsByColumns' : 's:_compareErrorItemsByLines')
|
||||||
|
|
||||||
|
let self._sorted = 1
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.isEmpty() " {{{2
|
||||||
|
return empty(self._rawLoclist)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.isNewerThan(stamp) " {{{2
|
||||||
|
if !exists("self._stamp")
|
||||||
|
let self._stamp = []
|
||||||
|
return 0
|
||||||
|
endif
|
||||||
|
return syntastic#util#compareLexi(self._stamp, a:stamp) > 0
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.copyRaw() " {{{2
|
||||||
|
return copy(self._rawLoclist)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.getRaw() " {{{2
|
||||||
|
return self._rawLoclist
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.getBuffers() " {{{2
|
||||||
|
return syntastic#util#unique(map(copy(self._rawLoclist), 'str2nr(v:val["bufnr"])') + [self._owner])
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.getCursorColumns() " {{{2
|
||||||
|
return self._columns
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.getStatuslineFlag() " {{{2
|
||||||
|
if !exists("self._stl_format")
|
||||||
|
let self._stl_format = ''
|
||||||
|
endif
|
||||||
|
if !exists("self._stl_flag")
|
||||||
|
let self._stl_flag = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
if g:syntastic_stl_format !=# self._stl_format
|
||||||
|
let self._stl_format = g:syntastic_stl_format
|
||||||
|
|
||||||
|
if !empty(self._rawLoclist)
|
||||||
|
let errors = self.errors()
|
||||||
|
let warnings = self.warnings()
|
||||||
|
|
||||||
|
let num_errors = len(errors)
|
||||||
|
let num_warnings = len(warnings)
|
||||||
|
let num_issues = len(self._rawLoclist)
|
||||||
|
|
||||||
|
let output = self._stl_format
|
||||||
|
|
||||||
|
"hide stuff wrapped in %E(...) unless there are errors
|
||||||
|
let output = substitute(output, '\m\C%E{\([^}]*\)}', num_errors ? '\1' : '' , 'g')
|
||||||
|
|
||||||
|
"hide stuff wrapped in %W(...) unless there are warnings
|
||||||
|
let output = substitute(output, '\m\C%W{\([^}]*\)}', num_warnings ? '\1' : '' , 'g')
|
||||||
|
|
||||||
|
"hide stuff wrapped in %B(...) unless there are both errors and warnings
|
||||||
|
let output = substitute(output, '\m\C%B{\([^}]*\)}', (num_warnings && num_errors) ? '\1' : '' , 'g')
|
||||||
|
|
||||||
|
"sub in the total errors/warnings/both
|
||||||
|
let output = substitute(output, '\m\C%w', num_warnings, 'g')
|
||||||
|
let output = substitute(output, '\m\C%e', num_errors, 'g')
|
||||||
|
let output = substitute(output, '\m\C%t', num_issues, 'g')
|
||||||
|
|
||||||
|
"first error/warning line num
|
||||||
|
let output = substitute(output, '\m\C%F', num_issues ? self._rawLoclist[0]['lnum'] : '', 'g')
|
||||||
|
|
||||||
|
"first error line num
|
||||||
|
let output = substitute(output, '\m\C%fe', num_errors ? errors[0]['lnum'] : '', 'g')
|
||||||
|
|
||||||
|
"first warning line num
|
||||||
|
let output = substitute(output, '\m\C%fw', num_warnings ? warnings[0]['lnum'] : '', 'g')
|
||||||
|
|
||||||
|
let self._stl_flag = output
|
||||||
|
else
|
||||||
|
let self._stl_flag = ''
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
return self._stl_flag
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.getFirstIssue() " {{{2
|
||||||
|
return get(self._rawLoclist, 0, {})
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.getName() " {{{2
|
||||||
|
return len(self._name)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.setName(name) " {{{2
|
||||||
|
let self._name = a:name
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.getOwner() " {{{2
|
||||||
|
return self._owner
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.setOwner(buffer) " {{{2
|
||||||
|
let self._owner = type(a:buffer) == type(0) ? a:buffer : str2nr(a:buffer)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.deploy() " {{{2
|
||||||
|
call self.setOwner(bufnr(''))
|
||||||
|
let self._stamp = syntastic#util#stamp()
|
||||||
|
for buf in self.getBuffers()
|
||||||
|
call setbufvar(buf, 'syntastic_loclist', self)
|
||||||
|
endfor
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.destroy() " {{{2
|
||||||
|
for buf in self.getBuffers()
|
||||||
|
call setbufvar(buf, 'syntastic_loclist', {})
|
||||||
|
endfor
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.decorate(tag) " {{{2
|
||||||
|
for e in self._rawLoclist
|
||||||
|
let e['text'] .= ' [' . a:tag . ']'
|
||||||
|
endfor
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.errors() " {{{2
|
||||||
|
if !exists("self._cachedErrors")
|
||||||
|
let self._cachedErrors = self.filter({'type': "E"})
|
||||||
|
endif
|
||||||
|
return self._cachedErrors
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.warnings() " {{{2
|
||||||
|
if !exists("self._cachedWarnings")
|
||||||
|
let self._cachedWarnings = self.filter({'type': "W"})
|
||||||
|
endif
|
||||||
|
return self._cachedWarnings
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Legacy function. Syntastic no longer calls it, but we keep it
|
||||||
|
" around because other plugins (f.i. powerline) depend on it.
|
||||||
|
function! g:SyntasticLoclist.hasErrorsOrWarningsToDisplay() " {{{2
|
||||||
|
return !self.isEmpty()
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" cache used by EchoCurrentError()
|
||||||
|
function! g:SyntasticLoclist.messages(buf) " {{{2
|
||||||
|
if !exists("self._cachedMessages")
|
||||||
|
let self._cachedMessages = {}
|
||||||
|
|
||||||
|
let errors = self.errors() + self.warnings()
|
||||||
|
for e in errors
|
||||||
|
let b = e['bufnr']
|
||||||
|
let l = e['lnum']
|
||||||
|
|
||||||
|
if !has_key(self._cachedMessages, b)
|
||||||
|
let self._cachedMessages[b] = {}
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !has_key(self._cachedMessages[b], l)
|
||||||
|
let self._cachedMessages[b][l] = [e]
|
||||||
|
elseif self._columns
|
||||||
|
call add(self._cachedMessages[b][l], e)
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
if self._columns
|
||||||
|
if !self._sorted
|
||||||
|
for b in keys(self._cachedMessages)
|
||||||
|
for l in keys(self._cachedMessages[b])
|
||||||
|
if len(self._cachedMessages[b][l]) > 1
|
||||||
|
for e in self._cachedMessages[b][l]
|
||||||
|
call s:_setScreenColumn(e)
|
||||||
|
endfor
|
||||||
|
call sort(self._cachedMessages[b][l], 's:_compareErrorItemsByColumns')
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
|
||||||
|
for b in keys(self._cachedMessages)
|
||||||
|
for l in keys(self._cachedMessages[b])
|
||||||
|
call s:_removeShadowedItems(self._cachedMessages[b][l])
|
||||||
|
endfor
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
return get(self._cachedMessages, a:buf, {})
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
"Filter the list and return new native loclist
|
||||||
|
"e.g.
|
||||||
|
" .filter({'bufnr': 10, 'type': 'e'})
|
||||||
|
"
|
||||||
|
"would return all errors for buffer 10.
|
||||||
|
"
|
||||||
|
"Note that all comparisons are done with ==?
|
||||||
|
function! g:SyntasticLoclist.filter(filters) " {{{2
|
||||||
|
let conditions = values(map(copy(a:filters), 's:_translate(v:key, v:val)'))
|
||||||
|
let filter = len(conditions) == 1 ?
|
||||||
|
\ conditions[0] : join(map(conditions, '"(" . v:val . ")"'), ' && ')
|
||||||
|
return filter(copy(self._rawLoclist), filter)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticLoclist.setloclist() " {{{2
|
||||||
|
if !exists('w:syntastic_loclist_set')
|
||||||
|
let w:syntastic_loclist_set = 0
|
||||||
|
endif
|
||||||
|
let replace = g:syntastic_reuse_loc_lists && w:syntastic_loclist_set
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'loclist: setloclist ' . (replace ? '(replace)' : '(new)'))
|
||||||
|
call setloclist(0, self.getRaw(), replace ? 'r' : ' ')
|
||||||
|
let w:syntastic_loclist_set = 1
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
"display the cached errors for this buf in the location list
|
||||||
|
function! g:SyntasticLoclist.show() " {{{2
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'loclist: show')
|
||||||
|
call self.setloclist()
|
||||||
|
|
||||||
|
if !self.isEmpty()
|
||||||
|
let num = winnr()
|
||||||
|
execute "lopen " . syntastic#util#var('loc_list_height')
|
||||||
|
if num != winnr()
|
||||||
|
wincmd p
|
||||||
|
endif
|
||||||
|
|
||||||
|
" try to find the loclist window and set w:quickfix_title
|
||||||
|
let errors = getloclist(0)
|
||||||
|
for buf in tabpagebuflist()
|
||||||
|
if buflisted(buf) && bufloaded(buf) && getbufvar(buf, '&buftype') ==# 'quickfix'
|
||||||
|
let win = bufwinnr(buf)
|
||||||
|
let title = getwinvar(win, 'quickfix_title')
|
||||||
|
|
||||||
|
" TODO: try to make sure we actually own this window; sadly,
|
||||||
|
" errors == getloclist(0) is the only somewhat safe way to
|
||||||
|
" achieve that
|
||||||
|
if strpart(title, 0, 16) ==# ':SyntasticCheck ' ||
|
||||||
|
\ ( (title == '' || title ==# ':setloclist()') && errors == getloclist(0) )
|
||||||
|
call setwinvar(win, 'quickfix_title', ':SyntasticCheck ' . self._name)
|
||||||
|
call setbufvar(buf, 'syntastic_owner_buffer', self._owner)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Non-method functions {{{1
|
||||||
|
|
||||||
|
function! SyntasticLoclistHide() " {{{2
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'loclist: hide')
|
||||||
|
silent! lclose
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private functions {{{1
|
||||||
|
|
||||||
|
function! s:_translate(key, val) " {{{2
|
||||||
|
return 'get(v:val, ' . string(a:key) . ', "") ==? ' . string(a:val)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:_setScreenColumn(item) " {{{2
|
||||||
|
if !has_key(a:item, 'scol')
|
||||||
|
let col = get(a:item, 'col', 0)
|
||||||
|
if col != 0 && a:item['vcol'] == 0
|
||||||
|
let buf = str2nr(a:item['bufnr'])
|
||||||
|
try
|
||||||
|
let line = getbufline(buf, a:item['lnum'])[0]
|
||||||
|
catch /\m^Vim\%((\a\+)\)\=:E684/
|
||||||
|
let line = ''
|
||||||
|
endtry
|
||||||
|
let a:item['scol'] = syntastic#util#screenWidth(strpart(line, 0, col), getbufvar(buf, '&tabstop'))
|
||||||
|
else
|
||||||
|
let a:item['scol'] = col
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:_removeShadowedItems(errors) " {{{2
|
||||||
|
" keep only the first message at a given column
|
||||||
|
let i = 0
|
||||||
|
while i < len(a:errors) - 1
|
||||||
|
let j = i + 1
|
||||||
|
let dupes = 0
|
||||||
|
while j < len(a:errors) && a:errors[j].scol == a:errors[i].scol
|
||||||
|
let dupes = 1
|
||||||
|
let j += 1
|
||||||
|
endwhile
|
||||||
|
if dupes
|
||||||
|
call remove(a:errors, i + 1, j - 1)
|
||||||
|
endif
|
||||||
|
let i += 1
|
||||||
|
endwhile
|
||||||
|
|
||||||
|
" merge messages with the same text
|
||||||
|
let i = 0
|
||||||
|
while i < len(a:errors) - 1
|
||||||
|
let j = i + 1
|
||||||
|
let dupes = 0
|
||||||
|
while j < len(a:errors) && a:errors[j].text == a:errors[i].text
|
||||||
|
let dupes = 1
|
||||||
|
let j += 1
|
||||||
|
endwhile
|
||||||
|
if dupes
|
||||||
|
call remove(a:errors, i + 1, j - 1)
|
||||||
|
endif
|
||||||
|
let i += 1
|
||||||
|
endwhile
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:_compareErrorItemsByColumns(a, b) " {{{2
|
||||||
|
if a:a['bufnr'] != a:b['bufnr']
|
||||||
|
" group by file
|
||||||
|
return a:a['bufnr'] - a:b['bufnr']
|
||||||
|
elseif a:a['lnum'] != a:b['lnum']
|
||||||
|
" sort by line
|
||||||
|
return a:a['lnum'] - a:b['lnum']
|
||||||
|
elseif a:a['scol'] != a:b['scol']
|
||||||
|
" sort by screen column
|
||||||
|
return a:a['scol'] - a:b['scol']
|
||||||
|
elseif a:a['type'] !=? a:b['type']
|
||||||
|
" errors take precedence over warnings
|
||||||
|
return a:a['type'] ==? 'E' ? -1 : 1
|
||||||
|
else
|
||||||
|
return 0
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! s:_compareErrorItemsByLines(a, b) " {{{2
|
||||||
|
if a:a['bufnr'] != a:b['bufnr']
|
||||||
|
" group by file
|
||||||
|
return a:a['bufnr'] - a:b['bufnr']
|
||||||
|
elseif a:a['lnum'] != a:b['lnum']
|
||||||
|
" sort by line
|
||||||
|
return a:a['lnum'] - a:b['lnum']
|
||||||
|
elseif a:a['type'] !=? a:b['type']
|
||||||
|
" errors take precedence over warnings
|
||||||
|
return a:a['type'] ==? 'E' ? -1 : 1
|
||||||
|
else
|
||||||
|
" sort by screen column
|
||||||
|
return a:a['scol'] - a:b['scol']
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
100
sources_non_forked/syntastic/plugin/syntastic/modemap.vim
Normal file
100
sources_non_forked/syntastic/plugin/syntastic/modemap.vim
Normal file
|
@ -0,0 +1,100 @@
|
||||||
|
if exists("g:loaded_syntastic_modemap") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_modemap = 1
|
||||||
|
|
||||||
|
let g:SyntasticModeMap = {}
|
||||||
|
|
||||||
|
" Public methods {{{1
|
||||||
|
|
||||||
|
function! g:SyntasticModeMap.Instance() " {{{2
|
||||||
|
if !exists('s:SyntasticModeMapInstance')
|
||||||
|
let s:SyntasticModeMapInstance = copy(self)
|
||||||
|
call s:SyntasticModeMapInstance.synch()
|
||||||
|
endif
|
||||||
|
|
||||||
|
return s:SyntasticModeMapInstance
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticModeMap.synch() " {{{2
|
||||||
|
if exists('g:syntastic_mode_map')
|
||||||
|
let self._mode = get(g:syntastic_mode_map, 'mode', 'active')
|
||||||
|
let self._activeFiletypes = copy(get(g:syntastic_mode_map, 'active_filetypes', []))
|
||||||
|
let self._passiveFiletypes = copy(get(g:syntastic_mode_map, 'passive_filetypes', []))
|
||||||
|
else
|
||||||
|
let self._mode = 'active'
|
||||||
|
let self._activeFiletypes = []
|
||||||
|
let self._passiveFiletypes = []
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticModeMap.allowsAutoChecking(filetype) " {{{2
|
||||||
|
let fts = split(a:filetype, '\m\.')
|
||||||
|
|
||||||
|
if self.isPassive()
|
||||||
|
return self._isOneFiletypeActive(fts)
|
||||||
|
else
|
||||||
|
return self._noFiletypesArePassive(fts)
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticModeMap.isPassive() " {{{2
|
||||||
|
return self._mode ==# 'passive'
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticModeMap.toggleMode() " {{{2
|
||||||
|
call self.synch()
|
||||||
|
|
||||||
|
if self._mode ==# 'active'
|
||||||
|
let self._mode = 'passive'
|
||||||
|
else
|
||||||
|
let self._mode = 'active'
|
||||||
|
endif
|
||||||
|
|
||||||
|
"XXX Changing a global variable. Tsk, tsk...
|
||||||
|
if !exists('g:syntastic_mode_map')
|
||||||
|
let g:syntastic_mode_map = {}
|
||||||
|
endif
|
||||||
|
let g:syntastic_mode_map['mode'] = self._mode
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticModeMap.echoMode() " {{{2
|
||||||
|
echo "Syntastic: " . self._mode . " mode enabled"
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticModeMap.modeInfo(...) " {{{2
|
||||||
|
echomsg 'Syntastic version: ' . g:syntastic_version
|
||||||
|
let type = a:0 ? a:1 : &filetype
|
||||||
|
echomsg 'Info for filetype: ' . type
|
||||||
|
|
||||||
|
call self.synch()
|
||||||
|
echomsg 'Mode: ' . self._mode
|
||||||
|
if self._mode ==# 'active'
|
||||||
|
if len(self._passiveFiletypes)
|
||||||
|
let plural = len(self._passiveFiletypes) != 1 ? 's' : ''
|
||||||
|
echomsg 'Passive filetype' . plural . ': ' . join(sort(copy(self._passiveFiletypes)))
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
if len(self._activeFiletypes)
|
||||||
|
let plural = len(self._activeFiletypes) != 1 ? 's' : ''
|
||||||
|
echomsg 'Active filetype' . plural . ': ' . join(sort(copy(self._activeFiletypes)))
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
echomsg 'Filetype ' . type . ' is ' . (self.allowsAutoChecking(type) ? 'active' : 'passive')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private methods {{{1
|
||||||
|
|
||||||
|
function! g:SyntasticModeMap._isOneFiletypeActive(filetypes) " {{{2
|
||||||
|
return !empty(filter(copy(a:filetypes), 'index(self._activeFiletypes, v:val) != -1'))
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticModeMap._noFiletypesArePassive(filetypes) " {{{2
|
||||||
|
return empty(filter(copy(a:filetypes), 'index(self._passiveFiletypes, v:val) != -1'))
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
86
sources_non_forked/syntastic/plugin/syntastic/notifiers.vim
Normal file
86
sources_non_forked/syntastic/plugin/syntastic/notifiers.vim
Normal file
|
@ -0,0 +1,86 @@
|
||||||
|
if exists("g:loaded_syntastic_notifiers") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_notifiers = 1
|
||||||
|
|
||||||
|
let g:SyntasticNotifiers = {}
|
||||||
|
|
||||||
|
let s:notifier_types = ['signs', 'balloons', 'highlighting', 'cursor', 'autoloclist']
|
||||||
|
lockvar! s:notifier_types
|
||||||
|
|
||||||
|
let s:persistent_notifiers = ['signs', 'balloons']
|
||||||
|
lockvar! s:persistent_notifiers
|
||||||
|
|
||||||
|
" Public methods {{{1
|
||||||
|
|
||||||
|
function! g:SyntasticNotifiers.Instance() " {{{2
|
||||||
|
if !exists('s:SyntasticNotifiersInstance')
|
||||||
|
let s:SyntasticNotifiersInstance = copy(self)
|
||||||
|
call s:SyntasticNotifiersInstance._initNotifiers()
|
||||||
|
endif
|
||||||
|
|
||||||
|
return s:SyntasticNotifiersInstance
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticNotifiers.refresh(loclist) " {{{2
|
||||||
|
if !a:loclist.isEmpty() && !a:loclist.isNewerThan([])
|
||||||
|
" loclist not fully constructed yet
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'notifiers: refresh')
|
||||||
|
for type in self._enabled_types
|
||||||
|
let class = substitute(type, '\m.*', 'Syntastic\u&Notifier', '')
|
||||||
|
if !has_key(g:{class}, 'enabled') || self._notifier[type].enabled()
|
||||||
|
if index(s:persistent_notifiers, type) > -1
|
||||||
|
" refresh only if loclist has changed since last call
|
||||||
|
if !exists('b:syntastic_' . type . '_stamp')
|
||||||
|
let b:syntastic_{type}_stamp = []
|
||||||
|
endif
|
||||||
|
if a:loclist.isNewerThan(b:syntastic_{type}_stamp) || a:loclist.isEmpty()
|
||||||
|
call self._notifier[type].refresh(a:loclist)
|
||||||
|
let b:syntastic_{type}_stamp = syntastic#util#stamp()
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
call self._notifier[type].refresh(a:loclist)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticNotifiers.reset(loclist) " {{{2
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'notifiers: reset')
|
||||||
|
for type in self._enabled_types
|
||||||
|
let class = substitute(type, '\m.*', 'Syntastic\u&Notifier', '')
|
||||||
|
|
||||||
|
" reset notifiers regardless if they are enabled or not, since
|
||||||
|
" the user might have disabled them since the last refresh();
|
||||||
|
" notifiers MUST be prepared to deal with reset() when disabled
|
||||||
|
if has_key(g:{class}, 'reset')
|
||||||
|
call self._notifier[type].reset(a:loclist)
|
||||||
|
endif
|
||||||
|
|
||||||
|
" also reset stamps
|
||||||
|
if index(s:persistent_notifiers, type) > -1
|
||||||
|
let b:syntastic_{type}_stamp = []
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private methods {{{1
|
||||||
|
|
||||||
|
function! g:SyntasticNotifiers._initNotifiers() " {{{2
|
||||||
|
let self._notifier = {}
|
||||||
|
for type in s:notifier_types
|
||||||
|
let class = substitute(type, '\m.*', 'Syntastic\u&Notifier', '')
|
||||||
|
let self._notifier[type] = g:{class}.New()
|
||||||
|
endfor
|
||||||
|
|
||||||
|
let self._enabled_types = copy(s:notifier_types)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
265
sources_non_forked/syntastic/plugin/syntastic/registry.vim
Normal file
265
sources_non_forked/syntastic/plugin/syntastic/registry.vim
Normal file
|
@ -0,0 +1,265 @@
|
||||||
|
if exists("g:loaded_syntastic_registry") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_registry = 1
|
||||||
|
|
||||||
|
" Initialisation {{{1
|
||||||
|
|
||||||
|
let s:defaultCheckers = {
|
||||||
|
\ 'actionscript':['mxmlc'],
|
||||||
|
\ 'ada': ['gcc'],
|
||||||
|
\ 'applescript': ['osacompile'],
|
||||||
|
\ 'arduino': ['avrgcc'],
|
||||||
|
\ 'asciidoc': ['asciidoc'],
|
||||||
|
\ 'asm': ['gcc'],
|
||||||
|
\ 'bro': ['bro'],
|
||||||
|
\ 'bemhtml': ['bemhtmllint'],
|
||||||
|
\ 'c': ['gcc'],
|
||||||
|
\ 'cabal': ['cabal'],
|
||||||
|
\ 'chef': ['foodcritic'],
|
||||||
|
\ 'co': ['coco'],
|
||||||
|
\ 'cobol': ['cobc'],
|
||||||
|
\ 'coffee': ['coffee', 'coffeelint'],
|
||||||
|
\ 'coq': ['coqtop'],
|
||||||
|
\ 'cpp': ['gcc'],
|
||||||
|
\ 'cs': ['mcs'],
|
||||||
|
\ 'css': ['csslint'],
|
||||||
|
\ 'cucumber': ['cucumber'],
|
||||||
|
\ 'cuda': ['nvcc'],
|
||||||
|
\ 'd': ['dmd'],
|
||||||
|
\ 'dart': ['dartanalyzer'],
|
||||||
|
\ 'docbk': ['xmllint'],
|
||||||
|
\ 'dustjs': ['swiffer'],
|
||||||
|
\ 'elixir': [],
|
||||||
|
\ 'erlang': ['escript'],
|
||||||
|
\ 'eruby': ['ruby'],
|
||||||
|
\ 'fortran': ['gfortran'],
|
||||||
|
\ 'glsl': ['cgc'],
|
||||||
|
\ 'go': ['go'],
|
||||||
|
\ 'haml': ['haml'],
|
||||||
|
\ 'handlebars': ['handlebars'],
|
||||||
|
\ 'haskell': ['ghc_mod', 'hdevtools', 'hlint'],
|
||||||
|
\ 'haxe': ['haxe'],
|
||||||
|
\ 'hss': ['hss'],
|
||||||
|
\ 'html': ['tidy'],
|
||||||
|
\ 'java': ['javac'],
|
||||||
|
\ 'javascript': ['jshint', 'jslint'],
|
||||||
|
\ 'json': ['jsonlint', 'jsonval'],
|
||||||
|
\ 'less': ['lessc'],
|
||||||
|
\ 'lex': ['flex'],
|
||||||
|
\ 'limbo': ['limbo'],
|
||||||
|
\ 'lisp': ['clisp'],
|
||||||
|
\ 'llvm': ['llvm'],
|
||||||
|
\ 'lua': ['luac'],
|
||||||
|
\ 'matlab': ['mlint'],
|
||||||
|
\ 'nasm': ['nasm'],
|
||||||
|
\ 'nroff': ['mandoc'],
|
||||||
|
\ 'objc': ['gcc'],
|
||||||
|
\ 'objcpp': ['gcc'],
|
||||||
|
\ 'ocaml': ['camlp4o'],
|
||||||
|
\ 'perl': ['perlcritic'],
|
||||||
|
\ 'php': ['php', 'phpcs', 'phpmd'],
|
||||||
|
\ 'po': ['msgfmt'],
|
||||||
|
\ 'pod': ['podchecker'],
|
||||||
|
\ 'puppet': ['puppet', 'puppetlint'],
|
||||||
|
\ 'python': ['python', 'flake8', 'pylint'],
|
||||||
|
\ 'r': [],
|
||||||
|
\ 'racket': ['racket'],
|
||||||
|
\ 'rst': ['rst2pseudoxml'],
|
||||||
|
\ 'ruby': ['mri'],
|
||||||
|
\ 'sass': ['sass'],
|
||||||
|
\ 'scala': ['fsc', 'scalac'],
|
||||||
|
\ 'scss': ['sass', 'scss_lint'],
|
||||||
|
\ 'sh': ['sh', 'shellcheck'],
|
||||||
|
\ 'slim': ['slimrb'],
|
||||||
|
\ 'tcl': ['nagelfar'],
|
||||||
|
\ 'tex': ['lacheck', 'chktex'],
|
||||||
|
\ 'texinfo': ['makeinfo'],
|
||||||
|
\ 'text': ['atdtool'],
|
||||||
|
\ 'twig': ['twiglint'],
|
||||||
|
\ 'typescript': ['tsc'],
|
||||||
|
\ 'vala': ['valac'],
|
||||||
|
\ 'verilog': ['verilator'],
|
||||||
|
\ 'vhdl': ['ghdl'],
|
||||||
|
\ 'vim': ['vimlint'],
|
||||||
|
\ 'xhtml': ['tidy'],
|
||||||
|
\ 'xml': ['xmllint'],
|
||||||
|
\ 'xslt': ['xmllint'],
|
||||||
|
\ 'yacc': ['bison'],
|
||||||
|
\ 'yaml': ['jsyaml'],
|
||||||
|
\ 'z80': ['z80syntaxchecker'],
|
||||||
|
\ 'zpt': ['zptlint'],
|
||||||
|
\ 'zsh': ['zsh', 'shellcheck']
|
||||||
|
\ }
|
||||||
|
lockvar! s:defaultCheckers
|
||||||
|
|
||||||
|
let s:defaultFiletypeMap = {
|
||||||
|
\ 'gentoo-metadata': 'xml',
|
||||||
|
\ 'lhaskell': 'haskell',
|
||||||
|
\ 'litcoffee': 'coffee'
|
||||||
|
\ }
|
||||||
|
lockvar! s:defaultFiletypeMap
|
||||||
|
|
||||||
|
let g:SyntasticRegistry = {}
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Public methods {{{1
|
||||||
|
|
||||||
|
" Note: Handling of filetype aliases: all public methods take aliases as
|
||||||
|
" parameters, all private methods take normalized filetypes. Public methods
|
||||||
|
" are thus supposed to normalize filetypes before calling private methods.
|
||||||
|
|
||||||
|
function! g:SyntasticRegistry.Instance() " {{{2
|
||||||
|
if !exists('s:SyntasticRegistryInstance')
|
||||||
|
let s:SyntasticRegistryInstance = copy(self)
|
||||||
|
let s:SyntasticRegistryInstance._checkerMap = {}
|
||||||
|
endif
|
||||||
|
|
||||||
|
return s:SyntasticRegistryInstance
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticRegistry.CreateAndRegisterChecker(args) " {{{2
|
||||||
|
let checker = g:SyntasticChecker.New(a:args)
|
||||||
|
let registry = g:SyntasticRegistry.Instance()
|
||||||
|
call registry._registerChecker(checker)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Given a list of checker names hints_list, return a map name --> checker.
|
||||||
|
" If hints_list is empty, user settings are are used instead. Checkers are
|
||||||
|
" not checked for availability (that is, the corresponding IsAvailable() are
|
||||||
|
" not run).
|
||||||
|
function! g:SyntasticRegistry.getCheckers(ftalias, hints_list) " {{{2
|
||||||
|
let ft = s:_normaliseFiletype(a:ftalias)
|
||||||
|
call self._loadCheckersFor(ft)
|
||||||
|
|
||||||
|
let checkers_map = self._checkerMap[ft]
|
||||||
|
if empty(checkers_map)
|
||||||
|
return []
|
||||||
|
endif
|
||||||
|
|
||||||
|
call self._checkDeprecation(ft)
|
||||||
|
|
||||||
|
let names =
|
||||||
|
\ !empty(a:hints_list) ? syntastic#util#unique(a:hints_list) :
|
||||||
|
\ exists('b:syntastic_checkers') ? b:syntastic_checkers :
|
||||||
|
\ exists('g:syntastic_' . ft . '_checkers') ? g:syntastic_{ft}_checkers :
|
||||||
|
\ get(s:defaultCheckers, ft, 0)
|
||||||
|
|
||||||
|
return type(names) == type([]) ?
|
||||||
|
\ self._filterCheckersByName(checkers_map, names) : [checkers_map[keys(checkers_map)[0]]]
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Same as getCheckers(), but keep only the checkers available. This runs the
|
||||||
|
" corresponding IsAvailable() functions for all checkers.
|
||||||
|
function! g:SyntasticRegistry.getCheckersAvailable(ftalias, hints_list) " {{{2
|
||||||
|
return filter(self.getCheckers(a:ftalias, a:hints_list), 'v:val.isAvailable()')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticRegistry.getKnownFiletypes() " {{{2
|
||||||
|
let types = keys(s:defaultCheckers)
|
||||||
|
|
||||||
|
call extend(types, keys(s:defaultFiletypeMap))
|
||||||
|
|
||||||
|
if exists('g:syntastic_filetype_map')
|
||||||
|
call extend(types, keys(g:syntastic_filetype_map))
|
||||||
|
endif
|
||||||
|
|
||||||
|
if exists('g:syntastic_extra_filetypes') && type(g:syntastic_extra_filetypes) == type([])
|
||||||
|
call extend(types, g:syntastic_extra_filetypes)
|
||||||
|
endif
|
||||||
|
|
||||||
|
return syntastic#util#unique(types)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticRegistry.getNamesOfAvailableCheckers(ftalias) " {{{2
|
||||||
|
let ft = s:_normaliseFiletype(a:ftalias)
|
||||||
|
call self._loadCheckersFor(ft)
|
||||||
|
return keys(filter( copy(self._checkerMap[ft]), 'v:val.isAvailable()' ))
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticRegistry.echoInfoFor(ftalias_list) " {{{2
|
||||||
|
let ft_list = syntastic#util#unique(map( copy(a:ftalias_list), 's:_normaliseFiletype(v:val)' ))
|
||||||
|
if len(ft_list) != 1
|
||||||
|
let available = []
|
||||||
|
let active = []
|
||||||
|
|
||||||
|
for ft in ft_list
|
||||||
|
call extend(available, map( self.getNamesOfAvailableCheckers(ft), 'ft . "/" . v:val' ))
|
||||||
|
call extend(active, map( self.getCheckersAvailable(ft, []), 'ft . "/" . v:val.getName()' ))
|
||||||
|
endfor
|
||||||
|
else
|
||||||
|
let ft = ft_list[0]
|
||||||
|
let available = self.getNamesOfAvailableCheckers(ft)
|
||||||
|
let active = map(self.getCheckersAvailable(ft, []), 'v:val.getName()')
|
||||||
|
endif
|
||||||
|
|
||||||
|
let cnt = len(available)
|
||||||
|
let plural = cnt != 1 ? 's' : ''
|
||||||
|
let cklist = cnt ? join(sort(available)) : '-'
|
||||||
|
echomsg 'Available checker' . plural . ': ' . cklist
|
||||||
|
|
||||||
|
let cnt = len(active)
|
||||||
|
let plural = cnt != 1 ? 's' : ''
|
||||||
|
let cklist = cnt ? join(active) : '-'
|
||||||
|
echomsg 'Currently enabled checker' . plural . ': ' . cklist
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private methods {{{1
|
||||||
|
|
||||||
|
function! g:SyntasticRegistry._registerChecker(checker) abort " {{{2
|
||||||
|
let ft = a:checker.getFiletype()
|
||||||
|
if !has_key(self._checkerMap, ft)
|
||||||
|
let self._checkerMap[ft] = {}
|
||||||
|
endif
|
||||||
|
|
||||||
|
let name = a:checker.getName()
|
||||||
|
if has_key(self._checkerMap[ft], name)
|
||||||
|
throw 'Syntastic: Duplicate syntax checker name: ' . ft . '/' . name
|
||||||
|
endif
|
||||||
|
|
||||||
|
let self._checkerMap[ft][name] = a:checker
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticRegistry._filterCheckersByName(checkers_map, list) " {{{2
|
||||||
|
return filter( map(copy(a:list), 'get(a:checkers_map, v:val, {})'), '!empty(v:val)' )
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticRegistry._loadCheckersFor(filetype) " {{{2
|
||||||
|
if has_key(self._checkerMap, a:filetype)
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
execute "runtime! syntax_checkers/" . a:filetype . "/*.vim"
|
||||||
|
|
||||||
|
if !has_key(self._checkerMap, a:filetype)
|
||||||
|
let self._checkerMap[a:filetype] = {}
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Check for obsolete variable g:syntastic_<filetype>_checker
|
||||||
|
function! g:SyntasticRegistry._checkDeprecation(filetype) " {{{2
|
||||||
|
if exists('g:syntastic_' . a:filetype . '_checker') && !exists('g:syntastic_' . a:filetype . '_checkers')
|
||||||
|
let g:syntastic_{a:filetype}_checkers = [g:syntastic_{a:filetype}_checker]
|
||||||
|
call syntastic#log#oneTimeWarn('variable g:syntastic_' . a:filetype . '_checker is deprecated')
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private functions {{{1
|
||||||
|
|
||||||
|
"resolve filetype aliases, and replace - with _ otherwise we cant name
|
||||||
|
"syntax checker functions legally for filetypes like "gentoo-metadata"
|
||||||
|
function! s:_normaliseFiletype(ftalias) " {{{2
|
||||||
|
let ft = get(s:defaultFiletypeMap, a:ftalias, a:ftalias)
|
||||||
|
let ft = get(g:syntastic_filetype_map, ft, ft)
|
||||||
|
let ft = substitute(ft, '\m-', '_', 'g')
|
||||||
|
return ft
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
138
sources_non_forked/syntastic/plugin/syntastic/signs.vim
Normal file
138
sources_non_forked/syntastic/plugin/syntastic/signs.vim
Normal file
|
@ -0,0 +1,138 @@
|
||||||
|
if exists("g:loaded_syntastic_notifier_signs") || !exists("g:loaded_syntastic_plugin")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_notifier_signs = 1
|
||||||
|
|
||||||
|
" Initialisation {{{1
|
||||||
|
|
||||||
|
" start counting sign ids at 5000, start here to hopefully avoid conflicting
|
||||||
|
" with any other code that places signs (not sure if this precaution is
|
||||||
|
" actually needed)
|
||||||
|
let s:first_sign_id = 5000
|
||||||
|
let s:next_sign_id = s:first_sign_id
|
||||||
|
|
||||||
|
let g:SyntasticSignsNotifier = {}
|
||||||
|
|
||||||
|
let s:setup_done = 0
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Public methods {{{1
|
||||||
|
|
||||||
|
function! g:SyntasticSignsNotifier.New() " {{{2
|
||||||
|
let newObj = copy(self)
|
||||||
|
|
||||||
|
if !s:setup_done
|
||||||
|
call self._setup()
|
||||||
|
let s:setup_done = 1
|
||||||
|
lockvar s:setup_done
|
||||||
|
endif
|
||||||
|
|
||||||
|
return newObj
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticSignsNotifier.enabled() " {{{2
|
||||||
|
return has('signs') && syntastic#util#var('enable_signs')
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
function! g:SyntasticSignsNotifier.refresh(loclist) " {{{2
|
||||||
|
call syntastic#log#debug(g:SyntasticDebugNotifications, 'signs: refresh')
|
||||||
|
let old_signs = copy(self._bufSignIds())
|
||||||
|
if self.enabled()
|
||||||
|
call self._signErrors(a:loclist)
|
||||||
|
endif
|
||||||
|
call self._removeSigns(old_signs)
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" Private methods {{{1
|
||||||
|
|
||||||
|
" One time setup: define our own sign types and highlighting
|
||||||
|
function! g:SyntasticSignsNotifier._setup() " {{{2
|
||||||
|
if has('signs')
|
||||||
|
if !hlexists('SyntasticErrorSign')
|
||||||
|
highlight link SyntasticErrorSign error
|
||||||
|
endif
|
||||||
|
if !hlexists('SyntasticWarningSign')
|
||||||
|
highlight link SyntasticWarningSign todo
|
||||||
|
endif
|
||||||
|
if !hlexists('SyntasticStyleErrorSign')
|
||||||
|
highlight link SyntasticStyleErrorSign SyntasticErrorSign
|
||||||
|
endif
|
||||||
|
if !hlexists('SyntasticStyleWarningSign')
|
||||||
|
highlight link SyntasticStyleWarningSign SyntasticWarningSign
|
||||||
|
endif
|
||||||
|
if !hlexists('SyntasticStyleErrorLine')
|
||||||
|
highlight link SyntasticStyleErrorLine SyntasticErrorLine
|
||||||
|
endif
|
||||||
|
if !hlexists('SyntasticStyleWarningLine')
|
||||||
|
highlight link SyntasticStyleWarningLine SyntasticWarningLine
|
||||||
|
endif
|
||||||
|
|
||||||
|
" define the signs used to display syntax and style errors/warns
|
||||||
|
exe 'sign define SyntasticError text=' . g:syntastic_error_symbol .
|
||||||
|
\ ' texthl=SyntasticErrorSign linehl=SyntasticErrorLine'
|
||||||
|
exe 'sign define SyntasticWarning text=' . g:syntastic_warning_symbol .
|
||||||
|
\ ' texthl=SyntasticWarningSign linehl=SyntasticWarningLine'
|
||||||
|
exe 'sign define SyntasticStyleError text=' . g:syntastic_style_error_symbol .
|
||||||
|
\ ' texthl=SyntasticStyleErrorSign linehl=SyntasticStyleErrorLine'
|
||||||
|
exe 'sign define SyntasticStyleWarning text=' . g:syntastic_style_warning_symbol .
|
||||||
|
\ ' texthl=SyntasticStyleWarningSign linehl=SyntasticStyleWarningLine'
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Place signs by all syntax errors in the buffer
|
||||||
|
function! g:SyntasticSignsNotifier._signErrors(loclist) " {{{2
|
||||||
|
let loclist = a:loclist
|
||||||
|
if !loclist.isEmpty()
|
||||||
|
|
||||||
|
let buf = bufnr('')
|
||||||
|
if !bufloaded(buf)
|
||||||
|
" signs can be placed only in loaded buffers
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
" errors come first, so that they are not masked by warnings
|
||||||
|
let issues = copy(loclist.errors())
|
||||||
|
call extend(issues, loclist.warnings())
|
||||||
|
call filter(issues, 'v:val["bufnr"] == buf')
|
||||||
|
let seen = {}
|
||||||
|
|
||||||
|
for i in issues
|
||||||
|
if i['lnum'] > 0 && !has_key(seen, i['lnum'])
|
||||||
|
let seen[i['lnum']] = 1
|
||||||
|
|
||||||
|
let sign_severity = i['type'] ==? 'W' ? 'Warning' : 'Error'
|
||||||
|
let sign_subtype = get(i, 'subtype', '')
|
||||||
|
let sign_type = 'Syntastic' . sign_subtype . sign_severity
|
||||||
|
|
||||||
|
execute "sign place " . s:next_sign_id . " line=" . i['lnum'] . " name=" . sign_type . " buffer=" . i['bufnr']
|
||||||
|
call add(self._bufSignIds(), s:next_sign_id)
|
||||||
|
let s:next_sign_id += 1
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Remove the signs with the given ids from this buffer
|
||||||
|
function! g:SyntasticSignsNotifier._removeSigns(ids) " {{{2
|
||||||
|
if has('signs')
|
||||||
|
for s in reverse(copy(a:ids))
|
||||||
|
execute "sign unplace " . s
|
||||||
|
call remove(self._bufSignIds(), index(self._bufSignIds(), s))
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" Get all the ids of the SyntaxError signs in the buffer
|
||||||
|
function! g:SyntasticSignsNotifier._bufSignIds() " {{{2
|
||||||
|
if !exists("b:syntastic_sign_ids")
|
||||||
|
let b:syntastic_sign_ids = []
|
||||||
|
endif
|
||||||
|
return b:syntastic_sign_ids
|
||||||
|
endfunction " }}}2
|
||||||
|
|
||||||
|
" }}}1
|
||||||
|
|
||||||
|
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -0,0 +1,67 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: mxmlc.vim
|
||||||
|
"Description: ActionScript syntax checker - using mxmlc
|
||||||
|
"Maintainer: Andy Earnshaw <andyearnshaw@gmail.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_actionscript_mxmlc_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_actionscript_mxmlc_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_actionscript_mxmlc_GetHighlightRegex(item)
|
||||||
|
let term = ''
|
||||||
|
|
||||||
|
if match(a:item['text'], '\mvariable ''') > -1
|
||||||
|
let term = matchstr(a:item['text'], '\m''\zs[^'']\+\ze''')
|
||||||
|
|
||||||
|
elseif match(a:item['text'], 'expected a definition keyword') > -1
|
||||||
|
let term = matchstr(a:item['text'], '\mnot \zs[^.]\+\ze\.')
|
||||||
|
|
||||||
|
elseif match(a:item['text'], '\mundefined \%(property\|method\)') > -1
|
||||||
|
let term = matchstr(a:item['text'], '\mundefined \%(property\|method\) \zs[^. ]\+\ze')
|
||||||
|
|
||||||
|
elseif match(a:item['text'], 'could not be found') > -1
|
||||||
|
let term = matchstr(a:item['text'], '\m \zs\S\+\ze could not be found')
|
||||||
|
|
||||||
|
elseif match(a:item['text'], 'Type was not found') > -1
|
||||||
|
let term = matchstr(a:item['text'], '\m: \zs[^.]\+\zs\.')
|
||||||
|
|
||||||
|
endif
|
||||||
|
|
||||||
|
return term != '' ? '\V\<' . escape(term, '\') . '\>' : ''
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_actionscript_mxmlc_GetLocList() dict
|
||||||
|
call syntastic#log#deprecationWarn('actionscript_mxmlc_conf', 'actionscript_mxmlc_args',
|
||||||
|
\ "'-load-config+=' . syntastic#util#shexpand(OLD_VAR)")
|
||||||
|
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '-output=' . syntastic#util#DevNull() })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%f(%l): col: %c %trror: %m,' .
|
||||||
|
\ '%f(%l): col: %c %tarning: %m,' .
|
||||||
|
\ '%f: %trror: %m,' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'actionscript',
|
||||||
|
\ 'name': 'mxmlc'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
47
sources_non_forked/syntastic/syntax_checkers/ada/gcc.vim
Normal file
47
sources_non_forked/syntastic/syntax_checkers/ada/gcc.vim
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: ada.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Alfredo Di Napoli <alfredo.dinapoli@gmail.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_ada_gcc_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_ada_gcc_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_ada_compiler_options')
|
||||||
|
let g:syntastic_ada_compiler_options = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_ada_gcc_IsAvailable() dict
|
||||||
|
if !exists('g:syntastic_ada_compiler')
|
||||||
|
let g:syntastic_ada_compiler = self.getExec()
|
||||||
|
endif
|
||||||
|
return executable(expand(g:syntastic_ada_compiler))
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_ada_gcc_GetLocList() dict
|
||||||
|
return syntastic#c#GetLocList('ada', 'gcc', {
|
||||||
|
\ 'errorformat':
|
||||||
|
\ '%-G%f:%s:,' .
|
||||||
|
\ '%f:%l:%c: %m,' .
|
||||||
|
\ '%f:%l: %m',
|
||||||
|
\ 'main_flags': '-c -x ada -fsyntax-only',
|
||||||
|
\ 'header_flags': '-x ada',
|
||||||
|
\ 'header_names': '\.ads$' })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'ada',
|
||||||
|
\ 'name': 'gcc' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,49 @@
|
||||||
|
"==============================================================================
|
||||||
|
" FileName: applescript.vim
|
||||||
|
" Desc: Syntax checking plugin for syntastic.vim
|
||||||
|
" Author: Zhao Cai
|
||||||
|
" Email: caizhaoff@gmail.com
|
||||||
|
" Version: 0.2.1
|
||||||
|
" Date Created: Thu 09 Sep 2011 10:30:09 AM EST
|
||||||
|
" Last Modified: Fri 09 Dec 2011 01:10:24 PM EST
|
||||||
|
"
|
||||||
|
" History: 0.1.0 - working, but it will run the script everytime to check
|
||||||
|
" syntax. Should use osacompile but strangely it does not give
|
||||||
|
" errors.
|
||||||
|
"
|
||||||
|
" 0.2.0 - switch to osacompile, it gives less errors compared
|
||||||
|
" with osascript.
|
||||||
|
"
|
||||||
|
" 0.2.1 - remove g:syntastic_applescript_tempfile. use
|
||||||
|
" tempname() instead.
|
||||||
|
"
|
||||||
|
" License: This program is free software. It comes without any
|
||||||
|
" warranty, to the extent permitted by applicable law. You can
|
||||||
|
" redistribute it and/or modify it under the terms of the Do What The
|
||||||
|
" Fuck You Want To Public License, Version 2, as published by Sam
|
||||||
|
" Hocevar. See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_applescript_osacompile_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_applescript_osacompile_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_applescript_osacompile_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '-o ' . tempname() . '.scpt' })
|
||||||
|
let errorformat = '%f:%l:%m'
|
||||||
|
return SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'applescript',
|
||||||
|
\ 'name': 'osacompile' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,26 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: avrgcc.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Karel <karelishere at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_arduino_avrgcc_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_arduino_avrgcc_checker = 1
|
||||||
|
|
||||||
|
runtime! syntax_checkers/c/*.vim
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'arduino',
|
||||||
|
\ 'name': 'avrgcc',
|
||||||
|
\ 'exec': 'avr-gcc',
|
||||||
|
\ 'redirect': 'c/avrgcc'})
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,47 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: asciidoc.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: LCD 47 <lcd047 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_asciidoc_asciidoc_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_asciidoc_asciidoc_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_asciidoc_asciidoc_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': syntastic#c#NullOutput() })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%Easciidoc: %tRROR: %f: line %l: %m,' .
|
||||||
|
\ '%Easciidoc: %tRROR: %f: %m,' .
|
||||||
|
\ '%Easciidoc: FAILED: %f: line %l: %m,' .
|
||||||
|
\ '%Easciidoc: FAILED: %f: %m,' .
|
||||||
|
\ '%Wasciidoc: %tARNING: %f: line %l: %m,' .
|
||||||
|
\ '%Wasciidoc: %tARNING: %f: %m,' .
|
||||||
|
\ '%Wasciidoc: DEPRECATED: %f: line %l: %m,' .
|
||||||
|
\ '%Wasciidoc: DEPRECATED: %f: %m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'returns': [0, 1] })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'asciidoc',
|
||||||
|
\ 'name': 'asciidoc'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
54
sources_non_forked/syntastic/syntax_checkers/asm/gcc.vim
Normal file
54
sources_non_forked/syntastic/syntax_checkers/asm/gcc.vim
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: gcc.vim
|
||||||
|
"Description: Syntax checking for at&t and intel assembly files with gcc
|
||||||
|
"Maintainer: Josh Rahm <joshuarahm@gmail.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_asm_gcc_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_asm_gcc_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_asm_compiler_options')
|
||||||
|
let g:syntastic_asm_compiler_options = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_asm_gcc_IsAvailable() dict
|
||||||
|
if !exists('g:syntastic_asm_compiler')
|
||||||
|
let g:syntastic_asm_compiler = self.getExec()
|
||||||
|
endif
|
||||||
|
return executable(expand(g:syntastic_asm_compiler))
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_asm_gcc_GetLocList() dict
|
||||||
|
return syntastic#c#GetLocList('asm', 'gcc', {
|
||||||
|
\ 'errorformat':
|
||||||
|
\ '%-G%f:%s:,' .
|
||||||
|
\ '%f:%l:%c: %trror: %m,' .
|
||||||
|
\ '%f:%l:%c: %tarning: %m,' .
|
||||||
|
\ '%f:%l: %m',
|
||||||
|
\ 'main_flags': '-x assembler -fsyntax-only -masm=' . s:GetDialect() })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:GetDialect()
|
||||||
|
return exists('g:syntastic_asm_dialect') ? g:syntastic_asm_dialect :
|
||||||
|
\ expand('%:e') ==? 'asm' ? 'intel' : 'att'
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'asm',
|
||||||
|
\ 'name': 'gcc' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,35 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: bemhtmllint.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Sergej Tatarincev <s.tatarincev at yandex.ua>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_bemhtml_bemhtmllint_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
|
||||||
|
let g:loaded_syntastic_bemhtml_bemhtmllint_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function SyntaxCheckers_bemhtml_bemhtmllint_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({})
|
||||||
|
let errorformat = '%f:%l:%c: %m'
|
||||||
|
return SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'bemhtml',
|
||||||
|
\ 'name': 'bemhtmllint',
|
||||||
|
\ 'exec': 'bemhtml-lint' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
45
sources_non_forked/syntastic/syntax_checkers/bro/bro.vim
Normal file
45
sources_non_forked/syntastic/syntax_checkers/bro/bro.vim
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: bro.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Justin Azoff <justin.azoff@gmail.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_bro_bro_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_bro_bro_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_bro_bro_IsAvailable() dict
|
||||||
|
return system(self.getExecEscaped() . ' --help') =~# '--parse-only'
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_bro_bro_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_before': '--parse-only' })
|
||||||
|
|
||||||
|
"example: error in ./foo.bro, line 3: unknown identifier banana, at or "near "banana"
|
||||||
|
let errorformat =
|
||||||
|
\ '%trror in %f\, line %l: %m,' .
|
||||||
|
\ '%tarning in %f\, line %l: %m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'bro',
|
||||||
|
\ 'name': 'bro'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
57
sources_non_forked/syntastic/syntax_checkers/c/avrgcc.vim
Normal file
57
sources_non_forked/syntastic/syntax_checkers/c/avrgcc.vim
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: avrgcc.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Karel <karelishere at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_c_avrgcc_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_c_avrgcc_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_avrgcc_config_file')
|
||||||
|
let g:syntastic_avrgcc_config_file = '.syntastic_avrgcc_config'
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_c_avrgcc_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'args_before': syntastic#c#ReadConfig(g:syntastic_avrgcc_config_file),
|
||||||
|
\ 'args_after': '-x c -fsyntax-only' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%-G%f:%s:,' .
|
||||||
|
\ '%-G%f:%l: %#error: %#(Each undeclared identifier is reported only%.%#,' .
|
||||||
|
\ '%-G%f:%l: %#error: %#for each function it appears%.%#,' .
|
||||||
|
\ '%-GIn file included%.%#,' .
|
||||||
|
\ '%-G %#from %f:%l\,,' .
|
||||||
|
\ '%f:%l:%c: %trror: %m,' .
|
||||||
|
\ '%f:%l:%c: %tarning: %m,' .
|
||||||
|
\ '%f:%l:%c: %m,' .
|
||||||
|
\ '%f:%l: %trror: %m,' .
|
||||||
|
\ '%f:%l: %tarning: %m,'.
|
||||||
|
\ '%f:%l: %m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'postprocess': ['compressWhitespace'] })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'c',
|
||||||
|
\ 'name': 'avrgcc',
|
||||||
|
\ 'exec': 'avr-gcc'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,58 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: checkpatch.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim using checkpatch.pl
|
||||||
|
"Maintainer: Daniel Walker <dwalker at fifo99 dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_c_checkpatch_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_c_checkpatch_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_c_checkpatch_IsAvailable() dict
|
||||||
|
call syntastic#log#deprecationWarn('c_checker_checkpatch_location', 'c_checkpatch_exe')
|
||||||
|
|
||||||
|
if !exists('g:syntastic_c_checkpatch_exe') && !executable(self.getExec())
|
||||||
|
if executable('checkpatch')
|
||||||
|
let g:syntastic_c_checkpatch_exe = 'checkpatch'
|
||||||
|
elseif executable('./scripts/checkpatch.pl')
|
||||||
|
let g:syntastic_c_checkpatch_exe = fnamemodify('./scripts/checkpatch.pl', ':p')
|
||||||
|
elseif executable('./scripts/checkpatch')
|
||||||
|
let g:syntastic_c_checkpatch_exe = fnamemodify('./scripts/checkpatch', ':p')
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
return executable(self.getExec())
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_c_checkpatch_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '--no-summary --no-tree --terse --file' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%f:%l: %tARNING: %m,' .
|
||||||
|
\ '%f:%l: %tRROR: %m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'returns': [0, 1],
|
||||||
|
\ 'subtype': 'Style' })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'c',
|
||||||
|
\ 'name': 'checkpatch',
|
||||||
|
\ 'exec': 'checkpatch.pl'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
69
sources_non_forked/syntastic/syntax_checkers/c/cppcheck.vim
Normal file
69
sources_non_forked/syntastic/syntax_checkers/c/cppcheck.vim
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: cppcheck.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim using cppcheck.pl
|
||||||
|
"Maintainer: LCD 47 <lcd047 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" The setting 'g:syntastic_cppcheck_config_file' allows you to define a file
|
||||||
|
" that contains additional compiler arguments like include directories or
|
||||||
|
" CFLAGS. The file is expected to contain one option per line. If none is
|
||||||
|
" given the filename defaults to '.syntastic_cppcheck_config':
|
||||||
|
"
|
||||||
|
" let g:syntastic_cppcheck_config_file = '.config'
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_c_cppcheck_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_c_cppcheck_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_cppcheck_config_file')
|
||||||
|
let g:syntastic_cppcheck_config_file = '.syntastic_cppcheck_config'
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_c_cppcheck_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'args': syntastic#c#ReadConfig(g:syntastic_cppcheck_config_file),
|
||||||
|
\ 'args_after': '-q --enable=style' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '[%f:%l]: (%trror) %m,' .
|
||||||
|
\ '[%f:%l]: (%tarning) %m,' .
|
||||||
|
\ '[%f:%l]: (%ttyle) %m,' .
|
||||||
|
\ '[%f:%l]: (%terformance) %m,' .
|
||||||
|
\ '[%f:%l]: (%tortability) %m,' .
|
||||||
|
\ '[%f:%l]: (%tnformation) %m,' .
|
||||||
|
\ '[%f:%l]: (%tnconclusive) %m,' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
let loclist = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'preprocess': 'cppcheck',
|
||||||
|
\ 'returns': [0] })
|
||||||
|
|
||||||
|
for e in loclist
|
||||||
|
if e['type'] =~? '\m^[SPI]'
|
||||||
|
let e['type'] = 'w'
|
||||||
|
let e['subtype'] = 'Style'
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return loclist
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'c',
|
||||||
|
\ 'name': 'cppcheck'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
58
sources_non_forked/syntastic/syntax_checkers/c/gcc.vim
Normal file
58
sources_non_forked/syntastic/syntax_checkers/c/gcc.vim
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: c.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Gregor Uhlenheuer <kongo2002 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_c_gcc_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_c_gcc_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_c_compiler_options')
|
||||||
|
let g:syntastic_c_compiler_options = '-std=gnu99'
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_c_gcc_IsAvailable() dict
|
||||||
|
if !exists('g:syntastic_c_compiler')
|
||||||
|
let g:syntastic_c_compiler = executable(self.getExec()) ? self.getExec() : 'clang'
|
||||||
|
endif
|
||||||
|
return executable(expand(g:syntastic_c_compiler))
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_c_gcc_GetLocList() dict
|
||||||
|
return syntastic#c#GetLocList('c', 'gcc', {
|
||||||
|
\ 'errorformat':
|
||||||
|
\ '%-G%f:%s:,' .
|
||||||
|
\ '%-G%f:%l: %#error: %#(Each undeclared identifier is reported only%.%#,' .
|
||||||
|
\ '%-G%f:%l: %#error: %#for each function it appears%.%#,' .
|
||||||
|
\ '%-GIn file included%.%#,' .
|
||||||
|
\ '%-G %#from %f:%l\,,' .
|
||||||
|
\ '%f:%l:%c: %trror: %m,' .
|
||||||
|
\ '%f:%l:%c: %tarning: %m,' .
|
||||||
|
\ '%f:%l:%c: %m,' .
|
||||||
|
\ '%f:%l: %trror: %m,' .
|
||||||
|
\ '%f:%l: %tarning: %m,'.
|
||||||
|
\ '%f:%l: %m',
|
||||||
|
\ 'main_flags': '-x c -fsyntax-only',
|
||||||
|
\ 'header_flags': '-x c',
|
||||||
|
\ 'header_names': '\m\.h$' })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'c',
|
||||||
|
\ 'name': 'gcc' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
61
sources_non_forked/syntastic/syntax_checkers/c/make.vim
Normal file
61
sources_non_forked/syntastic/syntax_checkers/c/make.vim
Normal file
|
@ -0,0 +1,61 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: make.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Gregor Uhlenheuer <kongo2002 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_c_make_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_c_make_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_c_make_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args': '-sk', 'fname': '' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%-G%f:%s:,' .
|
||||||
|
\ '%-G%f:%l: %#error: %#(Each undeclared identifier is reported only%.%#,' .
|
||||||
|
\ '%-G%f:%l: %#error: %#for each function it appears%.%#,' .
|
||||||
|
\ '%-GIn file included%.%#,' .
|
||||||
|
\ '%-G %#from %f:%l\,,' .
|
||||||
|
\ '%f:%l:%c: %trror: %m,' .
|
||||||
|
\ '%f:%l:%c: %tarning: %m,' .
|
||||||
|
\ '%f:%l:%c: %m,' .
|
||||||
|
\ '%f:%l: %trror: %m,' .
|
||||||
|
\ '%f:%l: %tarning: %m,'.
|
||||||
|
\ '%f:%l: %m'
|
||||||
|
|
||||||
|
if exists('g:syntastic_c_errorformat')
|
||||||
|
let errorformat = g:syntastic_c_errorformat
|
||||||
|
endif
|
||||||
|
|
||||||
|
" process makeprg
|
||||||
|
let errors = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
|
||||||
|
" filter the processed errors if desired
|
||||||
|
if exists('g:syntastic_c_remove_include_errors') && g:syntastic_c_remove_include_errors != 0
|
||||||
|
return filter(errors, 'has_key(v:val, "bufnr") && v:val["bufnr"] == ' . bufnr(''))
|
||||||
|
else
|
||||||
|
return errors
|
||||||
|
endif
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'c',
|
||||||
|
\ 'name': 'make'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
63
sources_non_forked/syntastic/syntax_checkers/c/oclint.vim
Normal file
63
sources_non_forked/syntastic/syntax_checkers/c/oclint.vim
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: oclint.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: "UnCO" Lin <undercooled aT lavabit com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" The setting 'g:syntastic_oclint_config_file' allows you to define a file
|
||||||
|
" that contains additional compiler arguments like include directories or
|
||||||
|
" CFLAGS. The file is expected to contain one option per line. If none is
|
||||||
|
" given the filename defaults to '.syntastic_oclint_config':
|
||||||
|
"
|
||||||
|
" let g:syntastic_oclint_config_file = '.config'
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_c_oclint_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_c_oclint_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_oclint_config_file')
|
||||||
|
let g:syntastic_oclint_config_file = '.syntastic_oclint_config'
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_c_oclint_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'post_args_before': '-- -c ' . syntastic#c#ReadConfig(g:syntastic_oclint_config_file) })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%E%f:%l:%c: %m P1 ,' .
|
||||||
|
\ '%E%f:%l:%c: %m P2 ,' .
|
||||||
|
\ '%W%f:%l:%c: %m P3 ,' .
|
||||||
|
\ '%E%f:%l:%c: fatal error: %m,' .
|
||||||
|
\ '%E%f:%l:%c: error: %m,' .
|
||||||
|
\ '%W%f:%l:%c: warning: %m,' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
let loclist = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'subtype': 'Style',
|
||||||
|
\ 'postprocess': ['compressWhitespace'],
|
||||||
|
\ 'returns': [0, 3, 5] })
|
||||||
|
|
||||||
|
call self.setWantSort(1)
|
||||||
|
|
||||||
|
return loclist
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'c',
|
||||||
|
\ 'name': 'oclint'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
53
sources_non_forked/syntastic/syntax_checkers/c/sparse.vim
Normal file
53
sources_non_forked/syntastic/syntax_checkers/c/sparse.vim
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: sparse.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim using sparse.pl
|
||||||
|
"Maintainer: Daniel Walker <dwalker at fifo99 dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" The setting 'g:syntastic_sparse_config_file' allows you to define a file
|
||||||
|
" that contains additional compiler arguments like include directories or
|
||||||
|
" CFLAGS. The file is expected to contain one option per line. If none is
|
||||||
|
" given the filename defaults to '.syntastic_sparse_config':
|
||||||
|
"
|
||||||
|
" let g:syntastic_sparse_config_file = '.config'
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_c_sparse_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_c_sparse_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_sparse_config_file')
|
||||||
|
let g:syntastic_sparse_config_file = '.syntastic_sparse_config'
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_c_sparse_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'args': syntastic#c#ReadConfig(g:syntastic_sparse_config_file),
|
||||||
|
\ 'args_after': '-ftabstop=' . &ts })
|
||||||
|
|
||||||
|
let errorformat = '%f:%l:%v: %trror: %m,%f:%l:%v: %tarning: %m,'
|
||||||
|
|
||||||
|
let loclist = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr("")},
|
||||||
|
\ 'returns': [0] })
|
||||||
|
return loclist
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'c',
|
||||||
|
\ 'name': 'sparse'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
62
sources_non_forked/syntastic/syntax_checkers/c/splint.vim
Normal file
62
sources_non_forked/syntastic/syntax_checkers/c/splint.vim
Normal file
|
@ -0,0 +1,62 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: splint.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: LCD 47 <lcd047 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" The setting 'g:syntastic_splint_config_file' allows you to define a file
|
||||||
|
" that contains additional compiler arguments like include directories or
|
||||||
|
" CFLAGS. The file is expected to contain one option per line. If none is
|
||||||
|
" given the filename defaults to '.syntastic_splint_config':
|
||||||
|
"
|
||||||
|
" let g:syntastic_splint_config_file = '.config'
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_c_splint_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_c_splint_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_splint_config_file')
|
||||||
|
let g:syntastic_splint_config_file = '.syntastic_splint_config'
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_c_splint_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'args': syntastic#c#ReadConfig(g:syntastic_splint_config_file),
|
||||||
|
\ 'args_after': '-showfunc -hints +quiet' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%-G%f:%l:%v: %[%#]%[%#]%[%#] Internal Bug %.%#,' .
|
||||||
|
\ '%-G%f(%l\,%v): %[%#]%[%#]%[%#] Internal Bug %.%#,' .
|
||||||
|
\ '%W%f:%l:%v: %m,' .
|
||||||
|
\ '%W%f(%l\,%v): %m,' .
|
||||||
|
\ '%W%f:%l: %m,' .
|
||||||
|
\ '%W%f(%l): %m,' .
|
||||||
|
\ '%-C %\+In file included from %.%#,' .
|
||||||
|
\ '%-C %\+from %.%#,' .
|
||||||
|
\ '%+C %.%#'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'subtype': 'Style',
|
||||||
|
\ 'postprocess': ['compressWhitespace'],
|
||||||
|
\ 'defaults': {'type': 'W'} })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'c',
|
||||||
|
\ 'name': 'splint'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
55
sources_non_forked/syntastic/syntax_checkers/cabal/cabal.vim
Normal file
55
sources_non_forked/syntastic/syntax_checkers/cabal/cabal.vim
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: cabal.vim
|
||||||
|
"Description: Haskell package description (.cabal file) linting and syntax
|
||||||
|
" validation via 'cabal check'
|
||||||
|
"Maintainer: Ian D. Bollinger <ian.bollinger@gmail.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_cabal_cabal_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_cabal_cabal_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_cabal_cabal_GetHighlightRegex(item)
|
||||||
|
let field = matchstr(a:item['text'], "\\vParse of field '\\zs[^']+")
|
||||||
|
if field != ''
|
||||||
|
return '\v\c^\s*' . field . '\s*:\s*\zs.*$'
|
||||||
|
endif
|
||||||
|
let field = matchstr(a:item['text'], "\\v(^|\\s)'\\zs[^']+\\ze'")
|
||||||
|
if field != ''
|
||||||
|
return '\V\c\<' . escape(field, '\') . '\>'
|
||||||
|
endif
|
||||||
|
return ''
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_cabal_cabal_GetLocList() dict
|
||||||
|
let makeprg = self.getExecEscaped() . ' check'
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%Ecabal: %f:%l: %m,' .
|
||||||
|
\ '%W* %m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'cwd': expand('%:p:h'),
|
||||||
|
\ 'preprocess': 'cabal',
|
||||||
|
\ 'defaults': {'bufnr': bufnr('')} })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'cabal',
|
||||||
|
\ 'name': 'cabal'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,39 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: foodcritic.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Doug Ireton <dougireton@gmail.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_chef_foodcritic_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_chef_foodcritic_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_chef_foodcritic_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({})
|
||||||
|
|
||||||
|
" FC023: Prefer conditional attributes: ./recipes/config.rb:49
|
||||||
|
let errorformat = 'FC%n: %m: %f:%l'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'chef',
|
||||||
|
\ 'name': 'foodcritic'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
43
sources_non_forked/syntastic/syntax_checkers/co/coco.vim
Normal file
43
sources_non_forked/syntastic/syntax_checkers/co/coco.vim
Normal file
|
@ -0,0 +1,43 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: co.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Andrew Kelley <superjoe30@gmail.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_co_coco_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_co_coco_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_co_coco_GetLocList() dict
|
||||||
|
let tmpdir = $TMPDIR != '' ? $TMPDIR : $TMP != '' ? $TMP : '/tmp'
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '-c -o ' . tmpdir })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%EFailed at: %f,' .
|
||||||
|
\ '%ZSyntax%trror: %m on line %l,'.
|
||||||
|
\ '%EFailed at: %f,'.
|
||||||
|
\ '%Z%trror: Parse error on line %l: %m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'co',
|
||||||
|
\ 'name': 'coco'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
46
sources_non_forked/syntastic/syntax_checkers/cobol/cobc.vim
Normal file
46
sources_non_forked/syntastic/syntax_checkers/cobol/cobc.vim
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: cobc.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: LCD 47 <lcd047 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_cobol_cobc_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_cobol_cobc_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_cobol_compiler_options')
|
||||||
|
let g:syntastic_cobol_compiler_options = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_cobol_cobc_IsAvailable() dict
|
||||||
|
if !exists('g:syntastic_cobol_compiler')
|
||||||
|
let g:syntastic_cobol_compiler = self.getExec()
|
||||||
|
endif
|
||||||
|
return executable(expand(g:syntastic_cobol_compiler))
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_cobol_cobc_GetLocList() dict
|
||||||
|
return syntastic#c#GetLocList('cobol', 'cobc', {
|
||||||
|
\ 'errorformat': '%f:%l: %trror: %m',
|
||||||
|
\ 'main_flags': '-fsyntax-only' })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'cobol',
|
||||||
|
\ 'name': 'cobc' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,56 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: coffee.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Lincoln Stoll <l@lds.li>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" Note: this script requires CoffeeScript version 1.6.2 or newer.
|
||||||
|
"
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_coffee_coffee_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_coffee_coffee_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_coffee_coffee_IsAvailable() dict
|
||||||
|
return executable(self.getExec()) &&
|
||||||
|
\ syntastic#util#versionIsAtLeast(syntastic#util#getVersion(
|
||||||
|
\ self.getExecEscaped() . ' --version 2>' . syntastic#util#DevNull()), [1,6,2])
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_coffee_coffee_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '-cp' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%E%f:%l:%c: %trror: %m,' .
|
||||||
|
\ 'Syntax%trror: In %f\, %m on line %l,' .
|
||||||
|
\ '%EError: In %f\, Parse error on line %l: %m,' .
|
||||||
|
\ '%EError: In %f\, %m on line %l,' .
|
||||||
|
\ '%W%f(%l): lint warning: %m,' .
|
||||||
|
\ '%W%f(%l): warning: %m,' .
|
||||||
|
\ '%E%f(%l): SyntaxError: %m,' .
|
||||||
|
\ '%-Z%p^,' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'coffee',
|
||||||
|
\ 'name': 'coffee'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,48 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: coffeelint.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Lincoln Stoll <l@lds.li>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_coffee_coffeelint_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_coffee_coffeelint_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_coffee_coffeelint_GetLocList() dict
|
||||||
|
if !exists('s:coffeelint_new')
|
||||||
|
let s:coffeelint_new = syntastic#util#versionIsAtLeast(syntastic#util#getVersion(
|
||||||
|
\ self.getExecEscaped() . ' --version'), [1, 4])
|
||||||
|
endif
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': (s:coffeelint_new ? '--reporter csv' : '--csv') })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%f\,%l\,%\d%#\,%trror\,%m,' .
|
||||||
|
\ '%f\,%l\,%trror\,%m,' .
|
||||||
|
\ '%f\,%l\,%\d%#\,%tarn\,%m,' .
|
||||||
|
\ '%f\,%l\,%tarn\,%m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'subtype': 'Style',
|
||||||
|
\ 'returns': [0, 1] })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'coffee',
|
||||||
|
\ 'name': 'coffeelint'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
40
sources_non_forked/syntastic/syntax_checkers/coq/coqtop.vim
Normal file
40
sources_non_forked/syntastic/syntax_checkers/coq/coqtop.vim
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: coqtop.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Matvey Aksenov <matvey.aksenov at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_coq_coqtop_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_coq_coqtop_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_coq_coqtop_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '-noglob -batch -load-vernac-source' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%AFile \"%f\"\, line %l\, characters %c\-%.%#\:,'.
|
||||||
|
\ '%C%m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'coq',
|
||||||
|
\ 'name': 'coqtop'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,31 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: cppcheck.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim using cppcheck.pl
|
||||||
|
"Maintainer: LCD 47 <lcd047 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" The setting 'g:syntastic_cppcheck_config_file' allows you to define a file
|
||||||
|
" that contains additional compiler arguments like include directories or
|
||||||
|
" CFLAGS. The file is expected to contain one option per line. If none is
|
||||||
|
" given the filename defaults to '.syntastic_cppcheck_config':
|
||||||
|
"
|
||||||
|
" let g:syntastic_cppcheck_config_file = '.config'
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_cpp_cppcheck_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_cpp_cppcheck_checker = 1
|
||||||
|
|
||||||
|
runtime! syntax_checkers/c/*.vim
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'cpp',
|
||||||
|
\ 'name': 'cppcheck',
|
||||||
|
\ 'redirect': 'c/cppcheck'})
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
64
sources_non_forked/syntastic/syntax_checkers/cpp/cpplint.vim
Normal file
64
sources_non_forked/syntastic/syntax_checkers/cpp/cpplint.vim
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: cpplint.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: LCD 47 <lcd047 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" For details about cpplint see:
|
||||||
|
" https://code.google.com/p/google-styleguide/
|
||||||
|
"
|
||||||
|
" Checker options:
|
||||||
|
"
|
||||||
|
" - g:syntastic_cpp_cpplint_thres (integer; default: 5)
|
||||||
|
" error threshold: policy violations with a severity above this
|
||||||
|
" value are highlighted as errors, the others are warnings
|
||||||
|
"
|
||||||
|
" - g:syntastic_cpp_cpplint_args (string; default: '--verbose=3')
|
||||||
|
" command line options to pass to cpplint
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_cpp_cpplint_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_cpp_cpplint_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_cpp_cpplint_thres')
|
||||||
|
let g:syntastic_cpp_cpplint_thres = 5
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_cpp_cpplint_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args': '--verbose=3' })
|
||||||
|
|
||||||
|
let errorformat = '%A%f:%l: %m [%t],%-G%.%#'
|
||||||
|
|
||||||
|
let loclist = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'subtype': 'Style',
|
||||||
|
\ 'returns': [0, 1] })
|
||||||
|
|
||||||
|
" change error types according to the prescribed threshold
|
||||||
|
for e in loclist
|
||||||
|
let e['type'] = e['type'] < g:syntastic_cpp_cpplint_thres ? 'W' : 'E'
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return loclist
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'cpp',
|
||||||
|
\ 'name': 'cpplint',
|
||||||
|
\ 'exec': 'cpplint.py'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
55
sources_non_forked/syntastic/syntax_checkers/cpp/gcc.vim
Normal file
55
sources_non_forked/syntastic/syntax_checkers/cpp/gcc.vim
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: cpp.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Gregor Uhlenheuer <kongo2002 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_cpp_gcc_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_cpp_gcc_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_cpp_compiler_options')
|
||||||
|
let g:syntastic_cpp_compiler_options = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_cpp_gcc_IsAvailable() dict
|
||||||
|
if !exists('g:syntastic_cpp_compiler')
|
||||||
|
let g:syntastic_cpp_compiler = executable(self.getExec()) ? self.getExec() : 'clang++'
|
||||||
|
endif
|
||||||
|
return executable(expand(g:syntastic_cpp_compiler))
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_cpp_gcc_GetLocList() dict
|
||||||
|
return syntastic#c#GetLocList('cpp', 'gcc', {
|
||||||
|
\ 'errorformat':
|
||||||
|
\ '%-G%f:%s:,' .
|
||||||
|
\ '%f:%l:%c: %trror: %m,' .
|
||||||
|
\ '%f:%l:%c: %tarning: %m,' .
|
||||||
|
\ '%f:%l:%c: %m,'.
|
||||||
|
\ '%f:%l: %trror: %m,'.
|
||||||
|
\ '%f:%l: %tarning: %m,'.
|
||||||
|
\ '%f:%l: %m',
|
||||||
|
\ 'main_flags': '-x c++ -fsyntax-only',
|
||||||
|
\ 'header_flags': '-x c++',
|
||||||
|
\ 'header_names': '\m\.\(h\|hpp\|hh\)$' })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'cpp',
|
||||||
|
\ 'name': 'gcc',
|
||||||
|
\ 'exec': 'g++' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
31
sources_non_forked/syntastic/syntax_checkers/cpp/oclint.vim
Normal file
31
sources_non_forked/syntastic/syntax_checkers/cpp/oclint.vim
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: oclint.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: "UnCO" Lin <undercooled aT lavabit com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" The setting 'g:syntastic_oclint_config_file' allows you to define a file
|
||||||
|
" that contains additional compiler arguments like include directories or
|
||||||
|
" CFLAGS. The file is expected to contain one option per line. If none is
|
||||||
|
" given the filename defaults to '.syntastic_oclint_config':
|
||||||
|
"
|
||||||
|
" let g:syntastic_oclint_config_file = '.config'
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_cpp_oclint_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_cpp_oclint_checker = 1
|
||||||
|
|
||||||
|
runtime! syntax_checkers/c/*.vim
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'cpp',
|
||||||
|
\ 'name': 'oclint',
|
||||||
|
\ 'redirect': 'c/oclint'})
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
39
sources_non_forked/syntastic/syntax_checkers/cs/mcs.vim
Normal file
39
sources_non_forked/syntastic/syntax_checkers/cs/mcs.vim
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: cs.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Daniel Walker <dwalker@fifo99.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_cs_mcs_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_cs_mcs_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_cs_mcs_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '--parse' })
|
||||||
|
|
||||||
|
let errorformat = '%f(%l\,%c): %trror %m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr("")} })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'cs',
|
||||||
|
\ 'name': 'mcs'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
52
sources_non_forked/syntastic/syntax_checkers/css/csslint.vim
Normal file
52
sources_non_forked/syntastic/syntax_checkers/css/csslint.vim
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: css.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim using `csslint` CLI tool (http://csslint.net).
|
||||||
|
"Maintainer: Ory Band <oryband at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" Specify additional options to csslint with this option. e.g. to disable
|
||||||
|
" warnings:
|
||||||
|
"
|
||||||
|
" let g:syntastic_csslint_options = '--warnings=none'
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_css_csslint_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_css_csslint_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_css_csslint_GetLocList() dict
|
||||||
|
call syntastic#log#deprecationWarn('csslint_options', 'css_csslint_args')
|
||||||
|
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '--format=compact' })
|
||||||
|
|
||||||
|
" Print CSS Lint's error/warning messages from compact format. Ignores blank lines.
|
||||||
|
let errorformat =
|
||||||
|
\ '%-G,' .
|
||||||
|
\ '%-G%f: lint free!,' .
|
||||||
|
\ '%f: line %l\, col %c\, %trror - %m,' .
|
||||||
|
\ '%f: line %l\, col %c\, %tarning - %m,'.
|
||||||
|
\ '%f: line %l\, col %c\, %m,'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr("")} })
|
||||||
|
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'css',
|
||||||
|
\ 'name': 'csslint'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
29
sources_non_forked/syntastic/syntax_checkers/css/phpcs.vim
Normal file
29
sources_non_forked/syntastic/syntax_checkers/css/phpcs.vim
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: phpcs.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: LCD 47 <lcd047 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" See here for details of phpcs
|
||||||
|
" - phpcs (see http://pear.php.net/package/PHP_CodeSniffer)
|
||||||
|
"
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_css_phpcs_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_css_phpcs_checker = 1
|
||||||
|
|
||||||
|
runtime! syntax_checkers/php/*.vim
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'css',
|
||||||
|
\ 'name': 'phpcs',
|
||||||
|
\ 'redirect': 'php/phpcs'})
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,64 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: prettycss.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: LCD 47 <lcd047 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" For details about PrettyCSS see:
|
||||||
|
"
|
||||||
|
" - http://fidian.github.io/PrettyCSS/
|
||||||
|
" - https://github.com/fidian/PrettyCSS
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_css_prettycss_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_css_prettycss_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_css_prettycss_GetHighlightRegex(item)
|
||||||
|
let term = matchstr(a:item["text"], '\m (\zs[^)]\+\ze)$')
|
||||||
|
if term != ''
|
||||||
|
let term = '\V' . escape(term, '\')
|
||||||
|
endif
|
||||||
|
return term
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_css_prettycss_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({})
|
||||||
|
|
||||||
|
" Print CSS Lint's error/warning messages from compact format. Ignores blank lines.
|
||||||
|
let errorformat =
|
||||||
|
\ '%EError: %m\, line %l\, char %c),' .
|
||||||
|
\ '%WWarning: %m\, line %l\, char %c),' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
let loclist = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr("")} })
|
||||||
|
|
||||||
|
for e in loclist
|
||||||
|
let e["text"] .= ')'
|
||||||
|
endfor
|
||||||
|
|
||||||
|
call self.setWantSort(1)
|
||||||
|
|
||||||
|
return loclist
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'css',
|
||||||
|
\ 'name': 'prettycss'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
26
sources_non_forked/syntastic/syntax_checkers/css/recess.vim
Normal file
26
sources_non_forked/syntastic/syntax_checkers/css/recess.vim
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: recess.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim using `recess`
|
||||||
|
" (http://twitter.github.io/recess/).
|
||||||
|
"Maintainer: Tim Carry <tim at pixelastic dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_css_recess_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_css_recess_checker = 1
|
||||||
|
|
||||||
|
runtime! syntax_checkers/less/*.vim
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'css',
|
||||||
|
\ 'name': 'recess',
|
||||||
|
\ 'redirect': 'less/recess'})
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,42 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: cucumber.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Martin Grenfell <martin.grenfell at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_cucumber_cucumber_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_cucumber_cucumber_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_cucumber_cucumber_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '--dry-run --quiet --strict --format pretty' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%f:%l:%c:%m,' .
|
||||||
|
\ '%W %.%# (%m),' .
|
||||||
|
\ '%-Z%f:%l:%.%#,'.
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'cucumber',
|
||||||
|
\ 'name': 'cucumber'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
78
sources_non_forked/syntastic/syntax_checkers/cuda/nvcc.vim
Normal file
78
sources_non_forked/syntastic/syntax_checkers/cuda/nvcc.vim
Normal file
|
@ -0,0 +1,78 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: cuda.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"
|
||||||
|
"Author: Hannes Schulz <schulz at ais dot uni-bonn dot de>
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
" in order to also check header files add this to your .vimrc:
|
||||||
|
" (this creates an empty .syntastic_dummy.cu file in your source directory)
|
||||||
|
"
|
||||||
|
" let g:syntastic_cuda_check_header = 1
|
||||||
|
|
||||||
|
" By default, nvcc and thus syntastic, defaults to the most basic architecture.
|
||||||
|
" This can produce false errors if the developer intends to compile for newer
|
||||||
|
" hardware and use newer features, eg. double precision numbers. To pass a
|
||||||
|
" specific target arch to nvcc, e.g. add the following to your .vimrc:
|
||||||
|
"
|
||||||
|
" let g:syntastic_cuda_arch = "sm_20"
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_cuda_nvcc_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_cuda_nvcc_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_cuda_nvcc_GetLocList() dict
|
||||||
|
if exists('g:syntastic_cuda_arch')
|
||||||
|
let arch_flag = '-arch=' . g:syntastic_cuda_arch
|
||||||
|
else
|
||||||
|
let arch_flag = ''
|
||||||
|
endif
|
||||||
|
let makeprg =
|
||||||
|
\ self.getExecEscaped() . ' ' . arch_flag .
|
||||||
|
\ ' --cuda -O0 -I . -Xcompiler -fsyntax-only ' .
|
||||||
|
\ syntastic#util#shexpand('%') . ' ' . syntastic#c#NullOutput()
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%*[^"]"%f"%*\D%l: %m,'.
|
||||||
|
\ '"%f"%*\D%l: %m,'.
|
||||||
|
\ '%-G%f:%l: (Each undeclared identifier is reported only once,'.
|
||||||
|
\ '%-G%f:%l: for each function it appears in.),'.
|
||||||
|
\ '%f:%l:%c:%m,'.
|
||||||
|
\ '%f(%l):%m,'.
|
||||||
|
\ '%f:%l:%m,'.
|
||||||
|
\ '"%f"\, line %l%*\D%c%*[^ ] %m,'.
|
||||||
|
\ '%D%*\a[%*\d]: Entering directory `%f'','.
|
||||||
|
\ '%X%*\a[%*\d]: Leaving directory `%f'','.
|
||||||
|
\ '%D%*\a: Entering directory `%f'','.
|
||||||
|
\ '%X%*\a: Leaving directory `%f'','.
|
||||||
|
\ '%DMaking %*\a in %f,'.
|
||||||
|
\ '%f|%l| %m'
|
||||||
|
|
||||||
|
if expand('%') =~? '\m\%(.h\|.hpp\|.cuh\)$'
|
||||||
|
if exists('g:syntastic_cuda_check_header')
|
||||||
|
let makeprg =
|
||||||
|
\ 'echo > .syntastic_dummy.cu ; ' .
|
||||||
|
\ self.getExecEscaped() . ' ' . arch_flag .
|
||||||
|
\ ' --cuda -O0 -I . .syntastic_dummy.cu -Xcompiler -fsyntax-only -include ' .
|
||||||
|
\ syntastic#util#shexpand('%') . ' ' . syntastic#c#NullOutput()
|
||||||
|
else
|
||||||
|
return []
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
return SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'cuda',
|
||||||
|
\ 'name': 'nvcc'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
59
sources_non_forked/syntastic/syntax_checkers/d/dmd.vim
Normal file
59
sources_non_forked/syntastic/syntax_checkers/d/dmd.vim
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: d.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Alfredo Di Napoli <alfredo dot dinapoli at gmail dot com>
|
||||||
|
"License: Based on the original work of Gregor Uhlenheuer and his
|
||||||
|
" cpp.vim checker so credits are dued.
|
||||||
|
" THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
" EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
||||||
|
" OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
" NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
||||||
|
" HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||||
|
" WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
" FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||||
|
" OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_d_dmd_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_d_dmd_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_d_compiler_options')
|
||||||
|
let g:syntastic_d_compiler_options = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_d_dmd_IsAvailable() dict
|
||||||
|
if !exists('g:syntastic_d_compiler')
|
||||||
|
let g:syntastic_d_compiler = self.getExec()
|
||||||
|
endif
|
||||||
|
return executable(expand(g:syntastic_d_compiler))
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_d_dmd_GetLocList() dict
|
||||||
|
if !exists('g:syntastic_d_include_dirs')
|
||||||
|
let g:syntastic_d_include_dirs = filter(glob($HOME . '/.dub/packages/*', 1, 1), 'isdirectory(v:val)')
|
||||||
|
call map(g:syntastic_d_include_dirs, 'isdirectory(v:val . "/source") ? v:val . "/source" : v:val')
|
||||||
|
call add(g:syntastic_d_include_dirs, './source')
|
||||||
|
endif
|
||||||
|
|
||||||
|
return syntastic#c#GetLocList('d', 'dmd', {
|
||||||
|
\ 'errorformat':
|
||||||
|
\ '%-G%f:%s:,%f(%l): %m,' .
|
||||||
|
\ '%f:%l: %m',
|
||||||
|
\ 'main_flags': '-c -of' . syntastic#util#DevNull(),
|
||||||
|
\ 'header_names': '\m\.di$' })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'd',
|
||||||
|
\ 'name': 'dmd' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,76 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: dartanalyzer.vim
|
||||||
|
"Description: Dart syntax checker - using dartanalyzer
|
||||||
|
"Maintainer: Maksim Ryzhikov <rv.maksim at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_dart_dartanalyzer_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_dart_dartanalyzer_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_dart_dartanalyzer_GetHighlightRegex(error)
|
||||||
|
if a:error['len']
|
||||||
|
let lcol = a:error['col'] - 1
|
||||||
|
let rcol = a:error['col'] + a:error['len']
|
||||||
|
let ret = '\%>' . lcol . 'c\%<' . rcol . 'c'
|
||||||
|
else
|
||||||
|
let ret = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
return ret
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_dart_dartanalyzer_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '--machine' })
|
||||||
|
|
||||||
|
" Machine readable format looks like:
|
||||||
|
" SEVERITY|TYPE|ERROR_CODE|FILENAME|LINE_NUMBER|COLUMN|LENGTH|MESSAGE
|
||||||
|
" SEVERITY: (WARNING|ERROR)
|
||||||
|
" TYPE: (RESOLVER|STATIC_TYPE|...)
|
||||||
|
" ERROR_CODE: (NO_SUCH_TYPE|...)
|
||||||
|
" FILENAME: String
|
||||||
|
" LINE_NUMBER: int
|
||||||
|
" COLUMN: int
|
||||||
|
" LENGTH: int
|
||||||
|
" MESSAGE: String
|
||||||
|
|
||||||
|
" We use %n to grab the error length, for the syntax highlighter
|
||||||
|
let commonformat = '|%.%#|%.%#|%f|%l|%c|%n|%m'
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%EERROR' . commonformat . ',' .
|
||||||
|
\ '%WWARNING' . commonformat
|
||||||
|
|
||||||
|
let loclist = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'returns': [0, 1, 2] })
|
||||||
|
|
||||||
|
for e in loclist
|
||||||
|
let e['text'] = substitute(e['text'], '\m\\\([\\|]\)', '\1', 'g')
|
||||||
|
|
||||||
|
" Undo the %n hack
|
||||||
|
let e['len'] = e['nr']
|
||||||
|
call remove(e, 'nr')
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return loclist
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'dart',
|
||||||
|
\ 'name': 'dartanalyzer' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,25 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: docbk.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Martin Grenfell <martin.grenfell at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_docbk_xmllint_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_docbk_xmllint_checker = 1
|
||||||
|
|
||||||
|
runtime! syntax_checkers/xml/*.vim
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'docbk',
|
||||||
|
\ 'name': 'xmllint',
|
||||||
|
\ 'redirect': 'xml/xmllint'})
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,38 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: swiffer.vim
|
||||||
|
"Description: Dust.js syntax checker - using swiffer
|
||||||
|
"Maintainer: Steven Foote <smfoote at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_dustjs_swiffer_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
|
||||||
|
let g:loaded_syntastic_dustjs_swiffer_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_dustjs_swiffer_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({})
|
||||||
|
|
||||||
|
let errorformat = '%E%f - Line %l\, Column %c: %m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'dustjs',
|
||||||
|
\ 'name': 'swiffer'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,56 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: elixir.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Richard Ramsden <rramsden at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_elixir_elixir_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_elixir_elixir_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
" TODO: we should probably split this into separate checkers
|
||||||
|
function! SyntaxCheckers_elixir_elixir_IsAvailable() dict
|
||||||
|
return executable('elixir') && executable('mix')
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_elixir_elixir_GetLocList() dict
|
||||||
|
if !exists('g:syntastic_enable_elixir_checker') || !g:syntastic_enable_elixir_checker
|
||||||
|
call syntastic#log#error('checker elixir/elixir: checks disabled for security reasons; ' .
|
||||||
|
\ 'set g:syntastic_enable_elixir_checker to 1 to override')
|
||||||
|
return []
|
||||||
|
endif
|
||||||
|
|
||||||
|
let make_options = {}
|
||||||
|
let compile_command = 'elixir'
|
||||||
|
let mix_file = syntastic#util#findInParent('mix.exs', expand('%:p:h'))
|
||||||
|
|
||||||
|
if filereadable(mix_file)
|
||||||
|
let compile_command = 'mix compile'
|
||||||
|
let make_options['cwd'] = fnamemodify(mix_file, ':p:h')
|
||||||
|
endif
|
||||||
|
|
||||||
|
let make_options['makeprg'] = self.makeprgBuild({ 'exe': compile_command })
|
||||||
|
|
||||||
|
let make_options['errorformat'] = '** %*[^\ ] %f:%l: %m'
|
||||||
|
|
||||||
|
return SyntasticMake(make_options)
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'elixir',
|
||||||
|
\ 'name': 'elixir'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
61
sources_non_forked/syntastic/syntax_checkers/erlang/erlang_check_file.erl
Executable file
61
sources_non_forked/syntastic/syntax_checkers/erlang/erlang_check_file.erl
Executable file
|
@ -0,0 +1,61 @@
|
||||||
|
#!/usr/bin/env escript
|
||||||
|
-export([main/1]).
|
||||||
|
|
||||||
|
main([FileName]) ->
|
||||||
|
LibDirs = (["ebin", "include", "src", "test"] ++
|
||||||
|
filelib:wildcard("{apps,deps,lib}/*/{ebin,include}")),
|
||||||
|
compile(FileName, LibDirs);
|
||||||
|
|
||||||
|
main([FileName, "-rebar", Path, LibDirs]) ->
|
||||||
|
{ok, L} = file:consult(Path),
|
||||||
|
P = dict:from_list(L),
|
||||||
|
Root = filename:dirname(Path),
|
||||||
|
|
||||||
|
Lib1 = case dict:find(lib_dirs, P) of
|
||||||
|
{ok, X} -> lists:map(fun(Sub) -> Root ++ "/" ++ Sub end, X);
|
||||||
|
_ -> []
|
||||||
|
end,
|
||||||
|
|
||||||
|
Lib2 = case dict:find(sub_dirs, P) of
|
||||||
|
{ok, Y} -> lists:foldl(
|
||||||
|
fun(Sub,Sofar) ->
|
||||||
|
Sofar ++ [
|
||||||
|
Root ++ "/" ++ Sub,
|
||||||
|
Root ++ "/" ++ Sub ++ "/include",
|
||||||
|
Root ++ "/" ++ Sub ++ "/deps",
|
||||||
|
Root ++ "/" ++ Sub ++ "/lib"
|
||||||
|
] end, [], Y);
|
||||||
|
_ -> []
|
||||||
|
end,
|
||||||
|
|
||||||
|
LibDirs1 = LibDirs ++ Lib1 ++ Lib2,
|
||||||
|
%io:format("~p~n", [LibDirs1]),
|
||||||
|
compile(FileName, LibDirs1);
|
||||||
|
|
||||||
|
main([FileName, LibDirs]) ->
|
||||||
|
compile(FileName, LibDirs).
|
||||||
|
|
||||||
|
compile(FileName, LibDirs) ->
|
||||||
|
Root = get_root(filename:dirname(FileName)),
|
||||||
|
ok = code:add_pathsa(LibDirs),
|
||||||
|
compile:file(FileName,
|
||||||
|
[warn_obsolete_guard,
|
||||||
|
warn_unused_import,
|
||||||
|
warn_shadow_vars,
|
||||||
|
warn_export_vars,
|
||||||
|
strong_validation,
|
||||||
|
report] ++
|
||||||
|
[{i, filename:join(Root, I)} || I <- LibDirs]).
|
||||||
|
|
||||||
|
get_root(Dir) ->
|
||||||
|
Path = filename:split(filename:absname(Dir)),
|
||||||
|
filename:join(get_root(lists:reverse(Path), Path)).
|
||||||
|
|
||||||
|
get_root([], Path) ->
|
||||||
|
Path;
|
||||||
|
get_root(["src" | Tail], _Path) ->
|
||||||
|
lists:reverse(Tail);
|
||||||
|
get_root(["test" | Tail], _Path) ->
|
||||||
|
lists:reverse(Tail);
|
||||||
|
get_root([_ | Tail], Path) ->
|
||||||
|
get_root(Tail, Path).
|
|
@ -0,0 +1,61 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: erlang.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Pawel Salata <rockplayer.pl at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_erlang_erlang_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_erlang_erlang_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_erlc_include_path')
|
||||||
|
let g:syntastic_erlc_include_path = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:check_file = syntastic#util#shescape(expand('<sfile>:p:h') . syntastic#util#Slash() . 'erlang_check_file.erl')
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_erlang_escript_GetLocList() dict
|
||||||
|
if expand('%:e') ==# 'hrl'
|
||||||
|
return []
|
||||||
|
endif
|
||||||
|
|
||||||
|
let shebang = syntastic#util#parseShebang()
|
||||||
|
if shebang['exe'] ==# 'escript'
|
||||||
|
let args = '-s'
|
||||||
|
let post_args = ''
|
||||||
|
else
|
||||||
|
let args = s:check_file
|
||||||
|
let post_args = g:syntastic_erlc_include_path
|
||||||
|
endif
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'args_after': args,
|
||||||
|
\ 'fname': syntastic#util#shexpand('%:p'),
|
||||||
|
\ 'post_args_after': post_args })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%W%f:%l: warning: %m,'.
|
||||||
|
\ '%E%f:%l: %m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'erlang',
|
||||||
|
\ 'name': 'escript'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,42 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: syntaxerl.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.
|
||||||
|
"Maintainer: locojay
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_erlang_syntaxerl_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
|
||||||
|
let g:loaded_syntastic_erlang_syntaxerl_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
|
||||||
|
function! SyntaxCheckers_erlang_syntaxerl_GetLocList() dict
|
||||||
|
|
||||||
|
let makeprg = self.makeprgBuild({})
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%W%f:%l: warning: %m,'.
|
||||||
|
\ '%E%f:%l: %m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'erlang',
|
||||||
|
\ 'name': 'syntaxerl'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
70
sources_non_forked/syntastic/syntax_checkers/eruby/ruby.vim
Normal file
70
sources_non_forked/syntastic/syntax_checkers/eruby/ruby.vim
Normal file
|
@ -0,0 +1,70 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: ruby.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Martin Grenfell <martin.grenfell at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_eruby_ruby_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_eruby_ruby_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_eruby_ruby_IsAvailable() dict
|
||||||
|
if !exists('g:syntastic_eruby_ruby_exec') && exists('g:syntastic_ruby_exec')
|
||||||
|
let g:syntastic_eruby_ruby_exec = g:syntastic_ruby_exec
|
||||||
|
endif
|
||||||
|
return executable(self.getExec())
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_eruby_ruby_GetLocList() dict
|
||||||
|
let fname = "'" . escape(expand('%'), "\\'") . "'"
|
||||||
|
|
||||||
|
" TODO: encodings became useful in ruby 1.9 :)
|
||||||
|
if syntastic#util#versionIsAtLeast(syntastic#util#getVersion(self.getExecEscaped(). ' --version'), [1, 9])
|
||||||
|
let enc = &fileencoding != '' ? &fileencoding : &encoding
|
||||||
|
let encoding_spec = ', :encoding => "' . (enc ==? 'utf-8' ? 'UTF-8' : 'BINARY') . '"'
|
||||||
|
else
|
||||||
|
let encoding_spec = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
"gsub fixes issue #7, rails has it's own eruby syntax
|
||||||
|
let makeprg =
|
||||||
|
\ self.getExecEscaped() . ' -rerb -e ' .
|
||||||
|
\ syntastic#util#shescape('puts ERB.new(File.read(' .
|
||||||
|
\ fname . encoding_spec .
|
||||||
|
\ ').gsub(''<%='',''<%''), nil, ''-'').src') .
|
||||||
|
\ ' | ' . self.getExecEscaped() . ' -c'
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%-GSyntax OK,'.
|
||||||
|
\ '%E-:%l: syntax error\, %m,%Z%p^,'.
|
||||||
|
\ '%W-:%l: warning: %m,'.
|
||||||
|
\ '%Z%p^,'.
|
||||||
|
\ '%-C%.%#'
|
||||||
|
|
||||||
|
let env = syntastic#util#isRunningWindows() ? {} : { 'RUBYOPT': '' }
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'env': env,
|
||||||
|
\ 'defaults': { 'bufnr': bufnr(""), 'vcol': 1 } })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'eruby',
|
||||||
|
\ 'name': 'ruby'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,51 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: fortran.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Karl Yngve Lervåg <karl.yngve@lervag.net>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_fortran_gfortran_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_fortran_gfortran_checker=1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_fortran_compiler_options')
|
||||||
|
let g:syntastic_fortran_compiler_options = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_fortran_gfortran_IsAvailable() dict
|
||||||
|
if !exists('g:syntastic_fortran_compiler')
|
||||||
|
let g:syntastic_fortran_compiler = self.getExec()
|
||||||
|
endif
|
||||||
|
return executable(expand(g:syntastic_fortran_compiler))
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_fortran_gfortran_GetLocList() dict
|
||||||
|
return syntastic#c#GetLocList('fortran', 'gfortran', {
|
||||||
|
\ 'errorformat':
|
||||||
|
\ '%-C %#,'.
|
||||||
|
\ '%-C %#%.%#,'.
|
||||||
|
\ '%A%f:%l.%c:,'.
|
||||||
|
\ '%Z%trror: %m,'.
|
||||||
|
\ '%Z%tarning: %m,'.
|
||||||
|
\ '%-G%.%#',
|
||||||
|
\ 'main_flags': '-fsyntax-only' })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'fortran',
|
||||||
|
\ 'name': 'gfortran' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
77
sources_non_forked/syntastic/syntax_checkers/glsl/cgc.vim
Normal file
77
sources_non_forked/syntastic/syntax_checkers/glsl/cgc.vim
Normal file
|
@ -0,0 +1,77 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: glsl.vim
|
||||||
|
"Description: Syntax checker for OpenGL Shading Language
|
||||||
|
"Maintainer: Joshua Rahm <joshuarahm@gmail.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_glsl_cgc_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_glsl_cgc_checker = 1
|
||||||
|
|
||||||
|
let s:glsl_extensions = {
|
||||||
|
\ 'glslf': 'gpu_fp',
|
||||||
|
\ 'glslv': 'gpu_vp',
|
||||||
|
\ 'frag': 'gpu_fp',
|
||||||
|
\ 'vert': 'gpu_vp',
|
||||||
|
\ 'fp': 'gpu_fp',
|
||||||
|
\ 'vp': 'gpu_vp'
|
||||||
|
\ }
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_glsl_cgc_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'args_before': '-oglsl -profile ' . s:GetProfile(),
|
||||||
|
\ 'args': (exists('g:syntastic_glsl_options') ? ' ' . g:syntastic_glsl_options : '') })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ "%E%f(%l) : error %m," .
|
||||||
|
\ "%W%f(%l) : warning %m"
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:GetProfile()
|
||||||
|
let save_view = winsaveview()
|
||||||
|
let old_foldenable = &foldenable
|
||||||
|
let old_lazyredraw = &lazyredraw
|
||||||
|
|
||||||
|
let &lazyredraw = 1
|
||||||
|
let &foldenable = 0
|
||||||
|
call cursor(1, 1)
|
||||||
|
|
||||||
|
let magic = '\m\C^// profile:\s*'
|
||||||
|
let line = search(magic, 'c')
|
||||||
|
|
||||||
|
call winrestview(save_view)
|
||||||
|
let &foldenable = old_foldenable
|
||||||
|
let &lazyredraw = old_lazyredraw
|
||||||
|
|
||||||
|
if line
|
||||||
|
let profile = matchstr(getline(line), magic . '\zs.*')
|
||||||
|
else
|
||||||
|
let extensions = exists('g:syntastic_glsl_extensions') ? g:syntastic_glsl_extensions : s:glsl_extensions
|
||||||
|
let profile = get(extensions, tolower(expand('%:e')), 'gpu_vert')
|
||||||
|
endif
|
||||||
|
|
||||||
|
return profile
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\'filetype': 'glsl',
|
||||||
|
\'name': 'cgc'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
91
sources_non_forked/syntastic/syntax_checkers/go/go.vim
Normal file
91
sources_non_forked/syntastic/syntax_checkers/go/go.vim
Normal file
|
@ -0,0 +1,91 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: go.vim
|
||||||
|
"Description: Check go syntax using 'gofmt -l' followed by 'go [build|test]'
|
||||||
|
"Maintainer: Kamil Kisiel <kamil@kamilkisiel.net>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
" This syntax checker does not reformat your source code.
|
||||||
|
" Use a BufWritePre autocommand to that end:
|
||||||
|
" autocmd FileType go autocmd BufWritePre <buffer> Fmt
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_go_go_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_go_go_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_go_go_IsAvailable() dict
|
||||||
|
return executable('go') && executable('gofmt')
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_go_go_GetLocList() dict
|
||||||
|
" Check with gofmt first, since `go build` and `go test` might not report
|
||||||
|
" syntax errors in the current file if another file with syntax error is
|
||||||
|
" compiled first.
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'exe': 'gofmt',
|
||||||
|
\ 'args': '-l',
|
||||||
|
\ 'tail': '> ' . syntastic#util#DevNull() })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%f:%l:%c: %m,' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
let errors = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'type': 'e'} })
|
||||||
|
if !empty(errors)
|
||||||
|
return errors
|
||||||
|
endif
|
||||||
|
|
||||||
|
" Test files, i.e. files with a name ending in `_test.go`, are not
|
||||||
|
" compiled by `go build`, therefore `go test` must be called for those.
|
||||||
|
if match(expand('%'), '\m_test\.go$') == -1
|
||||||
|
let makeprg = 'go build ' . syntastic#c#NullOutput()
|
||||||
|
let cleanup = 0
|
||||||
|
else
|
||||||
|
let makeprg = 'go test -c ' . syntastic#c#NullOutput()
|
||||||
|
let cleanup = 1
|
||||||
|
endif
|
||||||
|
|
||||||
|
" The first pattern is for warnings from C compilers.
|
||||||
|
let errorformat =
|
||||||
|
\ '%W%f:%l: warning: %m,' .
|
||||||
|
\ '%E%f:%l:%c:%m,' .
|
||||||
|
\ '%E%f:%l:%m,' .
|
||||||
|
\ '%C%\s%\+%m,' .
|
||||||
|
\ '%-G#%.%#'
|
||||||
|
|
||||||
|
" The go compiler needs to either be run with an import path as an
|
||||||
|
" argument or directly from the package directory. Since figuring out
|
||||||
|
" the proper import path is fickle, just cwd to the package.
|
||||||
|
|
||||||
|
let errors = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'cwd': expand('%:p:h'),
|
||||||
|
\ 'defaults': {'type': 'e'} })
|
||||||
|
|
||||||
|
if cleanup
|
||||||
|
call delete(expand('%:p:h') . syntastic#util#Slash() . expand('%:p:h:t') . '.test')
|
||||||
|
endif
|
||||||
|
|
||||||
|
return errors
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'go',
|
||||||
|
\ 'name': 'go'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
44
sources_non_forked/syntastic/syntax_checkers/go/gofmt.vim
Normal file
44
sources_non_forked/syntastic/syntax_checkers/go/gofmt.vim
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: gofmt.vim
|
||||||
|
"Description: Check go syntax using 'gofmt -l'
|
||||||
|
"Maintainer: Brandon Thomson <bt@brandonthomson.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
" This syntax checker does not reformat your source code.
|
||||||
|
" Use a BufWritePre autocommand to that end:
|
||||||
|
" autocmd FileType go autocmd BufWritePre <buffer> Fmt
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_go_gofmt_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_go_gofmt_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_go_gofmt_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'args_after': '-l',
|
||||||
|
\ 'tail_after': '> ' . syntastic#util#DevNull() })
|
||||||
|
|
||||||
|
let errorformat = '%f:%l:%c: %m,%-G%.%#'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'type': 'e'} })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'go',
|
||||||
|
\ 'name': 'gofmt'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
39
sources_non_forked/syntastic/syntax_checkers/go/golint.vim
Normal file
39
sources_non_forked/syntastic/syntax_checkers/go/golint.vim
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: golint.vim
|
||||||
|
"Description: Check go syntax using 'golint'
|
||||||
|
"Maintainer: Hiroshi Ioka <hirochachacha@gmail.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_go_golint_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_go_golint_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_go_golint_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({})
|
||||||
|
|
||||||
|
let errorformat = '%f:%l:%c: %m,%-G%.%#'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'subtype': 'Style' })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'go',
|
||||||
|
\ 'name': 'golint'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
48
sources_non_forked/syntastic/syntax_checkers/go/gotype.vim
Normal file
48
sources_non_forked/syntastic/syntax_checkers/go/gotype.vim
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: gotype.vim
|
||||||
|
"Description: Perform syntactic and semantic checking of Go code using 'gotype'
|
||||||
|
"Maintainer: luz <ne.tetewi@gmail.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_go_gotype_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_go_gotype_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_go_gotype_GetLocList() dict
|
||||||
|
let makeprg = self.getExecEscaped() . ' .'
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%f:%l:%c: %m,' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
" gotype needs the full go package to test types properly. Just cwd to
|
||||||
|
" the package for the same reasons specified in go.vim ("figuring out
|
||||||
|
" the import path is fickle").
|
||||||
|
|
||||||
|
let errors = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'cwd': expand('%:p:h'),
|
||||||
|
\ 'defaults': {'type': 'e'} })
|
||||||
|
|
||||||
|
return errors
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'go',
|
||||||
|
\ 'name': 'gotype'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
49
sources_non_forked/syntastic/syntax_checkers/go/govet.vim
Normal file
49
sources_non_forked/syntastic/syntax_checkers/go/govet.vim
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: govet.vim
|
||||||
|
"Description: Perform static analysis of Go code with the vet tool
|
||||||
|
"Maintainer: Kamil Kisiel <kamil@kamilkisiel.net>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_go_govet_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_go_govet_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_go_govet_IsAvailable() dict
|
||||||
|
return executable('go')
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_go_govet_GetLocList() dict
|
||||||
|
let makeprg = 'go vet'
|
||||||
|
let errorformat = '%Evet: %.%\+: %f:%l:%c: %m,%W%f:%l: %m,%-G%.%#'
|
||||||
|
|
||||||
|
" The go compiler needs to either be run with an import path as an
|
||||||
|
" argument or directly from the package directory. Since figuring out
|
||||||
|
" the proper import path is fickle, just cwd to the package.
|
||||||
|
|
||||||
|
let errors = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'cwd': expand('%:p:h'),
|
||||||
|
\ 'defaults': {'type': 'w'} })
|
||||||
|
|
||||||
|
return errors
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'go',
|
||||||
|
\ 'name': 'govet'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
46
sources_non_forked/syntastic/syntax_checkers/haml/haml.vim
Normal file
46
sources_non_forked/syntastic/syntax_checkers/haml/haml.vim
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: haml.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Martin Grenfell <martin.grenfell at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_haml_haml_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_haml_haml_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_haml_haml_IsAvailable() dict
|
||||||
|
call syntastic#log#deprecationWarn('haml_interpreter', 'haml_haml_exec')
|
||||||
|
return executable(self.getExec())
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_haml_haml_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '-c' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ 'Haml error on line %l: %m,' .
|
||||||
|
\ 'Syntax error on line %l: %m,' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'haml',
|
||||||
|
\ 'name': 'haml'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,37 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: haml_lint.vim
|
||||||
|
"Description: HAML style and syntax checker plugin for Syntastic
|
||||||
|
"Maintainer: Shane da Silva <shane@dasilva.io>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_haml_haml_lint_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_haml_haml_lint_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_haml_haml_lint_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({})
|
||||||
|
let errorformat = '%f:%l [%t] %m'
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'subtype': 'Style'})
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'haml',
|
||||||
|
\ 'name': 'haml_lint',
|
||||||
|
\ 'exec': 'haml-lint' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,42 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: handlebars.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Martin Grenfell <martin.grenfell at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_handlebars_handlebars_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_handlebars_handlebars_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_handlebars_handlebars_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '-f ' . syntastic#util#DevNull() })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%EError: %m on line %l:,'.
|
||||||
|
\ "%EError: %m,".
|
||||||
|
\ '%Z%p^,' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr("")} })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'handlebars',
|
||||||
|
\ 'name': 'handlebars'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,72 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: ghc-mod.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Anthony Carapetis <anthony.carapetis at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_haskell_ghc_mod_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_haskell_ghc_mod_checker = 1
|
||||||
|
|
||||||
|
let s:ghc_mod_new = -1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_haskell_ghc_mod_IsAvailable() dict
|
||||||
|
" We need either a Vim version that can handle NULs in system() output,
|
||||||
|
" or a ghc-mod version that has the --boundary option.
|
||||||
|
let exe = self.getExec()
|
||||||
|
let s:ghc_mod_new = executable(exe) ? s:GhcModNew(exe) : -1
|
||||||
|
return (s:ghc_mod_new >= 0) && (v:version >= 704 || s:ghc_mod_new)
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_haskell_ghc_mod_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'exe': self.getExecEscaped() . ' check' . (s:ghc_mod_new ? ' --boundary=""' : '') })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%-G%\s%#,' .
|
||||||
|
\ '%f:%l:%c:%trror: %m,' .
|
||||||
|
\ '%f:%l:%c:%tarning: %m,'.
|
||||||
|
\ '%f:%l:%c: %trror: %m,' .
|
||||||
|
\ '%f:%l:%c: %tarning: %m,' .
|
||||||
|
\ '%f:%l:%c:%m,' .
|
||||||
|
\ '%E%f:%l:%c:,' .
|
||||||
|
\ '%Z%m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'postprocess': ['compressWhitespace'],
|
||||||
|
\ 'returns': [0] })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:GhcModNew(exe)
|
||||||
|
let exe = syntastic#util#shescape(a:exe)
|
||||||
|
try
|
||||||
|
let ghc_mod_version = filter(split(system(exe), '\n'), 'v:val =~# ''\m^ghc-mod version''')[0]
|
||||||
|
let ret = syntastic#util#versionIsAtLeast(syntastic#util#parseVersion(ghc_mod_version), [2, 1, 2])
|
||||||
|
catch /\m^Vim\%((\a\+)\)\=:E684/
|
||||||
|
call syntastic#log#error("checker haskell/ghc_mod: can't parse version string (abnormal termination?)")
|
||||||
|
let ret = -1
|
||||||
|
endtry
|
||||||
|
return ret
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'haskell',
|
||||||
|
\ 'name': 'ghc_mod',
|
||||||
|
\ 'exec': 'ghc-mod' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,56 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: hdevtools.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Anthony Carapetis <anthony.carapetis at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_haskell_hdevtools_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_haskell_hdevtools_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_haskell_hdevtools_GetLocList() dict
|
||||||
|
if !exists('g:syntastic_haskell_hdevtools_args') && exists('g:hdevtools_options')
|
||||||
|
call syntastic#log#oneTimeWarn('variable g:hdevtools_options is deprecated, ' .
|
||||||
|
\ 'please use g:syntastic_haskell_hdevtools_args instead')
|
||||||
|
let g:syntastic_haskell_hdevtools_args = g:hdevtools_options
|
||||||
|
endif
|
||||||
|
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'exe_after': 'check',
|
||||||
|
\ 'fname': syntastic#util#shexpand('%:p') })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%-Z %#,'.
|
||||||
|
\ '%W%f:%l:%v: Warning: %m,'.
|
||||||
|
\ '%W%f:%l:%v: Warning:,'.
|
||||||
|
\ '%E%f:%l:%v: %m,'.
|
||||||
|
\ '%E%>%f:%l:%v:,'.
|
||||||
|
\ '%+C %#%m,'.
|
||||||
|
\ '%W%>%f:%l:%v:,'.
|
||||||
|
\ '%+C %#%tarning: %m,'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'vcol': 1},
|
||||||
|
\ 'postprocess': ['compressWhitespace'] })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'haskell',
|
||||||
|
\ 'name': 'hdevtools'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,39 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: hlint.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Nicolas Wu <nicolas.wu at gmail dot com>
|
||||||
|
"License: BSD
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_haskell_hlint_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_haskell_hlint_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_haskell_hlint_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'fname': syntastic#util#shexpand('%:p')})
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%E%f:%l:%v: Error: %m,' .
|
||||||
|
\ '%W%f:%l:%v: Warning: %m,' .
|
||||||
|
\ '%C%m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'vcol': 1},
|
||||||
|
\ 'postprocess': ['compressWhitespace'] })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'haskell',
|
||||||
|
\ 'name': 'hlint'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,43 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: scan.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: LCD 47 <lcd047 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_haskell_scan_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_haskell_scan_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_haskell_scan_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({})
|
||||||
|
|
||||||
|
let errorformat = '%f:%l:%v: %m'
|
||||||
|
|
||||||
|
let loclist = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'subtype': 'Style' })
|
||||||
|
|
||||||
|
call self.setWantSort(1)
|
||||||
|
|
||||||
|
return loclist
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'haskell',
|
||||||
|
\ 'name': 'scan'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
61
sources_non_forked/syntastic/syntax_checkers/haxe/haxe.vim
Normal file
61
sources_non_forked/syntastic/syntax_checkers/haxe/haxe.vim
Normal file
|
@ -0,0 +1,61 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: haxe.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: David Bernard <david.bernard.31 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_haxe_haxe_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_haxe_haxe_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_haxe_haxe_GetLocList() dict
|
||||||
|
if exists('b:vaxe_hxml')
|
||||||
|
let hxml = b:vaxe_hxml
|
||||||
|
elseif exists('g:vaxe_hxml')
|
||||||
|
let hxml = g:vaxe_hxml
|
||||||
|
else
|
||||||
|
let hxml = syntastic#util#findInParent('*.hxml', expand('%:p:h'))
|
||||||
|
endif
|
||||||
|
let hxml = fnamemodify(hxml, ':p')
|
||||||
|
|
||||||
|
if hxml != ''
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'fname': syntastic#util#shescape(fnamemodify(hxml, ':t')) })
|
||||||
|
|
||||||
|
let errorformat = '%E%f:%l: characters %c-%n : %m'
|
||||||
|
|
||||||
|
let loclist = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'cwd': fnamemodify(hxml, ':h') })
|
||||||
|
|
||||||
|
for e in loclist
|
||||||
|
let e['hl'] = '\%>' . e['col'] . 'c\%<' . (e['nr'] + 1) . 'c'
|
||||||
|
let e['col'] += 1
|
||||||
|
let e['nr'] = 0
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return loclist
|
||||||
|
endif
|
||||||
|
|
||||||
|
return []
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'haxe',
|
||||||
|
\ 'name': 'haxe'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
38
sources_non_forked/syntastic/syntax_checkers/hss/hss.vim
Normal file
38
sources_non_forked/syntastic/syntax_checkers/hss/hss.vim
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: hss.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Justin Donaldson (jdonaldson@gmail.com)
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_hss_hss_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_hss_hss_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_hss_hss_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after' : '-output ' . syntastic#util#DevNull() })
|
||||||
|
|
||||||
|
let errorformat = '%E%f:%l: %m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'hss',
|
||||||
|
\ 'name': 'hss'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
50
sources_non_forked/syntastic/syntax_checkers/html/jshint.vim
Normal file
50
sources_non_forked/syntastic/syntax_checkers/html/jshint.vim
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: jshint.vim
|
||||||
|
"Description: Javascript syntax checker for HTML - using jshint
|
||||||
|
"Maintainer: LCD 47 <lcd047@gmail.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_html_jshint_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_html_jshint_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_html_jshint_IsAvailable() dict
|
||||||
|
call syntastic#log#deprecationWarn('jshint_exec', 'html_jshint_exec')
|
||||||
|
return executable(self.getExec()) &&
|
||||||
|
\ syntastic#util#versionIsAtLeast(syntastic#util#getVersion(self.getExecEscaped() . ' --version'), [2,4])
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_html_jshint_GetLocList() dict
|
||||||
|
call syntastic#log#deprecationWarn('html_jshint_conf', 'html_jshint_args',
|
||||||
|
\ "'--config ' . syntastic#util#shexpand(OLD_VAR)")
|
||||||
|
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '--verbose --extract always' })
|
||||||
|
|
||||||
|
let errorformat = '%A%f: line %l\, col %v\, %m \(%t%*\d\)'
|
||||||
|
|
||||||
|
call self.setWantSort(1)
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr('')},
|
||||||
|
\ 'returns': [0, 2] })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'html',
|
||||||
|
\ 'name': 'jshint'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
219
sources_non_forked/syntastic/syntax_checkers/html/tidy.vim
Normal file
219
sources_non_forked/syntastic/syntax_checkers/html/tidy.vim
Normal file
|
@ -0,0 +1,219 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: tidy.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Martin Grenfell <martin.grenfell at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" Note: if you need to check HTML5 sources, you might consider installing a
|
||||||
|
" fork of HTML Tidy, named "HTML Tidy for HTML5":
|
||||||
|
"
|
||||||
|
" http://w3c.github.io/tidy-html5/
|
||||||
|
"
|
||||||
|
" HTML Tidy for HTML5 can be used without changes by this checker, just install
|
||||||
|
" it and point g:syntastic_html_tidy_exec to the executable.
|
||||||
|
"
|
||||||
|
" Checker options:
|
||||||
|
"
|
||||||
|
" - g:syntastic_html_tidy_ignore_errors (list; default: [])
|
||||||
|
" list of errors to ignore
|
||||||
|
" - g:syntastic_html_tidy_blocklevel_tags (list; default: [])
|
||||||
|
" list of additional blocklevel tags, to be added to "--new-blocklevel-tags"
|
||||||
|
" - g:syntastic_html_tidy_inline_tags (list; default: [])
|
||||||
|
" list of additional inline tags, to be added to "--new-inline-tags"
|
||||||
|
" - g:syntastic_html_tidy_empty_tags (list; default: [])
|
||||||
|
" list of additional empty tags, to be added to "--new-empty-tags"
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_html_tidy_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_html_tidy_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_html_tidy_ignore_errors')
|
||||||
|
let g:syntastic_html_tidy_ignore_errors = []
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_html_tidy_blocklevel_tags')
|
||||||
|
let g:syntastic_html_tidy_blocklevel_tags = []
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_html_tidy_inline_tags')
|
||||||
|
let g:syntastic_html_tidy_inline_tags = []
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_html_tidy_empty_tags')
|
||||||
|
let g:syntastic_html_tidy_empty_tags = []
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
" TODO: join this with xhtml.vim for DRY's sake?
|
||||||
|
function! s:TidyEncOptByFenc()
|
||||||
|
let tidy_opts = {
|
||||||
|
\ 'utf-8': '-utf8',
|
||||||
|
\ 'ascii': '-ascii',
|
||||||
|
\ 'latin1': '-latin1',
|
||||||
|
\ 'iso-2022-jp': '-iso-2022',
|
||||||
|
\ 'cp1252': '-win1252',
|
||||||
|
\ 'macroman': '-mac',
|
||||||
|
\ 'utf-16le': '-utf16le',
|
||||||
|
\ 'utf-16': '-utf16',
|
||||||
|
\ 'big5': '-big5',
|
||||||
|
\ 'cp932': '-shiftjis',
|
||||||
|
\ 'sjis': '-shiftjis',
|
||||||
|
\ 'cp850': '-ibm858',
|
||||||
|
\ }
|
||||||
|
return get(tidy_opts, &fileencoding, '-utf8')
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
let s:ignore_errors = [
|
||||||
|
\ "<table> lacks \"summary\" attribute",
|
||||||
|
\ "not approved by W3C",
|
||||||
|
\ "<input> proprietary attribute \"placeholder\"",
|
||||||
|
\ "<meta> proprietary attribute \"charset\"",
|
||||||
|
\ "<meta> lacks \"content\" attribute",
|
||||||
|
\ "inserting \"type\" attribute",
|
||||||
|
\ "proprietary attribute \"data-",
|
||||||
|
\ "missing <!DOCTYPE> declaration",
|
||||||
|
\ "inserting implicit <body>",
|
||||||
|
\ "inserting missing 'title' element",
|
||||||
|
\ "unescaped & or unknown entity",
|
||||||
|
\ "<input> attribute \"type\" has invalid value",
|
||||||
|
\ "proprietary attribute \"role\"",
|
||||||
|
\ "proprietary attribute \"aria-activedescendant\"",
|
||||||
|
\ "proprietary attribute \"aria-atomic\"",
|
||||||
|
\ "proprietary attribute \"aria-autocomplete\"",
|
||||||
|
\ "proprietary attribute \"aria-busy\"",
|
||||||
|
\ "proprietary attribute \"aria-checked\"",
|
||||||
|
\ "proprietary attribute \"aria-controls\"",
|
||||||
|
\ "proprietary attribute \"aria-describedby\"",
|
||||||
|
\ "proprietary attribute \"aria-disabled\"",
|
||||||
|
\ "proprietary attribute \"aria-dropeffect\"",
|
||||||
|
\ "proprietary attribute \"aria-expanded\"",
|
||||||
|
\ "proprietary attribute \"aria-flowto\"",
|
||||||
|
\ "proprietary attribute \"aria-grabbed\"",
|
||||||
|
\ "proprietary attribute \"aria-haspopup\"",
|
||||||
|
\ "proprietary attribute \"aria-hidden\"",
|
||||||
|
\ "proprietary attribute \"aria-invalid\"",
|
||||||
|
\ "proprietary attribute \"aria-label\"",
|
||||||
|
\ "proprietary attribute \"aria-labelledby\"",
|
||||||
|
\ "proprietary attribute \"aria-level\"",
|
||||||
|
\ "proprietary attribute \"aria-live\"",
|
||||||
|
\ "proprietary attribute \"aria-multiline\"",
|
||||||
|
\ "proprietary attribute \"aria-multiselectable\"",
|
||||||
|
\ "proprietary attribute \"aria-orientation\"",
|
||||||
|
\ "proprietary attribute \"aria-owns\"",
|
||||||
|
\ "proprietary attribute \"aria-posinset\"",
|
||||||
|
\ "proprietary attribute \"aria-pressed\"",
|
||||||
|
\ "proprietary attribute \"aria-readonly\"",
|
||||||
|
\ "proprietary attribute \"aria-relevant\"",
|
||||||
|
\ "proprietary attribute \"aria-relevant\"",
|
||||||
|
\ "proprietary attribute \"aria-required\"",
|
||||||
|
\ "proprietary attribute \"aria-selected\"",
|
||||||
|
\ "proprietary attribute \"aria-setsize\"",
|
||||||
|
\ "proprietary attribute \"aria-sort\"",
|
||||||
|
\ "proprietary attribute \"aria-valuemax\"",
|
||||||
|
\ "proprietary attribute \"aria-valuemin\"",
|
||||||
|
\ "proprietary attribute \"aria-valuenow\"",
|
||||||
|
\ "proprietary attribute \"aria-valuetext\""
|
||||||
|
\ ]
|
||||||
|
lockvar! s:ignore_errors
|
||||||
|
|
||||||
|
let s:blocklevel_tags = [
|
||||||
|
\ "main",
|
||||||
|
\ "section",
|
||||||
|
\ "article",
|
||||||
|
\ "aside",
|
||||||
|
\ "header",
|
||||||
|
\ "footer",
|
||||||
|
\ "nav",
|
||||||
|
\ "figure",
|
||||||
|
\ "figcaption"
|
||||||
|
\ ]
|
||||||
|
lockvar! s:blocklevel_tags
|
||||||
|
|
||||||
|
let s:inline_tags = [
|
||||||
|
\ "video",
|
||||||
|
\ "audio",
|
||||||
|
\ "source",
|
||||||
|
\ "embed",
|
||||||
|
\ "mark",
|
||||||
|
\ "progress",
|
||||||
|
\ "meter",
|
||||||
|
\ "time",
|
||||||
|
\ "ruby",
|
||||||
|
\ "rt",
|
||||||
|
\ "rp",
|
||||||
|
\ "canvas",
|
||||||
|
\ "command",
|
||||||
|
\ "details",
|
||||||
|
\ "datalist"
|
||||||
|
\ ]
|
||||||
|
lockvar! s:inline_tags
|
||||||
|
|
||||||
|
let s:empty_tags = [
|
||||||
|
\ "wbr",
|
||||||
|
\ "keygen"
|
||||||
|
\ ]
|
||||||
|
lockvar! s:empty_tags
|
||||||
|
|
||||||
|
function! s:IgnoreError(text)
|
||||||
|
for i in s:ignore_errors + g:syntastic_html_tidy_ignore_errors
|
||||||
|
if stridx(a:text, i) != -1
|
||||||
|
return 1
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
return 0
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:NewTags(name)
|
||||||
|
return syntastic#util#shescape(join( s:{a:name} + g:syntastic_html_tidy_{a:name}, ',' ))
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:Args()
|
||||||
|
let args = s:TidyEncOptByFenc() .
|
||||||
|
\ ' --new-blocklevel-tags ' . s:NewTags('blocklevel_tags') .
|
||||||
|
\ ' --new-inline-tags ' . s:NewTags('inline_tags') .
|
||||||
|
\ ' --new-empty-tags ' . s:NewTags('empty_tags') .
|
||||||
|
\ ' -e'
|
||||||
|
return args
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_html_tidy_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': s:Args() })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%Wline %l column %v - Warning: %m,' .
|
||||||
|
\ '%Eline %l column %v - Error: %m,' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
let loclist = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr("")},
|
||||||
|
\ 'returns': [0, 1, 2] })
|
||||||
|
|
||||||
|
" filter out valid HTML5 from the errors
|
||||||
|
for e in loclist
|
||||||
|
if e['valid'] && s:IgnoreError(e['text']) == 1
|
||||||
|
let e['valid'] = 0
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return loclist
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'html',
|
||||||
|
\ 'name': 'tidy'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,87 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: validator.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: LCD 47 <lcd047 at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" For detail;s about validator see: http://about.validator.nu/
|
||||||
|
"
|
||||||
|
" Checker options:
|
||||||
|
"
|
||||||
|
" - g:syntastic_html_validator_api (string; default: 'http://validator.nu/')
|
||||||
|
" URL of the service to use for checking; leave it to the default to run the
|
||||||
|
" checks against http://validator.nu/, or set it to 'http://localhost:8888/'
|
||||||
|
" if you're running a local service as per http://about.validator.nu/#src
|
||||||
|
"
|
||||||
|
" - g:syntastic_html_validator_parser (string; default: empty)
|
||||||
|
" parser to use; legal values are: xml, xmldtd, html, html5, html4, html4tr;
|
||||||
|
" set it to 'html5' to check HTML5 files; see the wiki for reference:
|
||||||
|
" http://wiki.whatwg.org/wiki/Validator.nu_Common_Input_Parameters#parser
|
||||||
|
"
|
||||||
|
" - g:syntastic_html_validator_nsfilter (string; default: empty)
|
||||||
|
" sets the nsfilter for the parser; see the wiki for details:
|
||||||
|
" http://wiki.whatwg.org/wiki/Validator.nu_Common_Input_Parameters#nsfilter
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_html_validator_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_html_validator_checker=1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_html_validator_api')
|
||||||
|
let g:syntastic_html_validator_api = 'http://validator.nu/'
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_html_validator_parser')
|
||||||
|
let g:syntastic_html_validator_parser = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_html_validator_nsfilter')
|
||||||
|
let g:syntastic_html_validator_nsfilter = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_html_validator_GetLocList() dict
|
||||||
|
let fname = syntastic#util#shexpand('%')
|
||||||
|
let makeprg = self.getExecEscaped() . ' -s --compressed -F out=gnu -F asciiquotes=yes' .
|
||||||
|
\ (g:syntastic_html_validator_parser != '' ? ' -F parser=' . g:syntastic_html_validator_parser : '') .
|
||||||
|
\ (g:syntastic_html_validator_nsfilter != '' ? ' -F nsfilter=' . g:syntastic_html_validator_nsfilter : '') .
|
||||||
|
\ ' -F doc=@' . fname . '\;type=text/html\;filename=' . fname . ' ' . g:syntastic_html_validator_api
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%E"%f":%l: %trror: %m,' .
|
||||||
|
\ '%E"%f":%l-%\d%\+: %trror: %m,' .
|
||||||
|
\ '%E"%f":%l%\%.%c: %trror: %m,' .
|
||||||
|
\ '%E"%f":%l%\%.%c-%\d%\+%\%.%\d%\+: %trror: %m,' .
|
||||||
|
\ '%E"%f":%l: %trror fatal: %m,' .
|
||||||
|
\ '%E"%f":%l-%\d%\+: %trror fatal: %m,' .
|
||||||
|
\ '%E"%f":%l%\%.%c: %trror fatal: %m,' .
|
||||||
|
\ '%E"%f":%l%\%.%c-%\d%\+%\%.%\d%\+: %trror fatal: %m,' .
|
||||||
|
\ '%W"%f":%l: info %tarning: %m,' .
|
||||||
|
\ '%W"%f":%l-%\d%\+: info %tarning: %m,' .
|
||||||
|
\ '%W"%f":%l%\%.%c: info %tarning: %m,' .
|
||||||
|
\ '%W"%f":%l%\%.%c-%\d%\+%\%.%\d%\+: info %tarning: %m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'preprocess': 'validator',
|
||||||
|
\ 'returns': [0] })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'html',
|
||||||
|
\ 'name': 'validator',
|
||||||
|
\ 'exec': 'curl' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
69
sources_non_forked/syntastic/syntax_checkers/html/w3.vim
Normal file
69
sources_non_forked/syntastic/syntax_checkers/html/w3.vim
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: w3.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Martin Grenfell <martin.grenfell at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
"
|
||||||
|
" Checker option:
|
||||||
|
"
|
||||||
|
" - g:syntastic_html_w3_api (string; default: 'http://validator.w3.org/check')
|
||||||
|
" URL of the service to use for checking; leave it to the default to run the
|
||||||
|
" checks against http://validator.w3.org/, or set it to
|
||||||
|
" 'http://localhost/w3c-validator/check' if you're running a local service
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_html_w3_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_html_w3_checker = 1
|
||||||
|
|
||||||
|
if !exists('g:syntastic_html_w3_api')
|
||||||
|
let g:syntastic_html_w3_api = 'http://validator.w3.org/check'
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_html_w3_GetLocList() dict
|
||||||
|
let makeprg = self.getExecEscaped() . ' -s -F output=json ' .
|
||||||
|
\ '-F uploaded_file=@' . syntastic#util#shexpand('%:p') . '\;type=text/html ' .
|
||||||
|
\ g:syntastic_html_w3_api
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%A %\+{,' .
|
||||||
|
\ '%C %\+"lastLine": %l\,%\?,' .
|
||||||
|
\ '%C %\+"lastColumn": %c\,%\?,' .
|
||||||
|
\ '%C %\+"message": "%m"\,%\?,' .
|
||||||
|
\ '%C %\+"type": "%trror"\,%\?,' .
|
||||||
|
\ '%-G %\+"type": "%tnfo"\,%\?,' .
|
||||||
|
\ '%C %\+"subtype": "%tarning"\,%\?,' .
|
||||||
|
\ '%Z %\+}\,,' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
let loclist = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr("")},
|
||||||
|
\ 'returns': [0] })
|
||||||
|
|
||||||
|
for e in loclist
|
||||||
|
let e['text'] = substitute(e['text'], '\m\\\([\"]\)', '\1', 'g')
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return loclist
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'html',
|
||||||
|
\ 'name': 'w3',
|
||||||
|
\ 'exec': 'curl' })
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,62 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: checkstyle.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Dmitry Geurkov <d.geurkov at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
" Tested with checkstyle 5.5
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_java_checkstyle_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_java_checkstyle_checker = 1
|
||||||
|
|
||||||
|
if !exists("g:syntastic_java_checkstyle_classpath")
|
||||||
|
let g:syntastic_java_checkstyle_classpath = 'checkstyle-5.5-all.jar'
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists("g:syntastic_java_checkstyle_conf_file")
|
||||||
|
let g:syntastic_java_checkstyle_conf_file = 'sun_checks.xml'
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_java_checkstyle_GetLocList() dict
|
||||||
|
|
||||||
|
let fname = syntastic#util#shescape( expand('%:p:h') . '/' . expand('%:t') )
|
||||||
|
|
||||||
|
if has('win32unix')
|
||||||
|
let fname = substitute(system('cygpath -m ' . fname), '\m\%x00', '', 'g')
|
||||||
|
endif
|
||||||
|
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'args_after': '-cp ' . g:syntastic_java_checkstyle_classpath .
|
||||||
|
\ ' com.puppycrawl.tools.checkstyle.Main -c ' .
|
||||||
|
\ syntastic#util#shexpand(g:syntastic_java_checkstyle_conf_file) .
|
||||||
|
\ ' -f xml',
|
||||||
|
\ 'fname': fname })
|
||||||
|
|
||||||
|
let errorformat = '%f:%t:%l:%c:%m'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'preprocess': 'checkstyle',
|
||||||
|
\ 'subtype': 'Style' })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'java',
|
||||||
|
\ 'name': 'checkstyle',
|
||||||
|
\ 'exec': 'java'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
435
sources_non_forked/syntastic/syntax_checkers/java/javac.vim
Normal file
435
sources_non_forked/syntastic/syntax_checkers/java/javac.vim
Normal file
|
@ -0,0 +1,435 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: javac.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Jochen Keil <jochen.keil at gmail dot com>
|
||||||
|
" Dmitry Geurkov <d.geurkov at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_java_javac_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_java_javac_checker = 1
|
||||||
|
let g:syntastic_java_javac_maven_pom_tags = ['build', 'properties']
|
||||||
|
let g:syntastic_java_javac_maven_pom_properties = {}
|
||||||
|
let s:has_maven = 0
|
||||||
|
|
||||||
|
" Global Options
|
||||||
|
if !exists('g:syntastic_java_javac_executable')
|
||||||
|
let g:syntastic_java_javac_executable = 'javac'
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_java_maven_executable')
|
||||||
|
let g:syntastic_java_maven_executable = 'mvn'
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_java_javac_options')
|
||||||
|
let g:syntastic_java_javac_options = '-Xlint'
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_java_maven_options')
|
||||||
|
let g:syntastic_java_maven_options = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_java_javac_classpath')
|
||||||
|
let g:syntastic_java_javac_classpath = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_java_javac_delete_output')
|
||||||
|
let g:syntastic_java_javac_delete_output = 1
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! s:CygwinPath(path)
|
||||||
|
return substitute(system('cygpath -m ' . syntastic#util#shescape(a:path)), "\n", '', 'g')
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
if !exists('g:syntastic_java_javac_temp_dir')
|
||||||
|
if has('win32') || has('win64')
|
||||||
|
let g:syntastic_java_javac_temp_dir = $TEMP . syntastic#util#Slash() . 'vim-syntastic-javac'
|
||||||
|
elseif has('win32unix')
|
||||||
|
let g:syntastic_java_javac_temp_dir = s:CygwinPath('/tmp/vim-syntastic-javac')
|
||||||
|
elseif $TMPDIR != ''
|
||||||
|
let g:syntastic_java_javac_temp_dir = $TMPDIR . '/vim-syntastic-javac'
|
||||||
|
else
|
||||||
|
let g:syntastic_java_javac_temp_dir = '/tmp/vim-syntastic-javac'
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_java_javac_autoload_maven_classpath')
|
||||||
|
let g:syntastic_java_javac_autoload_maven_classpath = 1
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_java_javac_config_file_enabled')
|
||||||
|
let g:syntastic_java_javac_config_file_enabled = 0
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_java_javac_config_file')
|
||||||
|
let g:syntastic_java_javac_config_file = '.syntastic_javac_config'
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_java_javac_custom_classpath_command')
|
||||||
|
let g:syntastic_java_javac_custom_classpath_command = ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_java_javac_maven_pom_ftime')
|
||||||
|
let g:syntastic_java_javac_maven_pom_ftime = {}
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:syntastic_java_javac_maven_pom_classpath')
|
||||||
|
let g:syntastic_java_javac_maven_pom_classpath = {}
|
||||||
|
endif
|
||||||
|
|
||||||
|
function! s:RemoveCarriageReturn(line)
|
||||||
|
return substitute(a:line, "\r", '', 'g')
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
" recursively remove directory and all it's sub-directories
|
||||||
|
function! s:RemoveDir(dir)
|
||||||
|
if isdirectory(a:dir)
|
||||||
|
for f in split(globpath(a:dir, '*'), "\n")
|
||||||
|
call s:RemoveDir(f)
|
||||||
|
endfor
|
||||||
|
silent! call system('rmdir ' . syntastic#util#shescape(a:dir))
|
||||||
|
else
|
||||||
|
silent! call delete(a:dir)
|
||||||
|
endif
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:ClassSep()
|
||||||
|
return (syntastic#util#isRunningWindows() || has('win32unix')) ? ';' : ':'
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:AddToClasspath(classpath, path)
|
||||||
|
if a:path == ''
|
||||||
|
return a:classpath
|
||||||
|
endif
|
||||||
|
return (a:classpath != '') ? a:classpath . s:ClassSep() . a:path : a:path
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:SplitClasspath(classpath)
|
||||||
|
return split(a:classpath, s:ClassSep())
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:LoadConfigFile()
|
||||||
|
if filereadable(expand(g:syntastic_java_javac_config_file))
|
||||||
|
exe 'source ' . fnameescape(expand(g:syntastic_java_javac_config_file))
|
||||||
|
endif
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:SaveClasspath()
|
||||||
|
" build classpath from lines
|
||||||
|
let path = ''
|
||||||
|
let lines = getline(1, line('$'))
|
||||||
|
for l in lines
|
||||||
|
let path = s:AddToClasspath(path, l)
|
||||||
|
endfor
|
||||||
|
" save classpath to config file
|
||||||
|
if g:syntastic_java_javac_config_file_enabled
|
||||||
|
if filereadable(expand(g:syntastic_java_javac_config_file))
|
||||||
|
" load lines from config file
|
||||||
|
let lines = readfile(expand(g:syntastic_java_javac_config_file))
|
||||||
|
" strip g:syntastic_java_javac_classpath options from config file lines
|
||||||
|
let i = 0
|
||||||
|
while i < len(lines)
|
||||||
|
if match(lines[i], 'g:syntastic_java_javac_classpath') != -1
|
||||||
|
call remove(lines, i)
|
||||||
|
else
|
||||||
|
let i += 1
|
||||||
|
endif
|
||||||
|
endwhile
|
||||||
|
else
|
||||||
|
let lines = []
|
||||||
|
endif
|
||||||
|
" add new g:syntastic_java_javac_classpath option to config
|
||||||
|
call add(lines, 'let g:syntastic_java_javac_classpath = ' . string(path))
|
||||||
|
" save config file lines
|
||||||
|
call writefile(lines, expand(g:syntastic_java_javac_config_file))
|
||||||
|
endif
|
||||||
|
" set new classpath
|
||||||
|
let g:syntastic_java_javac_classpath = path
|
||||||
|
let &modified = 0
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:EditClasspath()
|
||||||
|
let command = 'syntastic javac classpath'
|
||||||
|
let winnr = bufwinnr('^' . command . '$')
|
||||||
|
if winnr < 0
|
||||||
|
let path = []
|
||||||
|
let pathlines = split(g:syntastic_java_javac_classpath, "\n")
|
||||||
|
for p in pathlines
|
||||||
|
call extend(path, s:SplitClasspath(p))
|
||||||
|
endfor
|
||||||
|
execute (len(path) + 5) . 'sp ' . fnameescape(command)
|
||||||
|
|
||||||
|
augroup syntastic
|
||||||
|
autocmd BufWriteCmd <buffer> call s:SaveClasspath() | bwipeout
|
||||||
|
augroup END
|
||||||
|
|
||||||
|
setlocal buftype=acwrite bufhidden=wipe nobuflisted noswapfile nowrap number
|
||||||
|
for p in path
|
||||||
|
call append(line('$') - 1, p)
|
||||||
|
endfor
|
||||||
|
let &modified = 0
|
||||||
|
else
|
||||||
|
execute winnr . 'wincmd w'
|
||||||
|
endif
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:SaveConfig()
|
||||||
|
" get lines
|
||||||
|
let lines = getline(1, line('$'))
|
||||||
|
if g:syntastic_java_javac_config_file_enabled
|
||||||
|
" save config file lines
|
||||||
|
call writefile(lines, expand(g:syntastic_java_javac_config_file))
|
||||||
|
endif
|
||||||
|
let &modified = 0
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:EditConfig()
|
||||||
|
let command = 'syntastic javac config'
|
||||||
|
let winnr = bufwinnr('^' . command . '$')
|
||||||
|
if winnr < 0
|
||||||
|
let lines = []
|
||||||
|
if filereadable(expand(g:syntastic_java_javac_config_file))
|
||||||
|
let lines = readfile(expand(g:syntastic_java_javac_config_file))
|
||||||
|
endif
|
||||||
|
execute (len(lines) + 5) . 'sp ' . fnameescape(command)
|
||||||
|
|
||||||
|
augroup syntastic
|
||||||
|
autocmd BufWriteCmd <buffer> call s:SaveConfig() | bwipeout
|
||||||
|
augroup END
|
||||||
|
|
||||||
|
setlocal ft=vim buftype=acwrite bufhidden=wipe nobuflisted noswapfile nowrap number
|
||||||
|
for l in lines
|
||||||
|
call append(line('$') - 1, l)
|
||||||
|
endfor
|
||||||
|
let &modified = 0
|
||||||
|
else
|
||||||
|
execute winnr . 'wincmd w'
|
||||||
|
endif
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:GetMavenProperties()
|
||||||
|
let mvn_properties = {}
|
||||||
|
let pom = findfile('pom.xml', '.;')
|
||||||
|
if s:has_maven && filereadable(pom)
|
||||||
|
if !has_key(g:syntastic_java_javac_maven_pom_properties, pom)
|
||||||
|
let mvn_cmd = syntastic#util#shexpand(g:syntastic_java_maven_executable) .
|
||||||
|
\ ' -f ' . syntastic#util#shescape(pom) .
|
||||||
|
\ ' ' . g:syntastic_java_maven_options
|
||||||
|
let mvn_is_managed_tag = 1
|
||||||
|
let mvn_settings_output = split(system(mvn_cmd . ' help:effective-pom'), "\n")
|
||||||
|
let current_path = 'project'
|
||||||
|
for line in mvn_settings_output
|
||||||
|
let matches = matchlist(line, '\m^\s*<\([a-zA-Z0-9\-\.]\+\)>\s*$')
|
||||||
|
if mvn_is_managed_tag && !empty(matches)
|
||||||
|
let mvn_is_managed_tag = index(g:syntastic_java_javac_maven_pom_tags, matches[1]) >= 0
|
||||||
|
let current_path .= '.' . matches[1]
|
||||||
|
else
|
||||||
|
let matches = matchlist(line, '\m^\s*</\([a-zA-Z0-9\-\.]\+\)>\s*$')
|
||||||
|
if !empty(matches)
|
||||||
|
let mvn_is_managed_tag = index(g:syntastic_java_javac_maven_pom_tags, matches[1]) < 0
|
||||||
|
let current_path = substitute(current_path, '\m\.' . matches[1] . '$', '', '')
|
||||||
|
else
|
||||||
|
let matches = matchlist(line, '\m^\s*<\([a-zA-Z0-9\-\.]\+\)>\(.\+\)</[a-zA-Z0-9\-\.]\+>\s*$')
|
||||||
|
if mvn_is_managed_tag && !empty(matches)
|
||||||
|
let mvn_properties[current_path . '.' . matches[1]] = matches[2]
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
let g:syntastic_java_javac_maven_pom_properties[pom] = mvn_properties
|
||||||
|
endif
|
||||||
|
return g:syntastic_java_javac_maven_pom_properties[pom]
|
||||||
|
endif
|
||||||
|
return mvn_properties
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
command! SyntasticJavacEditClasspath call s:EditClasspath()
|
||||||
|
|
||||||
|
if g:syntastic_java_javac_config_file_enabled
|
||||||
|
command! SyntasticJavacEditConfig call s:EditConfig()
|
||||||
|
endif
|
||||||
|
|
||||||
|
function! s:GetMavenClasspath()
|
||||||
|
let pom = findfile('pom.xml', '.;')
|
||||||
|
if s:has_maven && filereadable(pom)
|
||||||
|
if !has_key(g:syntastic_java_javac_maven_pom_ftime, pom) || g:syntastic_java_javac_maven_pom_ftime[pom] != getftime(pom)
|
||||||
|
let mvn_cmd = syntastic#util#shexpand(g:syntastic_java_maven_executable) .
|
||||||
|
\ ' -f ' . syntastic#util#shescape(pom) .
|
||||||
|
\ ' ' . g:syntastic_java_maven_options
|
||||||
|
let mvn_classpath_output = split(system(mvn_cmd . ' dependency:build-classpath'), "\n")
|
||||||
|
let mvn_classpath = ''
|
||||||
|
let class_path_next = 0
|
||||||
|
|
||||||
|
for line in mvn_classpath_output
|
||||||
|
if class_path_next == 1
|
||||||
|
let mvn_classpath = s:RemoveCarriageReturn(line)
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
if stridx(line, 'Dependencies classpath:') >= 0
|
||||||
|
let class_path_next = 1
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
let mvn_properties = s:GetMavenProperties()
|
||||||
|
|
||||||
|
let output_dir = 'target/classes'
|
||||||
|
if has_key(mvn_properties, 'project.build.outputDirectory')
|
||||||
|
let output_dir = mvn_properties['project.build.outputDirectory']
|
||||||
|
endif
|
||||||
|
let mvn_classpath = s:AddToClasspath(mvn_classpath, output_dir)
|
||||||
|
|
||||||
|
let test_output_dir = 'target/test-classes'
|
||||||
|
if has_key(mvn_properties, 'project.build.testOutputDirectory')
|
||||||
|
let test_output_dir = mvn_properties['project.build.testOutputDirectory']
|
||||||
|
endif
|
||||||
|
let mvn_classpath = s:AddToClasspath(mvn_classpath, test_output_dir)
|
||||||
|
|
||||||
|
let g:syntastic_java_javac_maven_pom_ftime[pom] = getftime(pom)
|
||||||
|
let g:syntastic_java_javac_maven_pom_classpath[pom] = mvn_classpath
|
||||||
|
endif
|
||||||
|
return g:syntastic_java_javac_maven_pom_classpath[pom]
|
||||||
|
endif
|
||||||
|
return ''
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_java_javac_IsAvailable() dict
|
||||||
|
let s:has_maven = executable(expand(g:syntastic_java_maven_executable))
|
||||||
|
return executable(expand(g:syntastic_java_javac_executable))
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:MavenOutputDirectory()
|
||||||
|
let pom = findfile('pom.xml', '.;')
|
||||||
|
if s:has_maven && filereadable(pom)
|
||||||
|
let mvn_properties = s:GetMavenProperties()
|
||||||
|
let output_dir = getcwd()
|
||||||
|
if has_key(mvn_properties, 'project.properties.build.dir')
|
||||||
|
let output_dir = mvn_properties['project.properties.build.dir']
|
||||||
|
endif
|
||||||
|
if stridx(expand( '%:p:h' ), 'src.main.java') >= 0
|
||||||
|
let output_dir .= '/target/classes'
|
||||||
|
if has_key(mvn_properties, 'project.build.outputDirectory')
|
||||||
|
let output_dir = mvn_properties['project.build.outputDirectory']
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
if stridx(expand( '%:p:h' ), 'src.test.java') >= 0
|
||||||
|
let output_dir .= '/target/test-classes'
|
||||||
|
if has_key(mvn_properties, 'project.build.testOutputDirectory')
|
||||||
|
let output_dir = mvn_properties['project.build.testOutputDirectory']
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has('win32unix')
|
||||||
|
let output_dir = s:CygwinPath(output_dir)
|
||||||
|
endif
|
||||||
|
return output_dir
|
||||||
|
endif
|
||||||
|
return '.'
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_java_javac_GetLocList() dict
|
||||||
|
let javac_opts = g:syntastic_java_javac_options
|
||||||
|
|
||||||
|
let output_dir = ''
|
||||||
|
if g:syntastic_java_javac_delete_output
|
||||||
|
let output_dir = g:syntastic_java_javac_temp_dir
|
||||||
|
let javac_opts .= ' -d ' . syntastic#util#shescape(output_dir)
|
||||||
|
endif
|
||||||
|
|
||||||
|
" load classpath from config file
|
||||||
|
if g:syntastic_java_javac_config_file_enabled
|
||||||
|
call s:LoadConfigFile()
|
||||||
|
endif
|
||||||
|
|
||||||
|
let javac_classpath = ''
|
||||||
|
|
||||||
|
" add classpathes to javac_classpath
|
||||||
|
for path in split(g:syntastic_java_javac_classpath, s:ClassSep())
|
||||||
|
if path != ''
|
||||||
|
try
|
||||||
|
let ps = glob(path, 0, 1)
|
||||||
|
catch
|
||||||
|
let ps = split(glob(path, 0), "\n")
|
||||||
|
endtry
|
||||||
|
if type(ps) == type([])
|
||||||
|
for p in ps
|
||||||
|
let javac_classpath = s:AddToClasspath(javac_classpath, p)
|
||||||
|
endfor
|
||||||
|
else
|
||||||
|
let javac_classpath = s:AddToClasspath(javac_classpath, ps)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
if s:has_maven && g:syntastic_java_javac_autoload_maven_classpath
|
||||||
|
if !g:syntastic_java_javac_delete_output
|
||||||
|
let javac_opts .= ' -d ' . syntastic#util#shescape(s:MavenOutputDirectory())
|
||||||
|
endif
|
||||||
|
let javac_classpath = s:AddToClasspath(javac_classpath, s:GetMavenClasspath())
|
||||||
|
endif
|
||||||
|
|
||||||
|
" load custom classpath
|
||||||
|
if g:syntastic_java_javac_custom_classpath_command != ''
|
||||||
|
let lines = system(g:syntastic_java_javac_custom_classpath_command)
|
||||||
|
if syntastic#util#isRunningWindows() || has('win32unix')
|
||||||
|
let lines = substitute(lines, "\r\n", "\n", 'g')
|
||||||
|
endif
|
||||||
|
for l in split(lines, "\n")
|
||||||
|
let javac_classpath = s:AddToClasspath(javac_classpath, l)
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
|
||||||
|
if javac_classpath != ''
|
||||||
|
let javac_opts .= ' -cp ' . syntastic#util#shexpand(javac_classpath)
|
||||||
|
endif
|
||||||
|
|
||||||
|
let fname = expand('%:p:h') . syntastic#util#Slash() . expand ('%:t')
|
||||||
|
|
||||||
|
if has('win32unix')
|
||||||
|
let fname = s:CygwinPath(fname)
|
||||||
|
endif
|
||||||
|
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'args': javac_opts,
|
||||||
|
\ 'fname': syntastic#util#shescape(fname) })
|
||||||
|
|
||||||
|
" unashamedly stolen from *errorformat-javac* (quickfix.txt) and modified to include error types
|
||||||
|
let errorformat =
|
||||||
|
\ '%E%f:%l:\ error:\ %m,'.
|
||||||
|
\ '%W%f:%l:\ warning:\ %m,'.
|
||||||
|
\ '%A%f:%l:\ %m,'.
|
||||||
|
\ '%+Z%p^,'.
|
||||||
|
\ '%+C%.%#,'.
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
if g:syntastic_java_javac_delete_output
|
||||||
|
silent! call mkdir(output_dir, 'p')
|
||||||
|
endif
|
||||||
|
let errors = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'postprocess': ['cygwinRemoveCR'] })
|
||||||
|
|
||||||
|
if g:syntastic_java_javac_delete_output
|
||||||
|
call s:RemoveDir(output_dir)
|
||||||
|
endif
|
||||||
|
return errors
|
||||||
|
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'java',
|
||||||
|
\ 'name': 'javac'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,64 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: closurecompiler.vim
|
||||||
|
"Description: Javascript syntax checker - using Google Closure Compiler
|
||||||
|
"Maintainer: Motohiro Takayama <mootoh at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_javascript_closurecompiler_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_javascript_closurecompiler_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_javascript_closurecompiler_IsAvailable() dict
|
||||||
|
call syntastic#log#deprecationWarn('javascript_closure_compiler_path', 'javascript_closurecompiler_path')
|
||||||
|
|
||||||
|
return
|
||||||
|
\ executable("java") &&
|
||||||
|
\ exists("g:syntastic_javascript_closurecompiler_path") &&
|
||||||
|
\ filereadable(g:syntastic_javascript_closurecompiler_path)
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_javascript_closurecompiler_GetLocList() dict
|
||||||
|
call syntastic#log#deprecationWarn('javascript_closure_compiler_options', 'javascript_closurecompiler_args')
|
||||||
|
call syntastic#log#deprecationWarn('javascript_closure_compiler_file_list', 'javascript_closurecompiler_file_list')
|
||||||
|
|
||||||
|
if exists("g:syntastic_javascript_closurecompiler_file_list")
|
||||||
|
let file_list = join(readfile(g:syntastic_javascript_closurecompiler_file_list))
|
||||||
|
else
|
||||||
|
let file_list = syntastic#util#shexpand('%')
|
||||||
|
endif
|
||||||
|
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'exe_after': '-jar ' . g:syntastic_javascript_closurecompiler_path,
|
||||||
|
\ 'args_after': '--js' ,
|
||||||
|
\ 'fname': file_list })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%-GOK,'.
|
||||||
|
\ '%E%f:%l: ERROR - %m,'.
|
||||||
|
\ '%Z%p^,'.
|
||||||
|
\ '%W%f:%l: WARNING - %m,'.
|
||||||
|
\ '%Z%p^'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'javascript',
|
||||||
|
\ 'name': 'closurecompiler',
|
||||||
|
\ 'exec': 'java'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,56 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: eslint.vim
|
||||||
|
"Description: Javascript syntax checker - using eslint
|
||||||
|
"Maintainer: Maksim Ryzhikov <rv.maksim at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_javascript_eslint_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_javascript_eslint_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_javascript_eslint_IsAvailable() dict
|
||||||
|
return
|
||||||
|
\ executable(self.getExec()) &&
|
||||||
|
\ syntastic#util#versionIsAtLeast(syntastic#util#getVersion(self.getExecEscaped() . ' --version'), [0, 1])
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_javascript_eslint_GetLocList() dict
|
||||||
|
call syntastic#log#deprecationWarn('javascript_eslint_conf', 'javascript_eslint_args',
|
||||||
|
\ "'--config ' . syntastic#util#shexpand(OLD_VAR)")
|
||||||
|
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_before': '-f compact' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%E%f: line %l\, col %c\, Error - %m,' .
|
||||||
|
\ '%W%f: line %l\, col %c\, Warning - %m'
|
||||||
|
|
||||||
|
let loclist = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
|
||||||
|
for e in loclist
|
||||||
|
let e['col'] += 1
|
||||||
|
endfor
|
||||||
|
|
||||||
|
call self.setWantSort(1)
|
||||||
|
|
||||||
|
return loclist
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'javascript',
|
||||||
|
\ 'name': 'eslint'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,45 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: gjslint.vim
|
||||||
|
"Description: Javascript syntax checker - using gjslint
|
||||||
|
"Maintainer: Martin Grenfell <martin.grenfell at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_javascript_gjslint_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_javascript_gjslint_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_javascript_gjslint_GetLocList() dict
|
||||||
|
call syntastic#log#deprecationWarn('javascript_gjslint_conf', 'javascript_gjslint_args')
|
||||||
|
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'args_after': '--nosummary --unix_mode --nodebug_indentation --nobeep' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ "%f:%l:(New Error -%\\?\%n) %m," .
|
||||||
|
\ "%f:%l:(-%\\?%n) %m," .
|
||||||
|
\ "%-G1 files checked," .
|
||||||
|
\ " no errors found.," .
|
||||||
|
\ "%-G%.%#"
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'javascript',
|
||||||
|
\ 'name': 'gjslint'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,44 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: jscs.vim
|
||||||
|
"Description: Javascript syntax checker - using jscs
|
||||||
|
"Maintainer: LCD 47 <lcd047@gmail.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_javascript_jscs_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_javascript_jscs_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_javascript_jscs_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': '--no-colors --reporter checkstyle' })
|
||||||
|
|
||||||
|
let errorformat = '%f:%t:%l:%c:%m'
|
||||||
|
|
||||||
|
let loclist = SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'subtype': 'Style',
|
||||||
|
\ 'preprocess': 'checkstyle',
|
||||||
|
\ 'returns': [0, 2] })
|
||||||
|
|
||||||
|
call self.setWantSort(1)
|
||||||
|
|
||||||
|
return loclist
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'javascript',
|
||||||
|
\ 'name': 'jscs'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,59 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: jshint.vim
|
||||||
|
"Description: Javascript syntax checker - using jshint
|
||||||
|
"Maintainer: Martin Grenfell <martin.grenfell at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_javascript_jshint_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_javascript_jshint_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_javascript_jshint_IsAvailable() dict
|
||||||
|
call syntastic#log#deprecationWarn('jshint_exec', 'javascript_jshint_exec')
|
||||||
|
if !executable(self.getExec())
|
||||||
|
return 0
|
||||||
|
endif
|
||||||
|
let s:jshint_version = syntastic#util#getVersion(self.getExecEscaped() . ' --version')
|
||||||
|
return syntastic#util#versionIsAtLeast(s:jshint_version, [1])
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_javascript_jshint_GetLocList() dict
|
||||||
|
call syntastic#log#deprecationWarn('javascript_jshint_conf', 'javascript_jshint_args',
|
||||||
|
\ "'--config ' . syntastic#util#shexpand(OLD_VAR)")
|
||||||
|
|
||||||
|
if !exists('s:jshint_new')
|
||||||
|
let s:jshint_new = syntastic#util#versionIsAtLeast(s:jshint_version, [1, 1])
|
||||||
|
endif
|
||||||
|
|
||||||
|
let makeprg = self.makeprgBuild({ 'args_after': (s:jshint_new ? '--verbose ' : '') })
|
||||||
|
|
||||||
|
let errorformat = s:jshint_new ?
|
||||||
|
\ '%A%f: line %l\, col %v\, %m \(%t%*\d\)' :
|
||||||
|
\ '%E%f: line %l\, col %v\, %m'
|
||||||
|
|
||||||
|
call self.setWantSort(1)
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr('')},
|
||||||
|
\ 'returns': [0, 2] })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'javascript',
|
||||||
|
\ 'name': 'jshint'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,48 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: jsl.vim
|
||||||
|
"Description: Javascript syntax checker - using jsl
|
||||||
|
"Maintainer: Martin Grenfell <martin.grenfell at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_javascript_jsl_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_javascript_jsl_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_javascript_jsl_GetLocList() dict
|
||||||
|
call syntastic#log#deprecationWarn('javascript_jsl_conf', 'javascript_jsl_args',
|
||||||
|
\ "'-conf ' . syntastic#util#shexpand(OLD_VAR)")
|
||||||
|
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'args_after': '-nologo -nofilelisting -nosummary -nocontext -process' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%W%f(%l): lint warning: %m,'.
|
||||||
|
\ '%-Z%p^,'.
|
||||||
|
\ '%W%f(%l): warning: %m,'.
|
||||||
|
\ '%-Z%p^,'.
|
||||||
|
\ '%E%f(%l): SyntaxError: %m,'.
|
||||||
|
\ '%-Z%p^,'.
|
||||||
|
\ '%-G'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'javascript',
|
||||||
|
\ 'name': 'jsl'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,51 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: jslint.vim
|
||||||
|
"Description: Javascript syntax checker - using jslint
|
||||||
|
"Maintainer: Martin Grenfell <martin.grenfell at gmail dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"Tested with jslint 0.1.4.
|
||||||
|
"============================================================================
|
||||||
|
if exists("g:loaded_syntastic_javascript_jslint_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
|
||||||
|
let g:loaded_syntastic_javascript_jslint_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_javascript_jslint_GetHighlightRegex(item)
|
||||||
|
let term = matchstr(a:item['text'], '\mExpected .* and instead saw ''\zs.*\ze''')
|
||||||
|
if term != ''
|
||||||
|
let term = '\V\<' . escape(term, '\') . '\>'
|
||||||
|
endif
|
||||||
|
return term
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_javascript_jslint_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'args': '--white --nomen --regexp --plusplus --bitwise --newcap --sloppy --vars' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%E %##%\d%\+ %m,'.
|
||||||
|
\ '%-Z%.%#Line %l\, Pos %c,'.
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr("")} })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'javascript',
|
||||||
|
\ 'name': 'jslint'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,47 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: jsxhint.vim
|
||||||
|
"Description: Javascript syntax checker - using jsxhint
|
||||||
|
"Maintainer: Thomas Boyt <me@thomasboyt.com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists('g:loaded_syntastic_javascript_jsxhint_checker')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_javascript_jsxhint_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_javascript_jsxhint_IsAvailable() dict
|
||||||
|
let jsxhint_version = system(self.getExecEscaped() . ' --version')
|
||||||
|
return
|
||||||
|
\ v:shell_error == 0 &&
|
||||||
|
\ jsxhint_version =~# '\m^JSXHint\>' &&
|
||||||
|
\ syntastic#util#versionIsAtLeast(syntastic#util#parseVersion(jsxhint_version), [0, 4, 1])
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_javascript_jsxhint_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'args_after': '--verbose' })
|
||||||
|
|
||||||
|
let errorformat = '%A%f: line %l\, col %v\, %m \(%t%*\d\)'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr('')} })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'javascript',
|
||||||
|
\ 'name': 'jsxhint'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,43 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: jsonlint.vim
|
||||||
|
"Description: JSON syntax checker - using jsonlint
|
||||||
|
"Maintainer: Miller Medeiros <contact at millermedeiros dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_json_jsonlint_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_json_jsonlint_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_json_jsonlint_GetLocList() dict
|
||||||
|
let makeprg = self.makeprgBuild({ 'post_args_after': '--compact' })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%ELine %l:%c,'.
|
||||||
|
\ '%Z\\s%#Reason: %m,'.
|
||||||
|
\ '%C%.%#,'.
|
||||||
|
\ '%f: line %l\, col %c\, %m,'.
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr('')} })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'json',
|
||||||
|
\ 'name': 'jsonlint'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,41 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: jsonval.vim
|
||||||
|
"Description: JSON syntax checker - using jsonval
|
||||||
|
"Maintainer: Miller Medeiros <contact at millermedeiros dot com>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_json_jsonval_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_json_jsonval_checker = 1
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
function! SyntaxCheckers_json_jsonval_GetLocList() dict
|
||||||
|
" based on https://gist.github.com/1196345
|
||||||
|
let makeprg = self.makeprgBuild({})
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%E%f:\ %m\ at\ line\ %l,' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr('')} })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'json',
|
||||||
|
\ 'name': 'jsonval'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
|
@ -0,0 +1,41 @@
|
||||||
|
#!/usr/bin/env node
|
||||||
|
|
||||||
|
fs = require 'fs'
|
||||||
|
less = require 'less'
|
||||||
|
args = process.argv.slice(1)
|
||||||
|
options = {}
|
||||||
|
|
||||||
|
args = args.filter (arg) ->
|
||||||
|
match = arg.match(/^-I(.+)$/)
|
||||||
|
if match
|
||||||
|
options.paths.push(match[1]);
|
||||||
|
return false
|
||||||
|
|
||||||
|
match = arg.match(/^--?([a-z][\-0-9a-z]*)(?:=([^\s]+))?$/i)
|
||||||
|
if match
|
||||||
|
arg = match[1]
|
||||||
|
else
|
||||||
|
return arg
|
||||||
|
|
||||||
|
switch arg
|
||||||
|
when 'strict-imports' then options.strictImports = true
|
||||||
|
when 'include-path'
|
||||||
|
options.paths = match[2].split(if os.type().match(/Windows/) then ';' else ':')
|
||||||
|
.map (p) ->
|
||||||
|
if p
|
||||||
|
return path.resolve(process.cwd(), p)
|
||||||
|
when 'O0' then options.optimization = 0
|
||||||
|
when 'O1' then options.optimization = 1
|
||||||
|
when 'O2' then options.optimization = 2
|
||||||
|
|
||||||
|
options.filename = args[1]
|
||||||
|
|
||||||
|
parser = new(less.Parser) options
|
||||||
|
|
||||||
|
fs.readFile(options.filename, 'utf-8', (err,data) ->
|
||||||
|
parser.parse(data, (err, tree) ->
|
||||||
|
if err
|
||||||
|
less.writeError err
|
||||||
|
process.exit(1)
|
||||||
|
)
|
||||||
|
)
|
|
@ -0,0 +1,57 @@
|
||||||
|
// Generated by CoffeeScript 1.3.3
|
||||||
|
(function() {
|
||||||
|
var args, fs, less, options, parser;
|
||||||
|
|
||||||
|
fs = require('fs');
|
||||||
|
|
||||||
|
less = require('less');
|
||||||
|
|
||||||
|
args = process.argv.slice(1);
|
||||||
|
|
||||||
|
options = {};
|
||||||
|
|
||||||
|
args = args.filter(function(arg) {
|
||||||
|
var match;
|
||||||
|
match = arg.match(/^-I(.+)$/);
|
||||||
|
if (match) {
|
||||||
|
options.paths.push(match[1]);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
match = arg.match(/^--?([a-z][\-0-9a-z]*)(?:=([^\s]+))?$/i);
|
||||||
|
if (match) {
|
||||||
|
arg = match[1];
|
||||||
|
} else {
|
||||||
|
return arg;
|
||||||
|
}
|
||||||
|
switch (arg) {
|
||||||
|
case 'strict-imports':
|
||||||
|
return options.strictImports = true;
|
||||||
|
case 'include-path':
|
||||||
|
return options.paths = match[2].split(os.type().match(/Windows/) ? ';' : ':').map(function(p) {
|
||||||
|
if (p) {
|
||||||
|
return path.resolve(process.cwd(), p);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
case 'O0':
|
||||||
|
return options.optimization = 0;
|
||||||
|
case 'O1':
|
||||||
|
return options.optimization = 1;
|
||||||
|
case 'O2':
|
||||||
|
return options.optimization = 2;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
options.filename = args[1];
|
||||||
|
|
||||||
|
parser = new less.Parser(options);
|
||||||
|
|
||||||
|
fs.readFile(options.filename, 'utf-8', function(err, data) {
|
||||||
|
return parser.parse(data, function(err, tree) {
|
||||||
|
if (err) {
|
||||||
|
less.writeError(err);
|
||||||
|
return process.exit(1);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
}).call(this);
|
71
sources_non_forked/syntastic/syntax_checkers/less/lessc.vim
Normal file
71
sources_non_forked/syntastic/syntax_checkers/less/lessc.vim
Normal file
|
@ -0,0 +1,71 @@
|
||||||
|
"============================================================================
|
||||||
|
"File: less.vim
|
||||||
|
"Description: Syntax checking plugin for syntastic.vim
|
||||||
|
"Maintainer: Julien Blanchard <julien at sideburns dot eu>
|
||||||
|
"License: This program is free software. It comes without any warranty,
|
||||||
|
" to the extent permitted by applicable law. You can redistribute
|
||||||
|
" it and/or modify it under the terms of the Do What The Fuck You
|
||||||
|
" Want To Public License, Version 2, as published by Sam Hocevar.
|
||||||
|
" See http://sam.zoy.org/wtfpl/COPYING for more details.
|
||||||
|
"
|
||||||
|
"============================================================================
|
||||||
|
|
||||||
|
" To send additional options to less use the variable g:syntastic_less_options.
|
||||||
|
" The default is
|
||||||
|
" let g:syntastic_less_options = "--no-color"
|
||||||
|
"
|
||||||
|
" To use less-lint instead of less set the variable
|
||||||
|
" g:syntastic_less_use_less_lint.
|
||||||
|
|
||||||
|
if exists("g:loaded_syntastic_less_lessc_checker")
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
let g:loaded_syntastic_less_lessc_checker = 1
|
||||||
|
|
||||||
|
if !exists("g:syntastic_less_options")
|
||||||
|
let g:syntastic_less_options = ""
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists("g:syntastic_less_use_less_lint")
|
||||||
|
let g:syntastic_less_use_less_lint = 0
|
||||||
|
endif
|
||||||
|
|
||||||
|
let s:save_cpo = &cpo
|
||||||
|
set cpo&vim
|
||||||
|
|
||||||
|
let s:node_file = 'node ' . syntastic#util#shescape(expand('<sfile>:p:h') . syntastic#util#Slash() . 'less-lint.js')
|
||||||
|
|
||||||
|
function! SyntaxCheckers_less_lessc_IsAvailable() dict
|
||||||
|
return g:syntastic_less_use_less_lint ? executable('node') : executable(self.getExec())
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! SyntaxCheckers_less_lessc_GetLocList() dict
|
||||||
|
if !exists('s:check_file')
|
||||||
|
let s:check_file = g:syntastic_less_use_less_lint ? s:node_file : self.getExecEscaped()
|
||||||
|
endif
|
||||||
|
|
||||||
|
let makeprg = self.makeprgBuild({
|
||||||
|
\ 'exe': s:check_file,
|
||||||
|
\ 'args': g:syntastic_less_options,
|
||||||
|
\ 'args_after': '--no-color',
|
||||||
|
\ 'tail': '> ' . syntastic#util#DevNull() })
|
||||||
|
|
||||||
|
let errorformat =
|
||||||
|
\ '%m in %f on line %l\, column %c:,' .
|
||||||
|
\ '%m in %f:%l:%c,' .
|
||||||
|
\ '%-G%.%#'
|
||||||
|
|
||||||
|
return SyntasticMake({
|
||||||
|
\ 'makeprg': makeprg,
|
||||||
|
\ 'errorformat': errorformat,
|
||||||
|
\ 'defaults': {'bufnr': bufnr(""), 'text': "Syntax error"} })
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
||||||
|
\ 'filetype': 'less',
|
||||||
|
\ 'name': 'lessc'})
|
||||||
|
|
||||||
|
let &cpo = s:save_cpo
|
||||||
|
unlet s:save_cpo
|
||||||
|
|
||||||
|
" vim: set et sts=4 sw=4:
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue