Several changes to vim and i3
This commit is contained in:
parent
502a49e811
commit
f482f452e9
.gitmodules
i3/conf/client
vim
config
plugins
alepydocpython-mode
syntastic
.gitignoreCONTRIBUTING.mdLICENCEREADME.markdown
_assets
autoload/syntastic
doc
plugin
syntastic.vim
syntastic
syntax_checkers
actionscript
ada
ansible
apiblueprint
applescript
asciidoc
asl
asm
bemhtml
bro
c
avrgcc.vimcheckpatch.vimclang_check.vimclang_tidy.vimcppcheck.vimcppclean.vimflawfinder.vimgcc.vimmake.vimoclint.vimpc_lint.vimsparse.vimsplint.vim
cabal
chef
cmake
co
cobol
coffee
coq
cpp
avrgcc.vimclang_check.vimclang_tidy.vimcppcheck.vimcppclean.vimcpplint.vimflawfinder.vimgcc.vimoclint.vimpc_lint.vimverapp.vim
cs
css
cucumber
cuda
d
dart
docbk
dockerfile
dustjs
elixir
erlang
eruby
fortran
glsl
go
12
.gitmodules
vendored
12
.gitmodules
vendored
@ -10,9 +10,6 @@
|
|||||||
[submodule "vim/plugins/supertab"]
|
[submodule "vim/plugins/supertab"]
|
||||||
path = vim/plugins/supertab
|
path = vim/plugins/supertab
|
||||||
url = https://github.com/ervandew/supertab
|
url = https://github.com/ervandew/supertab
|
||||||
[submodule "vim/plugins/syntastic"]
|
|
||||||
path = vim/plugins/syntastic
|
|
||||||
url = https://github.com/vim-syntastic/syntastic.git
|
|
||||||
[submodule "vim/plugins/vim-airline"]
|
[submodule "vim/plugins/vim-airline"]
|
||||||
path = vim/plugins/vim-airline
|
path = vim/plugins/vim-airline
|
||||||
url = https://github.com/vim-airline/vim-airline.git
|
url = https://github.com/vim-airline/vim-airline.git
|
||||||
@ -136,3 +133,12 @@
|
|||||||
[submodule "tmux/plugins/tpm"]
|
[submodule "tmux/plugins/tpm"]
|
||||||
path = tmux/plugins/tpm
|
path = tmux/plugins/tpm
|
||||||
url = https://github.com/tmux-plugins/tpm.git
|
url = https://github.com/tmux-plugins/tpm.git
|
||||||
|
[submodule "vim/plugins/python-mode"]
|
||||||
|
path = vim/plugins/python-mode
|
||||||
|
url = https://github.com/klen/python-mode.git
|
||||||
|
[submodule "vim/plugins/ale"]
|
||||||
|
path = vim/plugins/ale
|
||||||
|
url = https://github.com/w0rp/ale.git
|
||||||
|
[submodule "vim/plugins/pydoc"]
|
||||||
|
path = vim/plugins/pydoc
|
||||||
|
url = https://github.com/fs111/pydoc.vim
|
||||||
|
@ -14,8 +14,10 @@
|
|||||||
exec_always 'i3-msg "workspace number 4; append_layout ~/.layout/ws-4.json"'
|
exec_always 'i3-msg "workspace number 4; append_layout ~/.layout/ws-4.json"'
|
||||||
|
|
||||||
# Mail
|
# Mail
|
||||||
workspace $ws5 gaps outer 0
|
|
||||||
workspace $ws5 gaps inner 0
|
|
||||||
assign [instance="mail"] $ws5
|
assign [instance="mail"] $ws5
|
||||||
# KeepassXC
|
# KeepassXC
|
||||||
assign [class="keepassxc"] $ws10
|
assign [class="keepassxc"] $ws10
|
||||||
|
|
||||||
|
# Morrowind
|
||||||
|
for_window [instance="morrowind.exe"] fullscreen enable
|
||||||
|
assign [instance="morrowind.exe"] $ws1
|
||||||
|
@ -1,16 +1,12 @@
|
|||||||
# {{{ WORKSPACES }}}
|
# {{{ WORKSPACES }}}
|
||||||
|
|
||||||
# Browser
|
# Browser
|
||||||
workspace $ws1 gaps outer 0
|
|
||||||
workspace $ws1 gaps inner 0
|
|
||||||
assign [class="Firefox"] $ws1
|
assign [class="Firefox"] $ws1
|
||||||
|
|
||||||
# Terminal
|
# Terminal
|
||||||
assign [class="URxvt" instance="urxvt"] $ws2
|
assign [class="URxvt" instance="urxvt"] $ws2
|
||||||
|
|
||||||
# Mail
|
# Mail
|
||||||
workspace $ws5 gaps outer 0
|
|
||||||
workspace $ws5 gaps inner 0
|
|
||||||
assign [instance="mail"] $ws5
|
assign [instance="mail"] $ws5
|
||||||
# KeepassXC
|
# KeepassXC
|
||||||
assign [class="keepassxc"] $ws10
|
assign [class="keepassxc"] $ws10
|
||||||
|
@ -85,14 +85,16 @@ let g:SimpylFold_docstring_preview = 1
|
|||||||
let g:SuperTabDefaultCompletionType = "<c-space>"
|
let g:SuperTabDefaultCompletionType = "<c-space>"
|
||||||
|
|
||||||
" Syntastic
|
" Syntastic
|
||||||
let g:syntastic_always_populate_loc_list = 1
|
" let g:syntastic_always_populate_loc_list = 1
|
||||||
let g:syntastic_auto_loc_list = 1
|
" let g:syntastic_auto_loc_list = 1
|
||||||
let g:syntastic_check_on_open = 1
|
" let g:syntastic_check_on_open = 1
|
||||||
let g:syntastic_check_on_wq = 0
|
" let g:syntastic_check_on_wq = 0
|
||||||
let g:syntastic_mode_map={"mode":"active", "active_filetypes": [], "passive_filetypes": ['tex']}
|
" let g:syntastic_mode_map={"mode":"active", "active_filetypes": [], "passive_filetypes": ['tex']}
|
||||||
let g:syntastic_python_checkers=['flake8']
|
" let g:syntastic_python_checkers=['flake8']
|
||||||
let g:syntastic_python_flake8_args='--ignore=E501,E225'
|
" let g:syntastic_python_flake8_args='--ignore=E501,E225'
|
||||||
|
|
||||||
|
" Ale
|
||||||
|
let g:ale_linters = {"python": ["flake8"]}
|
||||||
|
|
||||||
" UltiSnips
|
" UltiSnips
|
||||||
let g:UltiSnipsJumpForwardTrigger="<c-b>"
|
let g:UltiSnipsJumpForwardTrigger="<c-b>"
|
||||||
|
1
vim/plugins/ale
Submodule
1
vim/plugins/ale
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit 3f0e1cd05dc526b073946ad96c64f6a5e2f9e4e6
|
1
vim/plugins/pydoc
Submodule
1
vim/plugins/pydoc
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit 092a195220ff5bb9216ca5c9430256a4448ba708
|
1
vim/plugins/python-mode
Submodule
1
vim/plugins/python-mode
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit 5308d0cc241080057a58c1772ebd254f2922998d
|
4
vim/plugins/syntastic/.gitignore
vendored
4
vim/plugins/syntastic/.gitignore
vendored
@ -1,4 +0,0 @@
|
|||||||
*~
|
|
||||||
*.swp
|
|
||||||
tags
|
|
||||||
.DS_Store
|
|
@ -1,105 +0,0 @@
|
|||||||
# 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][bug_tracker]. 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][manual]. Syntastic is changing
|
|
||||||
rapidly at times, and it's possible that some features you want to add exist
|
|
||||||
already.
|
|
||||||
|
|
||||||
To submit a patch:
|
|
||||||
|
|
||||||
* fork the [repo][github] on GitHub;
|
|
||||||
* make a [topic branch][branches] 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][variables] to
|
|
||||||
aid readability.
|
|
||||||
|
|
||||||
<a name="checkerstyle"></a>
|
|
||||||
|
|
||||||
## 4. Syntax checker notes
|
|
||||||
|
|
||||||
Make sure to read the [guide][guide] 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%.%#'
|
|
||||||
```
|
|
||||||
|
|
||||||
[bug_tracker]: https://github.com/vim-syntastic/syntastic/issues
|
|
||||||
[manual]: https://github.com/vim-syntastic/syntastic/blob/master/doc/syntastic.txt
|
|
||||||
[github]: https://github.com/vim-syntastic/syntastic
|
|
||||||
[branches]: https://github.com/dchelimsky/rspec/wiki/Topic-Branches#using-topic-branches-when-contributing-patches
|
|
||||||
[variables]: http://www.refactoring.com/catalog/extractVariable.html
|
|
||||||
[guide]: https://github.com/vim-syntastic/syntastic/wiki/Syntax-Checker-Guide
|
|
@ -1,13 +0,0 @@
|
|||||||
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.
|
|
@ -1,545 +0,0 @@
|
|||||||
,
|
|
||||||
/ \,,_ .'|
|
|
||||||
,{{| /}}}}/_.' _____________________________________________
|
|
||||||
}}}}` '{{' '. / \
|
|
||||||
{{{{{ _ ;, \ / Ladies and Gentlemen, \
|
|
||||||
,}}}}}} /o`\ ` ;) | |
|
|
||||||
{{{{{{ / ( | this is ... |
|
|
||||||
}}}}}} | \ | |
|
|
||||||
{{{{{{{{ \ \ | |
|
|
||||||
}}}}}}}}} '.__ _ | | _____ __ __ _ |
|
|
||||||
{{{{{{{{ /`._ (_\ / | / ___/__ ______ / /_____ ______/ /_(_)____ |
|
|
||||||
}}}}}}' | //___/ --=: \__ \/ / / / __ \/ __/ __ `/ ___/ __/ / ___/ |
|
|
||||||
jgs `{{{{` | '--' | ___/ / /_/ / / / / /_/ /_/ (__ ) /_/ / /__ |
|
|
||||||
}}}` | /____/\__, /_/ /_/\__/\__,_/____/\__/_/\___/ |
|
|
||||||
| /____/ |
|
|
||||||
| /
|
|
||||||
\_____________________________________________/
|
|
||||||
|
|
||||||
|
|
||||||
- - -
|
|
||||||
1. [Introduction](#introduction)
|
|
||||||
2. [Installation](#installation)
|
|
||||||
2.1. [Requirements](#requirements)
|
|
||||||
2.2. [Installing syntastic with Pathogen](#installpathogen)
|
|
||||||
3. [Recommended settings](#settings)
|
|
||||||
4. [FAQ](#faq)
|
|
||||||
4.1. [I installed syntastic but it isn't reporting any errors...](#faqinfo)
|
|
||||||
4.2. [Syntastic supports several checkers for my filetype, how do I tell it which one(s) to use?](#faqcheckers)
|
|
||||||
4.3. [How can I run checkers for "foreign" filetypes against the current file?](#faqforeign)
|
|
||||||
4.4. [I have enabled multiple checkers for the current filetype. How can I display all errors from all checkers together?](#faqaggregate)
|
|
||||||
4.5. [How can I pass additional arguments to a checker?](#faqargs)
|
|
||||||
4.6. [I run a checker and the location list is not updated...](#faqloclist)
|
|
||||||
4.6. [I run`:lopen` or `:lwindow` and the error window is empty...](#faqloclist)
|
|
||||||
4.7. [How can I jump between the different errors without using the location list at the bottom of the window?](#faqlnext)
|
|
||||||
4.8. [The error window is closed automatically when I `:quit` the current buffer but not when I `:bdelete` it?](#faqbdelete)
|
|
||||||
4.9. [My favourite checker needs to load a configuration file from the project's root rather than the current directory...](#faqconfig)
|
|
||||||
4.10. [What is the difference between syntax checkers and style checkers?](#faqstyle)
|
|
||||||
4.11. [How can I check scripts written for different versions of Python?](#faqpython)
|
|
||||||
4.12. [How can I check scripts written for different versions of Ruby?](#faqruby)
|
|
||||||
4.13. [The `perl` checker has stopped working...](#faqperl)
|
|
||||||
4.14. [What happened to the `rustc` checker?](#faqrust)
|
|
||||||
4.15. [What happened to the `tsc` checker?](#faqtsc)
|
|
||||||
4.16. [What happened to the `xcrun` checker?](#faqxcrun)
|
|
||||||
5. [Resources](#otherresources)
|
|
||||||
|
|
||||||
- - -
|
|
||||||
|
|
||||||
<a name="introduction"></a>
|
|
||||||
|
|
||||||
## 1\. Introduction
|
|
||||||
|
|
||||||
Syntastic is a syntax checking plugin for [Vim][vim] created by
|
|
||||||
[Martin Grenfell][scrooloose]. It 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, syntastic has checking plugins for ACPI
|
|
||||||
Source Language, ActionScript, Ada, Ansible configurations, API Blueprint,
|
|
||||||
AppleScript, AsciiDoc, Assembly languages, BEMHTML, Bro, Bourne shell, C, C++,
|
|
||||||
C#, Cabal, Chef, CMake, CoffeeScript, Coco, Coq, CSS, Cucumber, CUDA, D, Dart,
|
|
||||||
DocBook, Dockerfile, Dust, Elixir, Erlang, eRuby, Fortran, Gentoo metadata,
|
|
||||||
GLSL, Go, Haml, Haskell, Haxe, Handlebars, HSS, HTML, Java, JavaScript,
|
|
||||||
JSON, JSX, Julia, LESS, Lex, Limbo, LISP, LLVM intermediate language, Lua,
|
|
||||||
Markdown, MATLAB, Mercury, NASM, Nix, Objective-C, Objective-C++, OCaml, Perl,
|
|
||||||
Perl POD, PHP, gettext Portable Object, OS X and iOS property lists, Pug
|
|
||||||
(formerly Jade), Puppet, Python, QML, R, Racket, RDF TriG, RDF Turtle, Relax
|
|
||||||
NG, reStructuredText, RPM spec, Ruby, SASS/SCSS, Scala, Slim, SML, Solidity,
|
|
||||||
Sphinx, SQL, Stylus, Tcl, TeX, Texinfo, Twig, TypeScript, Vala, Verilog, VHDL,
|
|
||||||
Vim help, VimL, xHtml, XML, XSLT, XQuery, YACC, YAML, YANG data models, z80,
|
|
||||||
Zope page templates, and Zsh. See the [manual][checkers] for details about the
|
|
||||||
corresponding supported checkers (`:help syntastic-checkers` in Vim).
|
|
||||||
|
|
||||||
A number of third-party Vim plugins also provide checkers for syntastic, for
|
|
||||||
example: [merlin][merlin], [omnisharp-vim][omnisharp], [rust.vim][rust],
|
|
||||||
[syntastic-extras][myint], [syntastic-more][roktas], [tsuquyomi][tsuquyomi],
|
|
||||||
[vim-crystal][crystal], [vim-eastwood][eastwood], and [vim-swift][swift].
|
|
||||||
|
|
||||||
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][screenshot]
|
|
||||||
|
|
||||||
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
|
|
||||||
|
|
||||||
<a name="requirements"></a>
|
|
||||||
|
|
||||||
### 2.1\. Requirements
|
|
||||||
|
|
||||||
Syntastic itself has rather relaxed requirements: it doesn't have any external
|
|
||||||
dependencies, and it needs a version of [Vim][vim] compiled with a few common
|
|
||||||
features: `autocmd`, `eval`, `file_in_path`, `modify_fname`, `quickfix`,
|
|
||||||
`reltime`, `statusline`, and `user_commands`. Not all possible combinations of
|
|
||||||
features that include the ones above make equal sense on all operating systems,
|
|
||||||
but Vim version 7 or later with the "normal", "big", or "huge" feature sets
|
|
||||||
should be fine.
|
|
||||||
|
|
||||||
Syntastic should work with any modern plugin managers for Vim, such as
|
|
||||||
[NeoBundle][neobundle], [Pathogen][pathogen], [Vim-Addon-Manager][vam],
|
|
||||||
[Vim-Plug][plug], or [Vundle][vundle]. Instructions for installing syntastic
|
|
||||||
with [Pathogen][pathogen] are included below for completeness.
|
|
||||||
|
|
||||||
Starting with Vim version 7.4.1486 you can also load syntastic using the
|
|
||||||
standard mechanism of packages, without the help of third-party plugin managers
|
|
||||||
(see `:help packages` in Vim for details). Beware however that, while support
|
|
||||||
for packages has been added in Vim 7.4.1384, the functionality needed by
|
|
||||||
syntastic is present only in versions 7.4.1486 and later.
|
|
||||||
|
|
||||||
Last but not least: syntastic doesn't know how to do any syntax checks by
|
|
||||||
itself. In order to get meaningful results you need to install external
|
|
||||||
checkers corresponding to the types of files you use. Please consult the
|
|
||||||
[manual][checkers] (`:help syntastic-checkers` in Vim) for a list of supported
|
|
||||||
checkers.
|
|
||||||
|
|
||||||
<a name="installpathogen"></a>
|
|
||||||
|
|
||||||
### 2.2\. Installing syntastic with Pathogen
|
|
||||||
|
|
||||||
If you already have [Pathogen][pathogen] working then skip [Step 1](#step1) and go to
|
|
||||||
[Step 2](#step2).
|
|
||||||
|
|
||||||
<a name="step1"></a>
|
|
||||||
|
|
||||||
#### 2.2.1\. Step 1: Install pathogen.vim
|
|
||||||
|
|
||||||
First I'll show you how to install Tim Pope's [Pathogen][pathogen] so that it's easy to
|
|
||||||
install syntastic. Do this in your terminal so that you get the `pathogen.vim`
|
|
||||||
file and the directories it needs:
|
|
||||||
```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.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 --depth=1 https://github.com/vim-syntastic/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][pathogen] 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 `execute 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="settings"></a>
|
|
||||||
|
|
||||||
## 3\. Recommended settings
|
|
||||||
|
|
||||||
Syntastic has numerous options that can be configured, and the defaults
|
|
||||||
are not particularly well suitable for new users. It is recommended
|
|
||||||
that you start by adding the following lines to your `vimrc` file, and
|
|
||||||
return to them after reading the manual (see `:help syntastic` in Vim):
|
|
||||||
```vim
|
|
||||||
set statusline+=%#warningmsg#
|
|
||||||
set statusline+=%{SyntasticStatuslineFlag()}
|
|
||||||
set statusline+=%*
|
|
||||||
|
|
||||||
let g:syntastic_always_populate_loc_list = 1
|
|
||||||
let g:syntastic_auto_loc_list = 1
|
|
||||||
let g:syntastic_check_on_open = 1
|
|
||||||
let g:syntastic_check_on_wq = 0
|
|
||||||
```
|
|
||||||
|
|
||||||
<a name="faq"></a>
|
|
||||||
|
|
||||||
## 4\. FAQ
|
|
||||||
|
|
||||||
<a name="faqinfo"></a>
|
|
||||||
|
|
||||||
__4.1. Q. I installed syntastic but it isn't reporting any errors...__
|
|
||||||
|
|
||||||
A. The most likely reason is that none of the syntax checkers that it requires
|
|
||||||
are installed. For example: by default, python requires either `flake8` or
|
|
||||||
`pylint` to be installed and in your `$PATH`. Read the [manual][checkers]
|
|
||||||
(`:help syntastic-checkers` in Vim) to find out what executables are
|
|
||||||
supported. 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`.
|
|
||||||
|
|
||||||
A second probable reason is that none of the available checkers are
|
|
||||||
enabled. Syntastic comes preconfigured with a default list of enabled checkers
|
|
||||||
per filetype, but this list is kept short in order to prevent slowing down Vim
|
|
||||||
or trying to run conflicting checks. The command `:SyntasticInfo` will show you
|
|
||||||
which checkers are enabled. You can tell syntastic which checkers (among the
|
|
||||||
available ones) you want to run by setting `g:syntastic_<filetype>_checkers` in
|
|
||||||
your `vimrc` (see [below](#faqcheckers)).
|
|
||||||
|
|
||||||
A third possible reason is that the `$PATH` seen by syntastic might not be same
|
|
||||||
as the `$PATH` in your login shell. Syntastic runs checkers using the shell
|
|
||||||
pointed to by Vim's `shell` (or by `g:syntastic_shell`, if set), and that's the
|
|
||||||
shell you need to configure to set the proper `$PATH` and environment variables
|
|
||||||
for your checkers. You can see syntastic's idea of `$PATH` by running
|
|
||||||
```vim
|
|
||||||
:echo syntastic#util#system('echo "$PATH"')
|
|
||||||
```
|
|
||||||
on UNIX and Mac OS-X systems, or
|
|
||||||
```vim
|
|
||||||
:echo syntastic#util#system('echo %PATH%')
|
|
||||||
```
|
|
||||||
on Windows.
|
|
||||||
|
|
||||||
Finally, 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 post an [issue][bug_tracker] - or better yet, create a pull request.
|
|
||||||
|
|
||||||
<a name="faqcheckers"></a>
|
|
||||||
|
|
||||||
__4.2. Q. Syntastic supports several checkers for my filetype, how do I tell it
|
|
||||||
which one(s) to use?__
|
|
||||||
|
|
||||||
A. Add a line like this to your `vimrc`:
|
|
||||||
```vim
|
|
||||||
let g:syntastic_<filetype>_checkers = ['<checker-name>']
|
|
||||||
```
|
|
||||||
|
|
||||||
To see the list of supported checkers for your filetype read the
|
|
||||||
[manual][checkers] (`:help syntastic-checkers` in Vim).
|
|
||||||
|
|
||||||
For example, 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']
|
|
||||||
```
|
|
||||||
|
|
||||||
Checkers 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>`.
|
|
||||||
For example 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`.
|
|
||||||
|
|
||||||
<a name="faqforeign"></a>
|
|
||||||
|
|
||||||
__4.3. Q. How can I run checkers for "foreign" filetypes against the current
|
|
||||||
file?__
|
|
||||||
|
|
||||||
A. You need to qualify the name of the "foreign" checker with the name
|
|
||||||
of its filetype. For example to check `tex` files with the checker
|
|
||||||
`language_check` (which normally acts only on files of type `text`), you can
|
|
||||||
add `text/language_check` to the list fo checkers for `tex`:
|
|
||||||
```vim
|
|
||||||
let g:syntastic_tex_checkers = ['lacheck', 'text/language_check']
|
|
||||||
```
|
|
||||||
|
|
||||||
This also works with `:SyntasticCheck`, e.g. the following command runs
|
|
||||||
`text/language_check` against the current file regardless of the current
|
|
||||||
filetype:
|
|
||||||
```vim
|
|
||||||
:SyntasticCheck text/language_check
|
|
||||||
```
|
|
||||||
|
|
||||||
Of course, the checkers specified this way need to be known to syntastic, and
|
|
||||||
they need to be shown as available when you run `:SyntasticInfo`. You can't
|
|
||||||
just make up a combination of a filetype and a program name and expect it to
|
|
||||||
work as a checker.
|
|
||||||
|
|
||||||
<a name="faqaggregate"></a>
|
|
||||||
|
|
||||||
__4.4. Q. I have enabled multiple checkers for the current filetype. How can I
|
|
||||||
display all errors from all checkers together?__
|
|
||||||
|
|
||||||
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="faqargs"></a>
|
|
||||||
|
|
||||||
__4.5. Q. How can I pass additional arguments to a checker?__
|
|
||||||
|
|
||||||
A. In most cases a command line is constructed using an internal function
|
|
||||||
named `makeprgBuild()`, which provides a number of options that allow you to
|
|
||||||
customise every part of the command that gets run. You can set these options
|
|
||||||
using global variables.
|
|
||||||
|
|
||||||
The general form of the global `args` variable is
|
|
||||||
`syntastic_<filetype>_<checker>_args`. Thus 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 number of checkers don't use the `makeprgBuild()` function mentioned above,
|
|
||||||
or have additional options that can be configured. For these checkers the exact
|
|
||||||
list of options should be included in the [manual][checkers]
|
|
||||||
(`:help syntastic-checkers` in Vim).
|
|
||||||
|
|
||||||
<a name="faqloclist"></a>
|
|
||||||
|
|
||||||
__4.6. Q. I run a checker and the location list is not updated...__
|
|
||||||
__4.6. Q. I run`:lopen` or `:lwindow` and the error window is empty...__
|
|
||||||
|
|
||||||
A. By default the location list is changed only when you run the `:Errors`
|
|
||||||
command, in order to minimise conflicts with other plugins. If you want the
|
|
||||||
location list to always be updated when you run the checkers, add this line to
|
|
||||||
your `vimrc`:
|
|
||||||
```vim
|
|
||||||
let g:syntastic_always_populate_loc_list = 1
|
|
||||||
```
|
|
||||||
|
|
||||||
<a name="faqlnext"></a>
|
|
||||||
|
|
||||||
__4.7. Q. How can I jump between the different errors without using the location
|
|
||||||
list at the bottom of the window?__
|
|
||||||
|
|
||||||
A. Vim provides several built-in commands for this. See `:help :lnext` and
|
|
||||||
`:help :lprevious`.
|
|
||||||
|
|
||||||
If you use these commands a lot then you may want to add shortcut mappings to
|
|
||||||
your `vimrc`, or install something like [unimpaired][unimpaired], which provides such
|
|
||||||
mappings (among other things).
|
|
||||||
|
|
||||||
<a name="faqbdelete"></a>
|
|
||||||
|
|
||||||
__4.8. 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 <C-r>=(getcmdtype()==#':' && getcmdpos()==1 ? 'lclose\|bdelete' : 'bd')<CR>
|
|
||||||
```
|
|
||||||
|
|
||||||
<a name="faqconfig"></a>
|
|
||||||
|
|
||||||
__4.9. My favourite checker needs to load a configuration file from the
|
|
||||||
project's root rather than the current directory...__
|
|
||||||
|
|
||||||
A. You can set up an `autocmd` to search for the configuration file in the
|
|
||||||
current directory and upwards, and add it to the checker's options when found.
|
|
||||||
For example for `jscs`:
|
|
||||||
|
|
||||||
```vim
|
|
||||||
function! FindConfig(prefix, what, where)
|
|
||||||
let cfg = findfile(a:what, escape(a:where, ' ') . ';')
|
|
||||||
return cfg !=# '' ? ' ' . a:prefix . ' ' . shellescape(cfg) : ''
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
autocmd FileType javascript let b:syntastic_javascript_jscs_args =
|
|
||||||
\ get(g:, 'syntastic_javascript_jscs_args', '') .
|
|
||||||
\ FindConfig('-c', '.jscsrc', expand('<afile>:p:h', 1))
|
|
||||||
```
|
|
||||||
|
|
||||||
<a name="faqstyle"></a>
|
|
||||||
|
|
||||||
__4.10. Q. What is the difference between syntax checkers and style checkers?__
|
|
||||||
|
|
||||||
A. The errors and warnings they produce are highlighted differently and can
|
|
||||||
be filtered by different rules, but otherwise the distinction is pretty much
|
|
||||||
arbitrary. There is an ongoing effort to keep things consistent, so you can
|
|
||||||
_generally_ expect messages produced by syntax checkers to be _mostly_ related
|
|
||||||
to syntax, and messages produced by style checkers to be _mostly_ about style.
|
|
||||||
But there can be no formal guarantee that, say, a style checker that runs into
|
|
||||||
a syntax error wouldn't die with a fatal message, nor that a syntax checker
|
|
||||||
wouldn't give you warnings against using some constructs as being bad practice.
|
|
||||||
There is also no guarantee that messages marked as `style` are less severe than
|
|
||||||
the ones marked as `syntax` (whatever that might mean). And there are even a
|
|
||||||
few Frankenstein checkers (for example `flake8` and `pylama`) that, by their
|
|
||||||
nature, produce both kinds of messages. Syntastic is not smart enough to be
|
|
||||||
able to sort out these things by itself.
|
|
||||||
|
|
||||||
Generally it's more useful to look at this from the perspective of filtering
|
|
||||||
unwanted messages, rather than as an indicator of severity levels. The
|
|
||||||
distinction between syntax and style is orthogonal to the distinction between
|
|
||||||
errors and warnings, and thus you can turn off messages based on level, on
|
|
||||||
type, or both.
|
|
||||||
|
|
||||||
e.g. To disable all style messages:
|
|
||||||
```vim
|
|
||||||
let g:syntastic_quiet_messages = { "type": "style" }
|
|
||||||
```
|
|
||||||
See `:help syntastic_quiet_messages` for more information.
|
|
||||||
|
|
||||||
<a name="faqpython"></a>
|
|
||||||
|
|
||||||
__4.11. Q. How can I check scripts written for different versions of Python?__
|
|
||||||
|
|
||||||
A. Install a Python version manager such as [virtualenv][virtualenv]
|
|
||||||
or [pyenv][pyenv], activate the environment for the relevant version
|
|
||||||
of Python, and install in it the checkers you want to use. Set
|
|
||||||
`g:syntastic_python_checkers` accordingly in your `vimrc`, and run [Vim][vim]
|
|
||||||
from the virtual environment.
|
|
||||||
|
|
||||||
If you're starting Vim from a desktop manager rather than from a terminal you
|
|
||||||
might need to write wrapper scripts around your checkers, to activate the
|
|
||||||
virtual environment before running the actual checks. Then you'll need to
|
|
||||||
point the relevant `g:syntastic_python_<checker>_exec` variables to the wrapper
|
|
||||||
scripts.
|
|
||||||
|
|
||||||
<a name="faqruby"></a>
|
|
||||||
|
|
||||||
__4.12. Q. How can I check scripts written for different versions of Ruby?__
|
|
||||||
|
|
||||||
A. Install a Ruby version manager such as [rvm][rvm] or [rbenv][rbenv],
|
|
||||||
activate the environment for the relevant version of Ruby, and install in it
|
|
||||||
the checkers you want to use. Set `g:syntastic_ruby_checkers` accordingly in
|
|
||||||
your `vimrc`, and run [Vim][vim] from the virtual environment.
|
|
||||||
|
|
||||||
If you're starting Vim from a desktop manager rather than from a terminal you
|
|
||||||
might need to write wrapper scripts around your checkers, to activate the
|
|
||||||
virtual environment before running the actual checks. Then you'll need to
|
|
||||||
point the relevant `g:syntastic_ruby_<checker>_exec` variables to the wrapper
|
|
||||||
scripts.
|
|
||||||
|
|
||||||
<a name="faqperl"></a>
|
|
||||||
|
|
||||||
__4.13. 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][perlrun]). This is probably fine if you
|
|
||||||
wrote the file yourself, but it's a security problem if you're checking
|
|
||||||
third-party files. Since there is currently no way to disable this behaviour
|
|
||||||
while still producing useful results, the checker is now disabled by default.
|
|
||||||
To (re-)enable it, make sure the `g:syntastic_perl_checkers` list includes
|
|
||||||
`perl`, and set `g:syntastic_enable_perl_checker` to 1 in your `vimrc`:
|
|
||||||
```vim
|
|
||||||
let g:syntastic_enable_perl_checker = 1
|
|
||||||
```
|
|
||||||
|
|
||||||
<a name="faqrust"></a>
|
|
||||||
|
|
||||||
__4.14. Q. What happened to the `rustc` checker?__
|
|
||||||
|
|
||||||
A. It is now part of the [rust.vim][rust] plugin. If you install this plugin the
|
|
||||||
checker should be picked up automatically by syntastic.
|
|
||||||
|
|
||||||
<a name="faqtsc"></a>
|
|
||||||
|
|
||||||
__4.15. Q. What happened to the `tsc` checker?__
|
|
||||||
|
|
||||||
A. It didn't meet people's expectations and it has been removed. The plugin
|
|
||||||
[tsuquyomi][tsuquyomi] comes packaged with a checker for TypeScript. If you
|
|
||||||
install this plugin the checker should be picked up automatically by syntastic.
|
|
||||||
|
|
||||||
<a name="faqxcrun"></a>
|
|
||||||
|
|
||||||
__4.16. Q. What happened to the `xcrun` checker?__
|
|
||||||
|
|
||||||
A. The `xcrun` checker used to have a security problem and it has been removed.
|
|
||||||
A better checker for __Swift__ is part of the [vim-swift][swift] plugin. If you
|
|
||||||
install this plugin the checker should be picked up automatically by syntastic.
|
|
||||||
|
|
||||||
<a name="otherresources"></a>
|
|
||||||
|
|
||||||
## 5\. Resources
|
|
||||||
|
|
||||||
The preferred place for posting suggestions, reporting bugs, and general
|
|
||||||
discussions related to syntastic is the [issue tracker at GitHub][bug_tracker].
|
|
||||||
A guide for writing syntax checkers can be found in the [wiki][guide].
|
|
||||||
There are also a dedicated [google group][google_group], and a
|
|
||||||
[syntastic tag at StackOverflow][stack_overflow].
|
|
||||||
|
|
||||||
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 [ghcmod-vim][ghcmod], [jedi-vim][jedi], [python-mode][python_mode], [vim-go][vimgo], or
|
|
||||||
[YouCompleteMe][ycm].
|
|
||||||
|
|
||||||
[scrooloose]: https://github.com/scrooloose
|
|
||||||
[screenshot]: https://github.com/vim-syntastic/syntastic/raw/master/_assets/screenshot_1.png
|
|
||||||
|
|
||||||
[bug_tracker]: https://github.com/vim-syntastic/syntastic/issues
|
|
||||||
[checkers]: https://github.com/vim-syntastic/syntastic/blob/master/doc/syntastic-checkers.txt
|
|
||||||
[crystal]: https://github.com/rhysd/vim-crystal
|
|
||||||
[eastwood]: https://github.com/venantius/vim-eastwood
|
|
||||||
[ghcmod]: https://github.com/eagletmt/ghcmod-vim
|
|
||||||
[google_group]: https://groups.google.com/group/vim-syntastic
|
|
||||||
[guide]: https://github.com/vim-syntastic/syntastic/wiki/Syntax-Checker-Guide
|
|
||||||
[jedi]: https://github.com/davidhalter/jedi-vim
|
|
||||||
[merlin]: https://github.com/the-lambda-church/merlin
|
|
||||||
[myint]: https://github.com/myint/syntastic-extras
|
|
||||||
[neobundle]: https://github.com/Shougo/neobundle.vim
|
|
||||||
[omnisharp]: https://github.com/OmniSharp/omnisharp-vim
|
|
||||||
[pathogen]: https://github.com/tpope/vim-pathogen
|
|
||||||
[perlrun]: http://perldoc.perl.org/perlrun.html#*-c*
|
|
||||||
[plug]: https://github.com/junegunn/vim-plug/
|
|
||||||
[pyenv]: https://github.com/yyuu/pyenv
|
|
||||||
[python_mode]: https://github.com/klen/python-mode
|
|
||||||
[rbenv]: https://github.com/rbenv/rbenv
|
|
||||||
[roktas]: https://github.com/roktas/syntastic-more
|
|
||||||
[rust]: https://github.com/rust-lang/rust.vim
|
|
||||||
[rvm]: https://rvm.io/
|
|
||||||
[stack_overflow]: http://stackoverflow.com/questions/tagged/syntastic
|
|
||||||
[swift]: https://github.com/kballard/vim-swift
|
|
||||||
[tsuquyomi]: https://github.com/Quramy/tsuquyomi/
|
|
||||||
[unimpaired]: https://github.com/tpope/vim-unimpaired
|
|
||||||
[vam]: https://github.com/MarcWeber/vim-addon-manager
|
|
||||||
[vim]: http://www.vim.org/
|
|
||||||
[vimgo]: https://github.com/fatih/vim-go
|
|
||||||
[virtualenv]: https://virtualenv.pypa.io/en/stable/
|
|
||||||
[vnu]: http://about.validator.nu/
|
|
||||||
[vnu_jar]: https://github.com/validator/validator/releases/latest
|
|
||||||
[vnu_server]: http://validator.github.io/validator/#standalone
|
|
||||||
[vundle]: https://github.com/gmarik/Vundle.vim
|
|
||||||
[ycm]: http://valloric.github.io/YouCompleteMe/
|
|
||||||
|
|
||||||
<!--
|
|
||||||
vim:tw=79:sw=4:
|
|
||||||
-->
|
|
Binary file not shown.
Before (image error) Size: 90 KiB |
@ -1,341 +0,0 @@
|
|||||||
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() abort " {{{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) abort " {{{2
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, 'ReadConfig: looking for', a:file)
|
|
||||||
|
|
||||||
" search upwards from the current file's directory
|
|
||||||
let config = syntastic#util#findFileInParent(a:file, expand('%:p:h', 1))
|
|
||||||
if config ==# ''
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, 'ReadConfig: file not found')
|
|
||||||
return ''
|
|
||||||
endif
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, 'ReadConfig: config file:', config)
|
|
||||||
if !filereadable(config)
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, 'ReadConfig: file unreadable')
|
|
||||||
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]/
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, 'ReadConfig: error reading file')
|
|
||||||
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) abort " {{{2
|
|
||||||
try
|
|
||||||
let flags = s:_get_cflags(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:_get_checker_var('g', a:filetype, a:subchecker, 'errorformat', a:options['errorformat'])
|
|
||||||
|
|
||||||
let postprocess = s:_get_checker_var('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() abort " {{{2
|
|
||||||
let s:handlers = []
|
|
||||||
let s:cflags = {}
|
|
||||||
|
|
||||||
call s:_registerHandler('\m\<cairo', 's:_checkPackage', ['cairo', 'cairo'])
|
|
||||||
call s:_registerHandler('\m\<freetype', 's:_checkPackage', ['freetype', 'freetype2', 'freetype'])
|
|
||||||
call s:_registerHandler('\m\<glade', 's:_checkPackage', ['glade', 'libglade-2.0', 'libglade'])
|
|
||||||
call s:_registerHandler('\m\<glib', 's:_checkPackage', ['glib', 'glib-2.0', 'glib'])
|
|
||||||
call s:_registerHandler('\m\<gtk', 's:_checkPackage', ['gtk', 'gtk+-2.0', 'gtk+', 'glib-2.0', 'glib'])
|
|
||||||
call s:_registerHandler('\m\<libsoup', 's:_checkPackage', ['libsoup', 'libsoup-2.4', 'libsoup-2.2'])
|
|
||||||
call s:_registerHandler('\m\<libxml', 's:_checkPackage', ['libxml', 'libxml-2.0', 'libxml'])
|
|
||||||
call s:_registerHandler('\m\<pango', 's:_checkPackage', ['pango', 'pango'])
|
|
||||||
call s:_registerHandler('\m\<SDL', 's:_checkPackage', ['sdl', 'sdl'])
|
|
||||||
call s:_registerHandler('\m\<opengl', 's:_checkPackage', ['opengl', 'gl'])
|
|
||||||
call s:_registerHandler('\m\<webkit', 's:_checkPackage', ['webkit', 'webkit-1.0'])
|
|
||||||
|
|
||||||
call s:_registerHandler('\m\<php\.h\>', 's:_checkPhp', [])
|
|
||||||
call s:_registerHandler('\m\<Python\.h\>', 's:_checkPython', [])
|
|
||||||
call s:_registerHandler('\m\<ruby', 's:_checkRuby', [])
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" register a handler dictionary object
|
|
||||||
function! s:_registerHandler(regex, function, args) abort " {{{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
|
|
||||||
|
|
||||||
" try to find library with 'pkg-config'
|
|
||||||
" search possible libraries from first to last given
|
|
||||||
" argument until one is found
|
|
||||||
function! s:_checkPackage(name, ...) abort " {{{2
|
|
||||||
if executable('pkg-config')
|
|
||||||
if !has_key(s:cflags, a:name)
|
|
||||||
for pkg in a:000
|
|
||||||
let pkg_flags = syntastic#util#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! s:_checkPhp() abort " {{{2
|
|
||||||
if executable('php-config')
|
|
||||||
if !has_key(s:cflags, 'php')
|
|
||||||
let s:cflags['php'] = syntastic#util#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 python headers with distutils
|
|
||||||
function! s:_checkPython() abort " {{{2
|
|
||||||
if executable('python')
|
|
||||||
if !has_key(s:cflags, 'python')
|
|
||||||
let s:cflags['python'] = syntastic#util#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
|
|
||||||
|
|
||||||
" try to find the ruby headers with 'rbconfig'
|
|
||||||
function! s:_checkRuby() abort " {{{2
|
|
||||||
if executable('ruby')
|
|
||||||
if !has_key(s:cflags, 'ruby')
|
|
||||||
let s:cflags['ruby'] = syntastic#util#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
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Utilities {{{1
|
|
||||||
|
|
||||||
" resolve checker-related user variables
|
|
||||||
function! s:_get_checker_var(scope, filetype, subchecker, name, default) abort " {{{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:_get_cflags(ft, ck, opts) abort " {{{2
|
|
||||||
" determine whether to parse header files as well
|
|
||||||
if has_key(a:opts, 'header_names') && expand('%', 1) =~? a:opts['header_names']
|
|
||||||
if s:_get_checker_var('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:_get_checker_var('g', a:ft, a:ck, 'compiler_options', '') . ' ' . s:_get_include_dirs(a:ft)
|
|
||||||
|
|
||||||
" check if the user manually set some cflags
|
|
||||||
let b_cflags = s:_get_checker_var('b', a:ft, a:ck, 'cflags', '')
|
|
||||||
if b_cflags !=# ''
|
|
||||||
let flags .= ' ' . b_cflags
|
|
||||||
endif
|
|
||||||
|
|
||||||
" add optional config file parameters
|
|
||||||
let config_file = s:_get_checker_var('g', a:ft, a:ck, 'config_file', '.syntastic_' . a:ft . '_config')
|
|
||||||
let flags .= ' ' . syntastic#c#ReadConfig(config_file)
|
|
||||||
|
|
||||||
if b_cflags ==# '' && (a:ft ==# 'c' || a:ft ==# 'cpp') && !s:_get_checker_var('g', a:ft, a:ck, 'no_include_search', 0)
|
|
||||||
" refresh the include file search if desired
|
|
||||||
if s:_get_checker_var('g', a:ft, a:ck, 'auto_refresh_includes', 0)
|
|
||||||
let flags .= ' ' . s:_search_headers()
|
|
||||||
else
|
|
||||||
" search for header includes if not cached already
|
|
||||||
if !exists('b:syntastic_' . a:ft . '_includes')
|
|
||||||
let b:syntastic_{a:ft}_includes = s:_search_headers()
|
|
||||||
endif
|
|
||||||
let flags .= ' ' . b:syntastic_{a:ft}_includes
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
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:_get_include_dirs(filetype) abort " {{{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:_search_headers() abort " {{{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', 1) . 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
|
|
||||||
|
|
||||||
" }}}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:
|
|
@ -1,222 +0,0 @@
|
|||||||
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) abort " {{{2
|
|
||||||
echomsg 'syntastic: info: ' . a:msg
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#log#warn(msg) abort " {{{2
|
|
||||||
echohl WarningMsg
|
|
||||||
echomsg 'syntastic: warning: ' . a:msg
|
|
||||||
echohl None
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#log#error(msg) abort " {{{2
|
|
||||||
execute 'normal! \<Esc>'
|
|
||||||
echohl ErrorMsg
|
|
||||||
echomsg 'syntastic: error: ' . a:msg
|
|
||||||
echohl None
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#log#oneTimeWarn(msg) abort " {{{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, ...) abort " {{{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, ...) abort " {{{2
|
|
||||||
if !s:_isDebugEnabled(a:level)
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
let leader = s:_log_timestamp()
|
|
||||||
call s:_logRedirect(1)
|
|
||||||
|
|
||||||
if a: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) abort " {{{2
|
|
||||||
if !s:_isDebugEnabled(a:level)
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
let leader = s:_log_timestamp()
|
|
||||||
call s:_logRedirect(1)
|
|
||||||
|
|
||||||
let vlist = copy(type(a:names) == type('') ? [a:names] : a:names)
|
|
||||||
let add_shell = index(vlist, 'shell') >= 0 && &shell !=# syntastic#util#var('shell')
|
|
||||||
if !empty(vlist)
|
|
||||||
call map(vlist, "'&' . v:val . ' = ' . strtrans(string(eval('&' . v:val))) . (s:_is_modified(v:val) ? ' (!)' : '')")
|
|
||||||
if add_shell
|
|
||||||
call add(vlist, 'u:shell = ' . strtrans(string(syntastic#util#var('shell'))) . ' (!)')
|
|
||||||
endif
|
|
||||||
echomsg leader . join(vlist, ', ')
|
|
||||||
endif
|
|
||||||
call s:_logRedirect(0)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#log#debugShowVariables(level, names) abort " {{{2
|
|
||||||
if !s:_isDebugEnabled(a:level)
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
let leader = s:_log_timestamp()
|
|
||||||
call s:_logRedirect(1)
|
|
||||||
|
|
||||||
let vlist = type(a:names) == type('') ? [a:names] : a:names
|
|
||||||
for name in vlist
|
|
||||||
let msg = s:_format_variable(name)
|
|
||||||
if msg !=# ''
|
|
||||||
echomsg leader . msg
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
|
|
||||||
call s:_logRedirect(0)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#log#debugDump(level) abort " {{{2
|
|
||||||
if !s:_isDebugEnabled(a:level)
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
call syntastic#log#debugShowVariables( a:level, sort(keys(g:_SYNTASTIC_DEFAULTS)) )
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#log#ndebug(level, title, messages) abort " {{{2
|
|
||||||
if s:_isDebugEnabled(a:level)
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
call syntastic#log#error(a:title)
|
|
||||||
if type(a:messages) == type([])
|
|
||||||
for msg in a:messages
|
|
||||||
echomsg msg
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
echomsg a:messages
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Private functions {{{1
|
|
||||||
|
|
||||||
function! s:_isDebugEnabled_smart(level) abort " {{{2
|
|
||||||
return and(g:syntastic_debug, a:level)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! s:_isDebugEnabled_dumb(level) abort " {{{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) abort " {{{2
|
|
||||||
if exists('g:syntastic_debug_file')
|
|
||||||
if a:on
|
|
||||||
try
|
|
||||||
execute 'redir >> ' . fnameescape(expand(g:syntastic_debug_file, 1))
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:/
|
|
||||||
silent! redir END
|
|
||||||
unlet g:syntastic_debug_file
|
|
||||||
endtry
|
|
||||||
else
|
|
||||||
silent! redir END
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Utilities {{{1
|
|
||||||
|
|
||||||
function! s:_log_timestamp_smart() abort " {{{2
|
|
||||||
return printf('syntastic: %f: ', reltimefloat(reltime(g:_SYNTASTIC_START)))
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! s:_log_timestamp_dumb() abort " {{{2
|
|
||||||
return 'syntastic: ' . split(reltimestr(reltime(g:_SYNTASTIC_START)))[0] . ': '
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
let s:_log_timestamp = function(has('float') && exists('*reltimefloat') ? 's:_log_timestamp_smart' : 's:_log_timestamp_dumb')
|
|
||||||
lockvar s:_log_timestamp
|
|
||||||
|
|
||||||
function! s:_format_variable(name) abort " {{{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
|
|
||||||
|
|
||||||
function! s:_is_modified(name) abort " {{{2
|
|
||||||
if !exists('s:option_defaults')
|
|
||||||
let s:option_defaults = {}
|
|
||||||
endif
|
|
||||||
if !has_key(s:option_defaults, a:name)
|
|
||||||
let opt_save = eval('&' . a:name)
|
|
||||||
execute 'set ' . a:name . '&'
|
|
||||||
let s:option_defaults[a:name] = eval('&' . a:name)
|
|
||||||
execute 'let &' . a:name . ' = ' . string(opt_save)
|
|
||||||
endif
|
|
||||||
|
|
||||||
return s:option_defaults[a:name] !=# eval('&' . a:name)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,73 +0,0 @@
|
|||||||
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) abort " {{{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) abort " {{{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) abort " {{{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) abort " {{{2
|
|
||||||
return filter(copy(a:errors), 'get(v:val, "bufnr") == ' . bufnr(''))
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" make sure line numbers are not past end of buffers
|
|
||||||
" XXX: this loads all referenced buffers in memory
|
|
||||||
function! syntastic#postprocess#guards(errors) abort " {{{2
|
|
||||||
let buffers = syntastic#util#unique(map(filter(copy(a:errors), 'v:val["valid"]'), 'str2nr(v:val["bufnr"])'))
|
|
||||||
|
|
||||||
let guards = {}
|
|
||||||
for b in buffers
|
|
||||||
let guards[b] = len(getbufline(b, 1, '$'))
|
|
||||||
endfor
|
|
||||||
|
|
||||||
for e in a:errors
|
|
||||||
if e['valid'] && e['lnum'] > guards[e['bufnr']]
|
|
||||||
let e['lnum'] = guards[e['bufnr']]
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
|
|
||||||
return a:errors
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,681 +0,0 @@
|
|||||||
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#bandit(errors) abort " {{{2
|
|
||||||
let out = []
|
|
||||||
let json = s:_decode_JSON(join(a:errors, ''))
|
|
||||||
|
|
||||||
if type(json) == type({}) && has_key(json, 'results') && type(json['results']) == type([])
|
|
||||||
for issue in json['results']
|
|
||||||
if type(issue) == type({})
|
|
||||||
try
|
|
||||||
call add(out,
|
|
||||||
\ issue['filename'] . ':' .
|
|
||||||
\ issue['line_number'] . ':' .
|
|
||||||
\ { 'LOW': 'I', 'MEDIUM': 'W', 'HIGH': 'E' }[issue['issue_severity']] . ':' .
|
|
||||||
\ issue['test_id'][1:] . ':' .
|
|
||||||
\ issue['issue_text'] .
|
|
||||||
\ ' [' . issue['test_name'] . '] (confidence: ' . issue['issue_confidence'] . ')')
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E716/
|
|
||||||
call syntastic#log#warn('checker python/bandit: unrecognized error item ' . string(issue))
|
|
||||||
let out = []
|
|
||||||
break
|
|
||||||
endtry
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker python/bandit: unrecognized error item ' . string(issue))
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker python/bandit: unrecognized error format (crashed checker?)')
|
|
||||||
endif
|
|
||||||
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#cabal(errors) abort " {{{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) abort " {{{2
|
|
||||||
let out = []
|
|
||||||
let fname = expand('%', 1)
|
|
||||||
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) abort " {{{2
|
|
||||||
return map(copy(a:errors), 'substitute(v:val, ''\v^\[[^]]+\]\zs( -\> \[[^]]+\])+\ze:'', "", "")')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#dockerfile_lint(errors) abort " {{{2
|
|
||||||
let out = []
|
|
||||||
let json = s:_decode_JSON(join(a:errors, ''))
|
|
||||||
|
|
||||||
if type(json) == type({})
|
|
||||||
try
|
|
||||||
let data = json['error']['data'] + json['warn']['data'] + json['info']['data']
|
|
||||||
for e in data
|
|
||||||
let type = toupper(e['level'][0])
|
|
||||||
if type ==# 'I'
|
|
||||||
let type = 'W'
|
|
||||||
let style = 1
|
|
||||||
else
|
|
||||||
let style = 0
|
|
||||||
endif
|
|
||||||
|
|
||||||
let line = get(e, 'line', 1)
|
|
||||||
let message = e['message']
|
|
||||||
if has_key(e, 'description') && e['description'] !=# 'None'
|
|
||||||
let message = message . '. ' . e['description']
|
|
||||||
endif
|
|
||||||
|
|
||||||
let msg =
|
|
||||||
\ type . ':' .
|
|
||||||
\ style . ':' .
|
|
||||||
\ line . ':' .
|
|
||||||
\ message
|
|
||||||
call add(out, msg)
|
|
||||||
endfor
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E716/
|
|
||||||
call syntastic#log#warn('checker dockerfile/dockerfile_lint: unrecognized error format (crashed checker?)')
|
|
||||||
let out = []
|
|
||||||
endtry
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker dockerfile/dockerfile_lint: unrecognized error format (crashed checker?)')
|
|
||||||
endif
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#dscanner(errors) abort " {{{2
|
|
||||||
let idx = 0
|
|
||||||
while idx < len(a:errors) && a:errors[idx][0] !=# '{'
|
|
||||||
let idx += 1
|
|
||||||
endwhile
|
|
||||||
let errs = s:_decode_JSON(join(a:errors[idx :], ''))
|
|
||||||
|
|
||||||
let out = []
|
|
||||||
if type(errs) == type({}) && has_key(errs, 'issues') && type(errs['issues']) == type([])
|
|
||||||
for issue in errs['issues']
|
|
||||||
try
|
|
||||||
call add(out,
|
|
||||||
\ issue['fileName'] . ':' .
|
|
||||||
\ issue['line'] . ':' .
|
|
||||||
\ issue['column'] . ':' .
|
|
||||||
\ issue['message'] . ' [' . issue['key'] . ']')
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E716/
|
|
||||||
call syntastic#log#warn('checker d/dscanner: unrecognized error item ' . string(issue))
|
|
||||||
let out = []
|
|
||||||
break
|
|
||||||
endtry
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker d/dscanner: unrecognized error format (crashed checker?)')
|
|
||||||
endif
|
|
||||||
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#flow(errors) abort " {{{2
|
|
||||||
let idx = 0
|
|
||||||
while idx < len(a:errors) && a:errors[idx][0] !=# '{'
|
|
||||||
let idx += 1
|
|
||||||
endwhile
|
|
||||||
let errs = s:_decode_JSON(join(a:errors[idx :], ''))
|
|
||||||
|
|
||||||
let out = []
|
|
||||||
if type(errs) == type({}) && has_key(errs, 'errors') && type(errs['errors']) == type([])
|
|
||||||
for e in errs['errors']
|
|
||||||
if type(e) == type({}) && has_key(e, 'message') && type(e['message']) == type([]) && len(e['message'])
|
|
||||||
let m = e['message'][0]
|
|
||||||
let t = e['message'][1:]
|
|
||||||
|
|
||||||
try
|
|
||||||
let msg =
|
|
||||||
\ m['path'] . ':' .
|
|
||||||
\ m['line'] . ':' .
|
|
||||||
\ m['start'] . ':' .
|
|
||||||
\ (m['line'] ==# m['endline'] && str2nr(m['end']) > 0 ? m['end'] . ':' : '') .
|
|
||||||
\ ' ' . m['descr']
|
|
||||||
|
|
||||||
if len(t)
|
|
||||||
let msg .= ' ' . join(map(t,
|
|
||||||
\ 'v:val["descr"] . " (" . v:val["path"] . ":" . v:val["line"] . ":" . v:val["start"] . ' .
|
|
||||||
\ '"," . (v:val["line"] !=# v:val["endline"] ? v:val["endline"] . ":" : "") . ' .
|
|
||||||
\ 'v:val["end"] . ")"'))
|
|
||||||
endif
|
|
||||||
|
|
||||||
let msg = substitute(msg, '\r', '', 'g')
|
|
||||||
let msg = substitute(msg, '\n', ' ', 'g')
|
|
||||||
|
|
||||||
call add(out, msg)
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E716/
|
|
||||||
call syntastic#log#warn('checker javascript/flow: unrecognized error format (crashed checker?)')
|
|
||||||
let out = []
|
|
||||||
break
|
|
||||||
endtry
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker javascript/flow: unrecognized error format (crashed checker?)')
|
|
||||||
let out = []
|
|
||||||
break
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker javascript/flow: unrecognized error format (crashed checker?)')
|
|
||||||
endif
|
|
||||||
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#iconv(errors) abort " {{{2
|
|
||||||
return
|
|
||||||
\ has('iconv') && &encoding !=# '' && &encoding !=# 'utf-8' ?
|
|
||||||
\ map(a:errors, 'iconv(v:val, "utf-8", &encoding)') :
|
|
||||||
\ a:errors
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#jscs(errors) abort " {{{2
|
|
||||||
let errs = join(a:errors, '')
|
|
||||||
if errs ==# ''
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
|
|
||||||
let json = s:_decode_JSON(errs)
|
|
||||||
|
|
||||||
let out = []
|
|
||||||
if type(json) == type({})
|
|
||||||
for fname in keys(json)
|
|
||||||
if type(json[fname]) == type([])
|
|
||||||
for e in json[fname]
|
|
||||||
try
|
|
||||||
let e['message'] = substitute(e['message'], "\n", ' ', 'g')
|
|
||||||
cal add(out, fname . ':' . e['line'] . ':' . e['column'] . ':' . e['message'])
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E716/
|
|
||||||
call syntastic#log#warn('checker javascript/jscs: unrecognized error item ' . string(e))
|
|
||||||
let out = []
|
|
||||||
endtry
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker javascript/jscs: unrecognized error format (crashed checker?)')
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker javascript/jscs: unrecognized error format (crashed checker?)')
|
|
||||||
endif
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#killEmpty(errors) abort " {{{2
|
|
||||||
return filter(copy(a:errors), 'v:val !=# ""')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#perl(errors) abort " {{{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#prospector(errors) abort " {{{2
|
|
||||||
let errs = join(a:errors, '')
|
|
||||||
if errs ==# ''
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
|
|
||||||
let json = s:_decode_JSON(errs)
|
|
||||||
|
|
||||||
let out = []
|
|
||||||
if type(json) == type({}) && has_key(json, 'messages')
|
|
||||||
if type(json['messages']) == type([])
|
|
||||||
for e in json['messages']
|
|
||||||
if type(e) == type({})
|
|
||||||
try
|
|
||||||
if e['source'] ==# 'pylint'
|
|
||||||
let e['location']['character'] += 1
|
|
||||||
endif
|
|
||||||
|
|
||||||
let msg =
|
|
||||||
\ e['location']['path'] . ':' .
|
|
||||||
\ e['location']['line'] . ':' .
|
|
||||||
\ e['location']['character'] . ': ' .
|
|
||||||
\ e['code'] . ' ' .
|
|
||||||
\ e['message'] . ' ' .
|
|
||||||
\ '[' . e['source'] . ']'
|
|
||||||
|
|
||||||
call add(out, msg)
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E716/
|
|
||||||
call syntastic#log#warn('checker python/prospector: unrecognized error item ' . string(e))
|
|
||||||
let out = []
|
|
||||||
break
|
|
||||||
endtry
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker python/prospector: unrecognized error item ' . string(e))
|
|
||||||
let out = []
|
|
||||||
break
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker python/prospector: unrecognized error format (crashed checker?)')
|
|
||||||
endif
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker python/prospector: unrecognized error format (crashed checker?)')
|
|
||||||
endif
|
|
||||||
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#rparse(errors) abort " {{{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#scss_lint(errors) abort " {{{2
|
|
||||||
let errs = join(a:errors, '')
|
|
||||||
if errs ==# ''
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
|
|
||||||
let json = s:_decode_JSON(errs)
|
|
||||||
|
|
||||||
let out = []
|
|
||||||
if type(json) == type({})
|
|
||||||
for fname in keys(json)
|
|
||||||
if type(json[fname]) == type([])
|
|
||||||
for e in json[fname]
|
|
||||||
try
|
|
||||||
cal add(out, fname . ':' .
|
|
||||||
\ e['severity'][0] . ':' .
|
|
||||||
\ e['line'] . ':' .
|
|
||||||
\ e['column'] . ':' .
|
|
||||||
\ e['length'] . ':' .
|
|
||||||
\ ( has_key(e, 'linter') ? e['linter'] . ': ' : '' ) .
|
|
||||||
\ e['reason'])
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E716/
|
|
||||||
call syntastic#log#warn('checker scss/scss_lint: unrecognized error item ' . string(e))
|
|
||||||
let out = []
|
|
||||||
endtry
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker scss/scss_lint: unrecognized error format (crashed checker?)')
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker scss/scss_lint: unrecognized error format (crashed checker?)')
|
|
||||||
endif
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#stylelint(errors) abort " {{{2
|
|
||||||
let out = []
|
|
||||||
|
|
||||||
" CssSyntaxError: /path/to/file.css:2:11: Missed semicolon
|
|
||||||
let parts = matchlist(a:errors[0], '\v^CssSyntaxError: (.{-1,}):(\d+):(\d+): (.+)')
|
|
||||||
if len(parts) > 4
|
|
||||||
call add(out, 'E:' . join(parts[1:4], ':'))
|
|
||||||
else
|
|
||||||
let errs = s:_decode_JSON(join(a:errors, ''))
|
|
||||||
|
|
||||||
let out = []
|
|
||||||
if type(errs) == type([]) && len(errs) == 1 && type(errs[0]) == type({}) &&
|
|
||||||
\ has_key(errs[0], 'source') && has_key(errs[0], 'warnings') && type(errs[0]['warnings']) == type([])
|
|
||||||
|
|
||||||
for e in errs[0]['warnings']
|
|
||||||
try
|
|
||||||
let severity = type(e['severity']) == type(0) ? ['W', 'E'][e['severity']-1] : e['severity'][0]
|
|
||||||
let msg =
|
|
||||||
\ severity . ':' .
|
|
||||||
\ errs[0]['source'] . ':' .
|
|
||||||
\ e['line'] . ':' .
|
|
||||||
\ e['column'] . ':' .
|
|
||||||
\ e['text']
|
|
||||||
call add(out, msg)
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E716/
|
|
||||||
call syntastic#log#warn('checker css/stylelint: unrecognized error item ' . string(e))
|
|
||||||
let out = []
|
|
||||||
break
|
|
||||||
endtry
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker css/stylelint: unrecognized error format (crashed checker?)')
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#tern_lint(errors) abort " {{{2
|
|
||||||
let errs = join(a:errors, '')
|
|
||||||
let json = s:_decode_JSON(errs)
|
|
||||||
|
|
||||||
echomsg string(json)
|
|
||||||
let out = []
|
|
||||||
if type(json) == type({}) && has_key(json, 'messages') && type(json['messages']) == type([])
|
|
||||||
for e in json['messages']
|
|
||||||
try
|
|
||||||
let line_from = byte2line(e['from'] + 1)
|
|
||||||
if line_from > 0
|
|
||||||
let line = line_from
|
|
||||||
let column = e['from'] - line2byte(line_from) + 2
|
|
||||||
let line_to = byte2line(e['from'] + 1)
|
|
||||||
let hl = line_to == line ? e['to'] - line2byte(line_to) + 1 : 0
|
|
||||||
else
|
|
||||||
let line = 0
|
|
||||||
let column = 0
|
|
||||||
let hl = 0
|
|
||||||
endif
|
|
||||||
|
|
||||||
if column < 0
|
|
||||||
let column = 0
|
|
||||||
endif
|
|
||||||
if hl < 0
|
|
||||||
let hl = 0
|
|
||||||
endif
|
|
||||||
|
|
||||||
call add(out,
|
|
||||||
\ e['file'] . ':' .
|
|
||||||
\ e['severity'][0] . ':' .
|
|
||||||
\ line . ':' .
|
|
||||||
\ column . ':' .
|
|
||||||
\ hl . ':' .
|
|
||||||
\ e['message'])
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E716/
|
|
||||||
call syntastic#log#warn('checker javascript/tern_lint: unrecognized error item ' . string(e))
|
|
||||||
let out = []
|
|
||||||
endtry
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker javascript/tern_lint: unrecognized error format (crashed checker?)')
|
|
||||||
endif
|
|
||||||
|
|
||||||
echomsg string(out)
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#tslint(errors) abort " {{{2
|
|
||||||
return map(copy(a:errors), 'substitute(v:val, ''\v^((ERROR|WARNING): )?\zs(\([^)]+\))\s(.+)$'', ''\4 \3'', "")')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#validator(errors) abort " {{{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
|
|
||||||
|
|
||||||
function! syntastic#preprocess#vint(errors) abort " {{{2
|
|
||||||
let errs = s:_decode_JSON(join(a:errors, ''))
|
|
||||||
|
|
||||||
let out = []
|
|
||||||
if type(errs) == type([])
|
|
||||||
for e in errs
|
|
||||||
if type(e) == type({})
|
|
||||||
try
|
|
||||||
let msg =
|
|
||||||
\ e['file_path'] . ':' .
|
|
||||||
\ e['line_number'] . ':' .
|
|
||||||
\ e['column_number'] . ':' .
|
|
||||||
\ e['severity'][0] . ': ' .
|
|
||||||
\ e['description'] . ' (' .
|
|
||||||
\ e['policy_name'] . ')'
|
|
||||||
|
|
||||||
call add(out, msg)
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E716/
|
|
||||||
call syntastic#log#warn('checker vim/vint: unrecognized error item ' . string(e))
|
|
||||||
let out = []
|
|
||||||
break
|
|
||||||
endtry
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker vim/vint: unrecognized error item ' . string(e))
|
|
||||||
let out = []
|
|
||||||
break
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('checker vim/vint: unrecognized error format (crashed checker?)')
|
|
||||||
endif
|
|
||||||
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Workarounds {{{1
|
|
||||||
|
|
||||||
" In errorformat, \ or % following %f make it depend on isfname. The default
|
|
||||||
" setting of isfname is crafted to work with completion, rather than general
|
|
||||||
" filename matching. The result for syntastic is that filenames containing
|
|
||||||
" spaces (or a few other special characters) can't be matched.
|
|
||||||
"
|
|
||||||
" Fixing isfname to address this problem would depend on the set of legal
|
|
||||||
" characters for filenames on the filesystem the project's files lives on.
|
|
||||||
" Inferring the kind of filesystem a file lives on, in advance to parsing the
|
|
||||||
" file's name, is an interesting problem (think f.i. a file loaded from a VFAT
|
|
||||||
" partition, mounted on Linux). A problem syntastic is not prepared to solve.
|
|
||||||
"
|
|
||||||
" As a result, the functions below exist for the only reason to avoid using
|
|
||||||
" things like %f\, in errorformat.
|
|
||||||
"
|
|
||||||
" References:
|
|
||||||
" https://groups.google.com/forum/#!topic/vim_dev/pTKmZmouhio
|
|
||||||
" https://vimhelp.appspot.com/quickfix.txt.html#error-file-format
|
|
||||||
|
|
||||||
function! syntastic#preprocess#basex(errors) abort " {{{2
|
|
||||||
let out = []
|
|
||||||
let idx = 0
|
|
||||||
while idx < len(a:errors)
|
|
||||||
let parts = matchlist(a:errors[idx], '\v^\[\S+\] Stopped at (.+), (\d+)/(\d+):')
|
|
||||||
if len(parts) > 3
|
|
||||||
let err = parts[1] . ':' . parts[2] . ':' . parts[3] . ':'
|
|
||||||
let parts = matchlist(a:errors[idx+1], '\v^\[(.)\D+(\d+)\] (.+)')
|
|
||||||
if len(parts) > 3
|
|
||||||
let err .= (parts[1] ==? 'W' || parts[1] ==? 'E' ? parts[1] : 'E') . ':' . parts[2] . ':' . parts[3]
|
|
||||||
call add(out, err)
|
|
||||||
let idx +=1
|
|
||||||
endif
|
|
||||||
elseif a:errors[idx] =~# '\m^\['
|
|
||||||
" unparseable errors
|
|
||||||
call add(out, a:errors[idx])
|
|
||||||
endif
|
|
||||||
let idx +=1
|
|
||||||
endwhile
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#bro(errors) abort " {{{2
|
|
||||||
let out = []
|
|
||||||
for e in a:errors
|
|
||||||
let parts = matchlist(e, '\v^%(fatal )?(error|warning) in (.{-1,}), line (\d+): (.+)')
|
|
||||||
if len(parts) > 4
|
|
||||||
let parts[1] = parts[1][0]
|
|
||||||
call add(out, join(parts[1:4], ':'))
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#coffeelint(errors) abort " {{{2
|
|
||||||
let out = []
|
|
||||||
for e in a:errors
|
|
||||||
let parts = matchlist(e, '\v^(.{-1,}),(\d+)%(,\d*)?,(error|warn),(.+)')
|
|
||||||
if len(parts) > 4
|
|
||||||
let parts[3] = parts[3][0]
|
|
||||||
call add(out, join(parts[1:4], ':'))
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#mypy(errors) abort " {{{2
|
|
||||||
let out = []
|
|
||||||
for e in a:errors
|
|
||||||
" new format
|
|
||||||
let parts = matchlist(e, '\v^(.{-1,}):(\d+): error: (.+)')
|
|
||||||
if len(parts) > 3
|
|
||||||
call add(out, join(parts[1:3], ':'))
|
|
||||||
continue
|
|
||||||
endif
|
|
||||||
|
|
||||||
" old format
|
|
||||||
let parts = matchlist(e, '\v^(.{-1,}), line (\d+): (.+)')
|
|
||||||
if len(parts) > 3
|
|
||||||
call add(out, join(parts[1:3], ':'))
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#preprocess#nix(errors) abort " {{{2
|
|
||||||
let out = []
|
|
||||||
for e in a:errors
|
|
||||||
let parts = matchlist(e, '\v^(.{-1,}), at (.{-1,}):(\d+):(\d+)$')
|
|
||||||
if len(parts) > 4
|
|
||||||
call add(out, join(parts[2:4], ':') . ':' . parts[1])
|
|
||||||
continue
|
|
||||||
endif
|
|
||||||
|
|
||||||
let parts = matchlist(e, '\v^(.{-1,}) at (.{-1,}), line (\d+):')
|
|
||||||
if len(parts) > 3
|
|
||||||
call add(out, parts[2] . ':' . parts[3] . ':' . parts[1])
|
|
||||||
continue
|
|
||||||
endif
|
|
||||||
|
|
||||||
let parts = matchlist(e, '\v^error: (.{-1,}), in (.{-1,})$')
|
|
||||||
if len(parts) > 2
|
|
||||||
call add(out, parts[2] . ':' . parts[1])
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Private functions {{{1
|
|
||||||
|
|
||||||
" @vimlint(EVL102, 1, l:true)
|
|
||||||
" @vimlint(EVL102, 1, l:false)
|
|
||||||
" @vimlint(EVL102, 1, l:null)
|
|
||||||
function! s:_decode_JSON(json) abort " {{{2
|
|
||||||
if a:json ==# ''
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
|
|
||||||
" The following is inspired by https://github.com/MarcWeber/vim-addon-manager and
|
|
||||||
" http://stackoverflow.com/questions/17751186/iterating-over-a-string-in-vimscript-or-parse-a-json-file/19105763#19105763
|
|
||||||
" A hat tip to Marc Weber for this trick
|
|
||||||
if substitute(a:json, '\v\"%(\\.|[^"\\])*\"|true|false|null|[+-]?\d+%(\.\d+%([Ee][+-]?\d+)?)?', '', 'g') !~# "[^,:{}[\\] \t]"
|
|
||||||
" JSON artifacts
|
|
||||||
let true = 1
|
|
||||||
let false = 0
|
|
||||||
let null = ''
|
|
||||||
|
|
||||||
try
|
|
||||||
let object = eval(a:json)
|
|
||||||
catch
|
|
||||||
" malformed JSON
|
|
||||||
let object = ''
|
|
||||||
endtry
|
|
||||||
else
|
|
||||||
let object = ''
|
|
||||||
endif
|
|
||||||
|
|
||||||
return object
|
|
||||||
endfunction " }}}2
|
|
||||||
" @vimlint(EVL102, 0, l:true)
|
|
||||||
" @vimlint(EVL102, 0, l:false)
|
|
||||||
" @vimlint(EVL102, 0, l:null)
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,622 +0,0 @@
|
|||||||
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() abort " {{{2
|
|
||||||
return has('win16') || has('win32') || has('win64')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#util#DevNull() abort " {{{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
|
|
||||||
|
|
||||||
function! syntastic#util#CygwinPath(path) abort " {{{2
|
|
||||||
return substitute(syntastic#util#system('cygpath -m ' . syntastic#util#shescape(a:path)), "\n", '', 'g')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#util#system(command) abort " {{{2
|
|
||||||
let old_shell = &shell
|
|
||||||
let old_lc_messages = $LC_MESSAGES
|
|
||||||
let old_lc_all = $LC_ALL
|
|
||||||
|
|
||||||
let &shell = syntastic#util#var('shell')
|
|
||||||
let $LC_MESSAGES = 'C'
|
|
||||||
let $LC_ALL = ''
|
|
||||||
|
|
||||||
let crashed = 0
|
|
||||||
let cmd_start = reltime()
|
|
||||||
try
|
|
||||||
let out = system(a:command)
|
|
||||||
catch
|
|
||||||
let crashed = 1
|
|
||||||
call syntastic#log#error('exception running system(' . string(a:command) . '): ' . v:exception)
|
|
||||||
if syntastic#util#isRunningWindows()
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, '$TMP = ' . string($TMP) . ', $TEMP = ' . string($TEMP))
|
|
||||||
else
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, '$TERM = ' . string($TERM))
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, '$TMPDIR = ' . string($TMPDIR))
|
|
||||||
endif
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, '$PATH = ' . string($PATH))
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, 'getcwd() = ' . string(getcwd()))
|
|
||||||
call syntastic#log#debugShowOptions(g:_SYNTASTIC_DEBUG_TRACE, g:_SYNTASTIC_SHELL_OPTIONS)
|
|
||||||
let out = ''
|
|
||||||
endtry
|
|
||||||
let cmd_time = split(reltimestr(reltime(cmd_start)))[0]
|
|
||||||
|
|
||||||
let $LC_ALL = old_lc_all
|
|
||||||
let $LC_MESSAGES = old_lc_messages
|
|
||||||
|
|
||||||
let &shell = old_shell
|
|
||||||
|
|
||||||
if !crashed && exists('g:_SYNTASTIC_DEBUG_TRACE')
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, 'system: command run in ' . cmd_time . 's')
|
|
||||||
endif
|
|
||||||
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Create a temporary directory
|
|
||||||
function! syntastic#util#tmpdir() abort " {{{2
|
|
||||||
let tempdir = ''
|
|
||||||
|
|
||||||
if (has('unix') || has('mac')) && executable('mktemp') && !has('win32unix')
|
|
||||||
" TODO: option "-t" to mktemp(1) is not portable
|
|
||||||
let tmp = $TMPDIR !=# '' ? $TMPDIR : $TMP !=# '' ? $TMP : '/tmp'
|
|
||||||
let out = split(syntastic#util#system('mktemp -q -d ' . tmp . '/vim-syntastic-' . getpid() . '-XXXXXXXX'), "\n")
|
|
||||||
if v:shell_error == 0 && len(out) == 1
|
|
||||||
let tempdir = out[0]
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
if tempdir ==# ''
|
|
||||||
if has('win32') || has('win64')
|
|
||||||
let tempdir = $TEMP . syntastic#util#Slash() . 'vim-syntastic-' . getpid()
|
|
||||||
elseif has('win32unix')
|
|
||||||
let tempdir = syntastic#util#CygwinPath('/tmp/vim-syntastic-' . getpid())
|
|
||||||
elseif $TMPDIR !=# ''
|
|
||||||
let tempdir = $TMPDIR . '/vim-syntastic-' . getpid()
|
|
||||||
else
|
|
||||||
let tempdir = '/tmp/vim-syntastic-' . getpid()
|
|
||||||
endif
|
|
||||||
|
|
||||||
try
|
|
||||||
call mkdir(tempdir, 'p', 0700)
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E739/
|
|
||||||
call syntastic#log#error(v:exception)
|
|
||||||
let tempdir = '.'
|
|
||||||
endtry
|
|
||||||
endif
|
|
||||||
|
|
||||||
return tempdir
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Recursively remove a directory
|
|
||||||
function! syntastic#util#rmrf(what) abort " {{{2
|
|
||||||
" try to make sure we don't delete directories we didn't create
|
|
||||||
if a:what !~? 'vim-syntastic-'
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
if getftype(a:what) ==# 'dir'
|
|
||||||
call s:_delete(a:what, 'rf')
|
|
||||||
else
|
|
||||||
silent! call delete(a:what)
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#util#getbufvar(buf, name, ...) abort " {{{2
|
|
||||||
return a:0 ? s:_getbufvar(a:buf, a:name, a:1) : getbufvar(a:buf, a:name)
|
|
||||||
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(buf) abort " {{{2
|
|
||||||
for lnum in range(1, 5)
|
|
||||||
let line = get(getbufline(a:buf, lnum), 0, '')
|
|
||||||
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 Vim variable. Allow buffer variables to override global ones.
|
|
||||||
function! syntastic#util#bufRawVar(buf, name, ...) abort " {{{2
|
|
||||||
return s:_getbufvar(a:buf, a:name, get(g:, a:name, a:0 ? a:1 : ''))
|
|
||||||
endfunction "}}}2
|
|
||||||
|
|
||||||
" Get the value of a syntastic variable. Allow buffer variables to override global ones.
|
|
||||||
function! syntastic#util#bufVar(buf, name, ...) abort " {{{2
|
|
||||||
return call('syntastic#util#bufRawVar', [a:buf, 'syntastic_' . a:name] + a:000)
|
|
||||||
endfunction "}}}2
|
|
||||||
|
|
||||||
" Get the value of a Vim variable. Allow local variables to override global ones.
|
|
||||||
function! syntastic#util#rawVar(name, ...) abort " {{{2
|
|
||||||
return get(b:, a:name, get(g:, a:name, a:0 ? a:1 : ''))
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Get the value of a syntastic variable. Allow local variables to override global ones.
|
|
||||||
function! syntastic#util#var(name, ...) abort " {{{2
|
|
||||||
return call('syntastic#util#rawVar', ['syntastic_' . a:name] + a:000)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Parse a version string. Return an array of version components.
|
|
||||||
function! syntastic#util#parseVersion(version, ...) abort " {{{2
|
|
||||||
return map(split(matchstr( a:version, a:0 ? a:1 : '\v^\D*\zs\d+(\.\d+)+\ze' ), '\m\.'), 'str2nr(v:val)')
|
|
||||||
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) abort " {{{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) abort " {{{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
|
|
||||||
" still here, thus everything matched
|
|
||||||
return 0
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#util#screenWidth(str, tabstop) abort " {{{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) abort " {{{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) abort " {{{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 named a:what; return path to that file
|
|
||||||
function! syntastic#util#findFileInParent(what, where) abort " {{{2
|
|
||||||
let old_suffixesadd = &suffixesadd
|
|
||||||
let &suffixesadd = ''
|
|
||||||
let file = findfile(a:what, escape(a:where, ' ') . ';')
|
|
||||||
let &suffixesadd = old_suffixesadd
|
|
||||||
return file
|
|
||||||
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#findGlobInParent(what, where) abort " {{{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 !=# ''
|
|
||||||
try
|
|
||||||
" Vim 7.4.279 and later
|
|
||||||
let p = globpath(here, a:what, 1, 1)
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E118/
|
|
||||||
let p = split(globpath(here, a:what, 1), "\n")
|
|
||||||
endtry
|
|
||||||
|
|
||||||
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 the buffer number of a filename
|
|
||||||
" @vimlint(EVL104, 1, l:old_shellslash)
|
|
||||||
function! syntastic#util#fname2buf(fname) abort " {{{2
|
|
||||||
if exists('+shellslash')
|
|
||||||
" bufnr() can't cope with backslashes
|
|
||||||
let old_shellslash = &shellslash
|
|
||||||
let &shellslash = 1
|
|
||||||
endif
|
|
||||||
|
|
||||||
" this is a best-effort attempt to escape file patterns (cf. :h file-pattern)
|
|
||||||
" XXX it fails for filenames containing something like \{2,3}
|
|
||||||
for md in [':~:.', ':~', ':p']
|
|
||||||
let buf = bufnr('^' . escape(fnamemodify(a:fname, md), '\*?,{}[') . '$')
|
|
||||||
if buf != -1
|
|
||||||
break
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
if buf == -1
|
|
||||||
" XXX definitely wrong, but hope is the last thing to die :)
|
|
||||||
let buf = bufnr(fnamemodify(a:fname, ':p'))
|
|
||||||
endif
|
|
||||||
|
|
||||||
if exists('+shellslash')
|
|
||||||
let &shellslash = old_shellslash
|
|
||||||
endif
|
|
||||||
|
|
||||||
return buf
|
|
||||||
endfunction " }}}2
|
|
||||||
" @vimlint(EVL104, 0, l:old_shellslash)
|
|
||||||
|
|
||||||
" Returns unique elements in a list
|
|
||||||
function! syntastic#util#unique(list) abort " {{{2
|
|
||||||
let seen = {}
|
|
||||||
let uniques = []
|
|
||||||
for e in a:list
|
|
||||||
let k = string(e)
|
|
||||||
if !has_key(seen, k)
|
|
||||||
let seen[k] = 1
|
|
||||||
call add(uniques, e)
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return uniques
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" A less noisy shellescape()
|
|
||||||
function! syntastic#util#shescape(string) abort " {{{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, ...) abort " {{{2
|
|
||||||
return syntastic#util#shescape(a:0 ? expand(a:string, a:1) : expand(a:string, 1))
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Escape arguments
|
|
||||||
function! syntastic#util#argsescape(opt) abort " {{{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
|
|
||||||
|
|
||||||
" Decode XML entities
|
|
||||||
function! syntastic#util#decodeXMLEntities(string) abort " {{{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) abort " {{{2
|
|
||||||
if a:full
|
|
||||||
redraw!
|
|
||||||
else
|
|
||||||
redraw
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#util#dictFilter(errors, filter) abort " {{{2
|
|
||||||
let rules = s:_translateFilter(a:filter)
|
|
||||||
" call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, "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 [seconds, fractions] list of strings, representing the
|
|
||||||
" (hopefully high resolution) time since program start
|
|
||||||
function! syntastic#util#stamp() abort " {{{2
|
|
||||||
return split( split(reltimestr(reltime(g:_SYNTASTIC_START)))[0], '\.' )
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#util#setLastTick(buf) abort " {{{2
|
|
||||||
call setbufvar(a:buf, 'syntastic_lasttick', getbufvar(a:buf, 'changedtick'))
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
let s:_wid_base = 'syntastic_' . getpid() . '_' . reltimestr(g:_SYNTASTIC_START) . '_'
|
|
||||||
let s:_wid_pool = 0
|
|
||||||
|
|
||||||
" Add unique IDs to windows
|
|
||||||
function! syntastic#util#setWids() abort " {{{2
|
|
||||||
for tab in range(1, tabpagenr('$'))
|
|
||||||
for win in range(1, tabpagewinnr(tab, '$'))
|
|
||||||
if gettabwinvar(tab, win, 'syntastic_wid') ==# ''
|
|
||||||
call settabwinvar(tab, win, 'syntastic_wid', s:_wid_base . s:_wid_pool)
|
|
||||||
let s:_wid_pool += 1
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
endfor
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#util#str2float(val) abort " {{{2
|
|
||||||
return s:_str2float(a:val)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! syntastic#util#float2str(val) abort " {{{2
|
|
||||||
return s:_float2str(a:val)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Crude printf()-like width formatter. Handles wide characters.
|
|
||||||
function! syntastic#util#wformat(format, str) abort " {{{2
|
|
||||||
if a:format ==# ''
|
|
||||||
return a:str
|
|
||||||
endif
|
|
||||||
|
|
||||||
echomsg string(a:format) . ', ' . string(a:str)
|
|
||||||
let specs = matchlist(a:format, '\v^(-?)(0?)(%([1-9]\d*))?%(\.(\d+))?$')
|
|
||||||
if len(specs) < 5
|
|
||||||
return a:str
|
|
||||||
endif
|
|
||||||
|
|
||||||
let flushleft = specs[1] ==# '-'
|
|
||||||
let lpad = specs[2] ==# '0' ? '0' : ' '
|
|
||||||
let minlen = str2nr(specs[3])
|
|
||||||
let maxlen = str2nr(specs[4])
|
|
||||||
let out = substitute(a:str, "\t", ' ', 'g')
|
|
||||||
|
|
||||||
if maxlen && s:_width(out) > maxlen
|
|
||||||
let chars = filter(split(out, '\zs\ze', 1), 'v:val !=# ""')
|
|
||||||
let out = ''
|
|
||||||
|
|
||||||
if flushleft
|
|
||||||
for c in chars
|
|
||||||
if s:_width(out . c) < maxlen
|
|
||||||
let out .= c
|
|
||||||
else
|
|
||||||
let out .= &encoding ==# 'utf-8' && &termencoding ==# 'utf-8' ? "\u2026" : '>'
|
|
||||||
break
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
call reverse(chars)
|
|
||||||
for c in chars
|
|
||||||
if s:_width(c . out) < maxlen
|
|
||||||
let out = c . out
|
|
||||||
else
|
|
||||||
let out = (&encoding ==# 'utf-8' && &termencoding ==# 'utf-8' ? "\u2026" : '<') . out
|
|
||||||
break
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
if minlen && s:_width(out) < minlen
|
|
||||||
if flushleft
|
|
||||||
let out .= repeat(' ', minlen - s:_width(out))
|
|
||||||
else
|
|
||||||
let out = repeat(lpad, minlen - s:_width(out)) . out
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
return out
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Private functions {{{1
|
|
||||||
|
|
||||||
function! s:_translateFilter(filters) abort " {{{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) abort " {{{2
|
|
||||||
let fkey = a:key
|
|
||||||
if fkey[0] ==# '!'
|
|
||||||
let fkey = fkey[1:]
|
|
||||||
let not = 1
|
|
||||||
else
|
|
||||||
let not = 0
|
|
||||||
endif
|
|
||||||
|
|
||||||
if fkey ==? 'level'
|
|
||||||
let op = not ? ' ==? ' : ' !=? '
|
|
||||||
let ret = 'v:val["type"]' . op . string(a:term[0])
|
|
||||||
elseif fkey ==? 'type'
|
|
||||||
if a:term ==? 'style'
|
|
||||||
let op = not ? ' ==? ' : ' !=? '
|
|
||||||
let ret = 'get(v:val, "subtype", "")' . op . '"style"'
|
|
||||||
else
|
|
||||||
let op = not ? '!' : ''
|
|
||||||
let ret = op . 'has_key(v:val, "subtype")'
|
|
||||||
endif
|
|
||||||
elseif fkey ==? 'regex'
|
|
||||||
let op = not ? ' =~? ' : ' !~? '
|
|
||||||
let ret = 'v:val["text"]' . op . string(a:term)
|
|
||||||
elseif fkey ==? 'file' || fkey[:4] ==? 'file:'
|
|
||||||
let op = not ? ' =~# ' : ' !~# '
|
|
||||||
let ret = 'bufname(str2nr(v:val["bufnr"]))'
|
|
||||||
let mod = fkey[4:]
|
|
||||||
if mod !=# ''
|
|
||||||
let ret = 'fnamemodify(' . ret . ', ' . string(mod) . ')'
|
|
||||||
endif
|
|
||||||
let ret .= op . string(a:term)
|
|
||||||
else
|
|
||||||
call syntastic#log#warn('quiet_messages: ignoring invalid key ' . strtrans(string(fkey)))
|
|
||||||
let ret = '1'
|
|
||||||
endif
|
|
||||||
return ret
|
|
||||||
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
|
|
||||||
|
|
||||||
" @vimlint(EVL103, 1, a:flags)
|
|
||||||
function! s:_delete_dumb(what, flags) abort " {{{2
|
|
||||||
if !exists('s:rmrf')
|
|
||||||
let s:rmrf =
|
|
||||||
\ has('unix') || has('mac') ? 'rm -rf' :
|
|
||||||
\ has('win32') || has('win64') ? 'rmdir /S /Q' :
|
|
||||||
\ has('win16') || has('win95') || has('dos16') || has('dos32') ? 'deltree /Y' : ''
|
|
||||||
endif
|
|
||||||
|
|
||||||
if s:rmrf !=# ''
|
|
||||||
silent! call syntastic#util#system(s:rmrf . ' ' . syntastic#util#shescape(a:what))
|
|
||||||
else
|
|
||||||
call s:_rmrf(a:what)
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
" @vimlint(EVL103, 0, a:flags)
|
|
||||||
|
|
||||||
" delete(dir, 'rf') was added in Vim 7.4.1107, but it didn't become usable until 7.4.1128
|
|
||||||
let s:_delete = function(v:version > 704 || (v:version == 704 && has('patch1128')) ? 'delete' : 's:_delete_dumb')
|
|
||||||
lockvar s:_delete
|
|
||||||
|
|
||||||
function! s:_rmrf(what) abort " {{{2
|
|
||||||
if !exists('s:rmdir')
|
|
||||||
let s:rmdir = syntastic#util#shescape(get(g:, 'netrw_localrmdir', 'rmdir'))
|
|
||||||
endif
|
|
||||||
|
|
||||||
if getftype(a:what) ==# 'dir'
|
|
||||||
if filewritable(a:what) != 2
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
try
|
|
||||||
" Vim 7.4.279 and later
|
|
||||||
let entries = globpath(a:what, '*', 1, 1)
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E118/
|
|
||||||
let entries = split(globpath(a:what, '*', 1), "\n")
|
|
||||||
endtry
|
|
||||||
for f in entries
|
|
||||||
call s:_rmrf(f)
|
|
||||||
endfor
|
|
||||||
silent! call syntastic#util#system(s:rmdir . ' ' . syntastic#util#shescape(a:what))
|
|
||||||
else
|
|
||||||
silent! call delete(a:what)
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
let s:_str2float = function(exists('*str2float') ? 'str2float' : 'str2nr')
|
|
||||||
lockvar s:_str2float
|
|
||||||
|
|
||||||
function! s:_float2str_smart(val) abort " {{{2
|
|
||||||
return printf('%.1f', a:val)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! s:_float2str_dumb(val) abort " {{{2
|
|
||||||
return a:val
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
let s:_float2str = function(has('float') ? 's:_float2str_smart' : 's:_float2str_dumb')
|
|
||||||
lockvar s:_float2str
|
|
||||||
|
|
||||||
function! s:_getbufvar_dumb(buf, name, ...) abort " {{{2
|
|
||||||
let ret = getbufvar(a:buf, a:name)
|
|
||||||
if a:0 && type(ret) == type('') && ret ==# ''
|
|
||||||
unlet! ret
|
|
||||||
let ret = a:1
|
|
||||||
endif
|
|
||||||
return ret
|
|
||||||
endfunction "}}}2
|
|
||||||
|
|
||||||
let s:_getbufvar = function(v:version > 703 || (v:version == 703 && has('patch831')) ? 'getbufvar' : 's:_getbufvar_dumb')
|
|
||||||
lockvar s:_getbufvar
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -1,795 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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') || &compatible
|
|
||||||
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.8.0-56'
|
|
||||||
lockvar g:_SYNTASTIC_VERSION
|
|
||||||
|
|
||||||
" Sanity checks {{{1
|
|
||||||
|
|
||||||
if v:version < 700 || (v:version == 700 && !has('patch175'))
|
|
||||||
call syntastic#log#error('need Vim version 7.0.175 or later')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
for s:feature in [
|
|
||||||
\ 'autocmd',
|
|
||||||
\ 'eval',
|
|
||||||
\ 'file_in_path',
|
|
||||||
\ 'modify_fname',
|
|
||||||
\ 'quickfix',
|
|
||||||
\ 'reltime',
|
|
||||||
\ 'statusline',
|
|
||||||
\ '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 !exists('g:syntastic_shell')
|
|
||||||
let g:syntastic_shell = &shell
|
|
||||||
endif
|
|
||||||
|
|
||||||
if s:_running_windows
|
|
||||||
let g:_SYNTASTIC_UNAME = 'Windows'
|
|
||||||
elseif executable('uname')
|
|
||||||
try
|
|
||||||
let g:_SYNTASTIC_UNAME = split(syntastic#util#system('uname'), "\n")[0]
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E484/
|
|
||||||
call syntastic#log#error("can't run external programs (misconfigured shell options?)")
|
|
||||||
finish
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E684/
|
|
||||||
let g:_SYNTASTIC_UNAME = 'Unknown'
|
|
||||||
endtry
|
|
||||||
else
|
|
||||||
let g:_SYNTASTIC_UNAME = 'Unknown'
|
|
||||||
endif
|
|
||||||
lockvar g:_SYNTASTIC_UNAME
|
|
||||||
|
|
||||||
" XXX Ugly hack to make g:_SYNTASTIC_UNAME available to :SyntasticInfo without
|
|
||||||
" polluting session namespaces
|
|
||||||
let g:syntastic_version =
|
|
||||||
\ g:_SYNTASTIC_VERSION .
|
|
||||||
\ ' (Vim ' . v:version . (has('nvim') ? ', Neovim' : '') . ', ' .
|
|
||||||
\ g:_SYNTASTIC_UNAME .
|
|
||||||
\ (has('gui') ? ', GUI' : '') . ')'
|
|
||||||
lockvar g:syntastic_version
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Defaults {{{1
|
|
||||||
|
|
||||||
let g:_SYNTASTIC_DEFAULTS = {
|
|
||||||
\ 'aggregate_errors': 0,
|
|
||||||
\ 'always_populate_loc_list': 0,
|
|
||||||
\ 'auto_jump': 0,
|
|
||||||
\ 'auto_loc_list': 2,
|
|
||||||
\ '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': '>>',
|
|
||||||
\ 'exit_checks': !(s:_running_windows && syntastic#util#var('shell', &shell) =~? '\m\<cmd\.exe$'),
|
|
||||||
\ '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,
|
|
||||||
\ 'nested_autocommands': 0,
|
|
||||||
\ 'quiet_messages': {},
|
|
||||||
\ 'reuse_loc_lists': 1,
|
|
||||||
\ 'shell': &shell,
|
|
||||||
\ '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} = copy(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 g:_SYNTASTIC_SHELL_OPTIONS = [
|
|
||||||
\ 'shell',
|
|
||||||
\ 'shellcmdflag',
|
|
||||||
\ 'shellpipe',
|
|
||||||
\ 'shellquote',
|
|
||||||
\ 'shellredir',
|
|
||||||
\ 'shelltemp',
|
|
||||||
\ 'shellxquote'
|
|
||||||
\ ]
|
|
||||||
for s:feature in [
|
|
||||||
\ 'autochdir',
|
|
||||||
\ 'shellslash',
|
|
||||||
\ 'shellxescape',
|
|
||||||
\ ]
|
|
||||||
|
|
||||||
if exists('+' . s:feature)
|
|
||||||
call add(g:_SYNTASTIC_SHELL_OPTIONS, s:feature)
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
lockvar! g:_SYNTASTIC_SHELL_OPTIONS
|
|
||||||
|
|
||||||
" debug constants
|
|
||||||
let g:_SYNTASTIC_DEBUG_TRACE = 1
|
|
||||||
lockvar g:_SYNTASTIC_DEBUG_TRACE
|
|
||||||
let g:_SYNTASTIC_DEBUG_LOCLIST = 2
|
|
||||||
lockvar g:_SYNTASTIC_DEBUG_LOCLIST
|
|
||||||
let g:_SYNTASTIC_DEBUG_NOTIFICATIONS = 4
|
|
||||||
lockvar g:_SYNTASTIC_DEBUG_NOTIFICATIONS
|
|
||||||
let g:_SYNTASTIC_DEBUG_AUTOCOMMANDS = 8
|
|
||||||
lockvar g:_SYNTASTIC_DEBUG_AUTOCOMMANDS
|
|
||||||
let g:_SYNTASTIC_DEBUG_VARIABLES = 16
|
|
||||||
lockvar g:_SYNTASTIC_DEBUG_VARIABLES
|
|
||||||
let g:_SYNTASTIC_DEBUG_CHECKERS = 32
|
|
||||||
lockvar g:_SYNTASTIC_DEBUG_CHECKERS
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
runtime! plugin/syntastic/*.vim
|
|
||||||
|
|
||||||
let s:registry = g:SyntasticRegistry.Instance()
|
|
||||||
let s:notifiers = g:SyntasticNotifiers.Instance()
|
|
||||||
let s:modemap = g:SyntasticModeMap.Instance()
|
|
||||||
|
|
||||||
let s:_check_stack = []
|
|
||||||
let s:_quit_pre = []
|
|
||||||
|
|
||||||
" Commands {{{1
|
|
||||||
|
|
||||||
" @vimlint(EVL103, 1, a:cursorPos)
|
|
||||||
" @vimlint(EVL103, 1, a:cmdLine)
|
|
||||||
" @vimlint(EVL103, 1, a:argLead)
|
|
||||||
function! s:CompleteCheckerName(argLead, cmdLine, cursorPos) abort " {{{2
|
|
||||||
let names = []
|
|
||||||
|
|
||||||
let sep_idx = stridx(a:argLead, '/')
|
|
||||||
if sep_idx >= 1
|
|
||||||
let ft = a:argLead[: sep_idx-1]
|
|
||||||
call extend(names, map( s:registry.getNamesOfAvailableCheckers(ft), 'ft . "/" . v:val' ))
|
|
||||||
else
|
|
||||||
for ft in s:registry.resolveFiletypes(&filetype)
|
|
||||||
call extend(names, s:registry.getNamesOfAvailableCheckers(ft))
|
|
||||||
endfor
|
|
||||||
call extend(names, map( copy(s:registry.getKnownFiletypes()), 'v:val . "/"' ))
|
|
||||||
endif
|
|
||||||
|
|
||||||
return join(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) abort " {{{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! -bar -nargs=* -complete=custom,s:CompleteCheckerName SyntasticCheck call SyntasticCheck(<f-args>)
|
|
||||||
command! -bar -nargs=? -complete=custom,s:CompleteFiletypes SyntasticInfo call SyntasticInfo(<f-args>)
|
|
||||||
command! -bar Errors call SyntasticErrors()
|
|
||||||
command! -bar SyntasticReset call SyntasticReset()
|
|
||||||
command! -bar SyntasticToggleMode call SyntasticToggleMode()
|
|
||||||
command! -bar SyntasticSetLoclist call SyntasticSetLoclist()
|
|
||||||
|
|
||||||
command! SyntasticJavacEditClasspath runtime! syntax_checkers/java/*.vim | SyntasticJavacEditClasspath
|
|
||||||
command! SyntasticJavacEditConfig runtime! syntax_checkers/java/*.vim | SyntasticJavacEditConfig
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Public API {{{1
|
|
||||||
|
|
||||||
function! SyntasticCheck(...) abort " {{{2
|
|
||||||
call s:UpdateErrors(bufnr(''), 0, a:000)
|
|
||||||
call syntastic#util#redraw(g:syntastic_full_redraws)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! SyntasticInfo(...) abort " {{{2
|
|
||||||
call s:modemap.modeInfo(a:000)
|
|
||||||
call s:registry.echoInfoFor(a:000)
|
|
||||||
call s:_explain_skip(a:000)
|
|
||||||
call syntastic#log#debugShowOptions(g:_SYNTASTIC_DEBUG_TRACE, g:_SYNTASTIC_SHELL_OPTIONS)
|
|
||||||
call syntastic#log#debugDump(g:_SYNTASTIC_DEBUG_VARIABLES)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! SyntasticErrors() abort " {{{2
|
|
||||||
call g:SyntasticLoclist.current().show()
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! SyntasticReset() abort " {{{2
|
|
||||||
call s:ClearCache(bufnr(''))
|
|
||||||
call s:notifiers.refresh(g:SyntasticLoclist.New([]))
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! SyntasticToggleMode() abort " {{{2
|
|
||||||
call s:modemap.toggleMode()
|
|
||||||
call s:ClearCache(bufnr(''))
|
|
||||||
call s:notifiers.refresh(g:SyntasticLoclist.New([]))
|
|
||||||
call s:modemap.echoMode()
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! SyntasticSetLoclist() abort " {{{2
|
|
||||||
call g:SyntasticLoclist.current().setloclist(0)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Autocommands {{{1
|
|
||||||
|
|
||||||
augroup syntastic
|
|
||||||
autocmd!
|
|
||||||
autocmd VimEnter * call s:VimEnterHook()
|
|
||||||
autocmd BufEnter * call s:BufEnterHook(expand('<afile>', 1))
|
|
||||||
autocmd BufWinEnter * call s:BufWinEnterHook(expand('<afile>', 1))
|
|
||||||
augroup END
|
|
||||||
|
|
||||||
if g:syntastic_nested_autocommands
|
|
||||||
augroup syntastic
|
|
||||||
autocmd BufReadPost * nested call s:BufReadPostHook(expand('<afile>', 1))
|
|
||||||
autocmd BufWritePost * nested call s:BufWritePostHook(expand('<afile>', 1))
|
|
||||||
augroup END
|
|
||||||
else
|
|
||||||
augroup syntastic
|
|
||||||
autocmd BufReadPost * call s:BufReadPostHook(expand('<afile>', 1))
|
|
||||||
autocmd BufWritePost * call s:BufWritePostHook(expand('<afile>', 1))
|
|
||||||
augroup END
|
|
||||||
endif
|
|
||||||
|
|
||||||
if exists('##QuitPre')
|
|
||||||
" QuitPre was added in Vim 7.3.544
|
|
||||||
augroup syntastic
|
|
||||||
autocmd QuitPre * call s:QuitPreHook(expand('<afile>', 1))
|
|
||||||
augroup END
|
|
||||||
endif
|
|
||||||
|
|
||||||
function! s:BufReadPostHook(fname) abort " {{{2
|
|
||||||
let buf = syntastic#util#fname2buf(a:fname)
|
|
||||||
if g:syntastic_check_on_open && buf > 0
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_AUTOCOMMANDS,
|
|
||||||
\ 'autocmd: BufReadPost, buffer ' . buf . ' = ' . string(a:fname))
|
|
||||||
if index(s:_check_stack, buf) == -1
|
|
||||||
call add(s:_check_stack, buf)
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! s:BufWritePostHook(fname) abort " {{{2
|
|
||||||
let buf = syntastic#util#fname2buf(a:fname)
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_AUTOCOMMANDS,
|
|
||||||
\ 'autocmd: BufWritePost, buffer ' . buf . ' = ' . string(a:fname))
|
|
||||||
call s:UpdateErrors(buf, 1, [])
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! s:BufEnterHook(fname) abort " {{{2
|
|
||||||
let buf = syntastic#util#fname2buf(a:fname)
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_AUTOCOMMANDS,
|
|
||||||
\ 'autocmd: BufEnter, buffer ' . buf . ' = ' . string(a:fname) . ', &buftype = ' . string(&buftype))
|
|
||||||
if buf > 0 && getbufvar(buf, '&buftype') ==# ''
|
|
||||||
let idx = index(reverse(copy(s:_check_stack)), buf)
|
|
||||||
if idx >= 0
|
|
||||||
if !has('vim_starting')
|
|
||||||
call remove(s:_check_stack, -idx - 1)
|
|
||||||
call s:UpdateErrors(buf, 1, [])
|
|
||||||
endif
|
|
||||||
elseif &buftype ==# ''
|
|
||||||
call s:notifiers.refresh(g:SyntasticLoclist.current())
|
|
||||||
endif
|
|
||||||
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"]')
|
|
||||||
let owner = str2nr(getbufvar(buf, 'syntastic_owner_buffer'))
|
|
||||||
let buffers = syntastic#util#unique(map(loclist, 'v:val["bufnr"]') + (owner ? [owner] : []))
|
|
||||||
if !empty(get(w:, 'syntastic_loclist_set', [])) && !empty(loclist) && empty(filter( buffers, 'syntastic#util#bufIsActive(v:val)' ))
|
|
||||||
call SyntasticLoclistHide()
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! s:BufWinEnterHook(fname) abort " {{{2
|
|
||||||
let buf = syntastic#util#fname2buf(a:fname)
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_AUTOCOMMANDS,
|
|
||||||
\ 'autocmd: BufWinEnter, buffer ' . buf . ' = ' . string(a:fname) . ', &buftype = ' . string(&buftype))
|
|
||||||
if buf > 0 && getbufvar(buf, '&buftype') ==# ''
|
|
||||||
let idx = index(reverse(copy(s:_check_stack)), buf)
|
|
||||||
if idx >= 0 && !has('vim_starting')
|
|
||||||
call remove(s:_check_stack, -idx - 1)
|
|
||||||
call s:UpdateErrors(buf, 1, [])
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! s:VimEnterHook() abort " {{{2
|
|
||||||
let buf = bufnr('')
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_AUTOCOMMANDS,
|
|
||||||
\ 'autocmd: VimEnter, buffer ' . buf . ' = ' . string(bufname(buf)) . ', &buftype = ' . string(&buftype))
|
|
||||||
let idx = index(reverse(copy(s:_check_stack)), buf)
|
|
||||||
if idx >= 0 && getbufvar(buf, '&buftype') ==# ''
|
|
||||||
call remove(s:_check_stack, -idx - 1)
|
|
||||||
call s:UpdateErrors(buf, 1, [])
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! s:QuitPreHook(fname) abort " {{{2
|
|
||||||
let buf = syntastic#util#fname2buf(a:fname)
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_AUTOCOMMANDS, 'autocmd: QuitPre, buffer ' . buf . ' = ' . string(a:fname))
|
|
||||||
|
|
||||||
if !syntastic#util#var('check_on_wq')
|
|
||||||
call syntastic#util#setWids()
|
|
||||||
call add(s:_quit_pre, buf . '_' . getbufvar(buf, 'changetick') . '_' . w:syntastic_wid)
|
|
||||||
endif
|
|
||||||
|
|
||||||
if !empty(get(w:, 'syntastic_loclist_set', []))
|
|
||||||
call SyntasticLoclistHide()
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Main {{{1
|
|
||||||
|
|
||||||
"refresh and redraw all the error info for this buf when saving or reading
|
|
||||||
function! s:UpdateErrors(buf, auto_invoked, checker_names) abort " {{{2
|
|
||||||
call syntastic#log#debugShowVariables(g:_SYNTASTIC_DEBUG_TRACE, 'version')
|
|
||||||
call syntastic#log#debugShowOptions(g:_SYNTASTIC_DEBUG_TRACE, g:_SYNTASTIC_SHELL_OPTIONS)
|
|
||||||
call syntastic#log#debugDump(g:_SYNTASTIC_DEBUG_VARIABLES)
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, 'UpdateErrors' . (a:auto_invoked ? ' (auto)' : '') .
|
|
||||||
\ ': ' . (len(a:checker_names) ? join(a:checker_names) : 'default checkers'))
|
|
||||||
|
|
||||||
call s:modemap.synch()
|
|
||||||
|
|
||||||
if s:_skip_file(a:buf)
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
let run_checks = !a:auto_invoked || s:modemap.doAutoChecking(a:buf)
|
|
||||||
if run_checks
|
|
||||||
call s:CacheErrors(a:buf, a:checker_names)
|
|
||||||
call syntastic#util#setLastTick(a:buf)
|
|
||||||
elseif a:auto_invoked
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
let loclist = g:SyntasticLoclist.current(a:buf)
|
|
||||||
|
|
||||||
if exists('*SyntasticCheckHook')
|
|
||||||
call SyntasticCheckHook(loclist.getRaw())
|
|
||||||
endif
|
|
||||||
|
|
||||||
" populate loclist and jump {{{3
|
|
||||||
let do_jump = syntastic#util#var('auto_jump') + 0
|
|
||||||
if do_jump == 2
|
|
||||||
let do_jump = loclist.getFirstError(1)
|
|
||||||
elseif do_jump == 3
|
|
||||||
let do_jump = loclist.getFirstError()
|
|
||||||
elseif 0 > do_jump || do_jump > 3
|
|
||||||
let do_jump = 0
|
|
||||||
endif
|
|
||||||
|
|
||||||
if syntastic#util#var('always_populate_loc_list') || do_jump
|
|
||||||
call loclist.setloclist(1)
|
|
||||||
if run_checks && do_jump && !loclist.isEmpty()
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, 'loclist: jump')
|
|
||||||
execute 'silent! lrewind ' . do_jump
|
|
||||||
|
|
||||||
" 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(buf) abort " {{{2
|
|
||||||
let loclist = g:SyntasticLoclist.current(a:buf)
|
|
||||||
call s:notifiers.reset(loclist)
|
|
||||||
call loclist.destroy()
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
"detect and cache all syntax errors in this buffer
|
|
||||||
function! s:CacheErrors(buf, checker_names) abort " {{{2
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, 'CacheErrors: ' .
|
|
||||||
\ (len(a:checker_names) ? join(a:checker_names) : 'default checkers'))
|
|
||||||
call s:ClearCache(a:buf)
|
|
||||||
let newLoclist = g:SyntasticLoclist.New([])
|
|
||||||
call newLoclist.setOwner(a:buf)
|
|
||||||
|
|
||||||
if !s:_skip_file(a:buf)
|
|
||||||
" debug logging {{{3
|
|
||||||
call syntastic#log#debugShowVariables(g:_SYNTASTIC_DEBUG_TRACE, 'aggregate_errors')
|
|
||||||
if syntastic#util#isRunningWindows()
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, '$TMP = ' . string($TMP) . ', $TEMP = ' . string($TEMP))
|
|
||||||
else
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, '$TERM = ' . string($TERM))
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, '$TMPDIR = ' . string($TMPDIR))
|
|
||||||
endif
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, '$PATH = ' . string($PATH))
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, 'getcwd() = ' . string(getcwd()))
|
|
||||||
" }}}3
|
|
||||||
|
|
||||||
let clist = s:registry.getCheckers(getbufvar(a:buf, '&filetype'), a:checker_names)
|
|
||||||
|
|
||||||
let aggregate_errors =
|
|
||||||
\ syntastic#util#var('aggregate_errors') || len(syntastic#util#unique(map(copy(clist), 'v:val.getFiletype()'))) > 1
|
|
||||||
let decorate_errors = aggregate_errors && syntastic#util#var('id_checkers')
|
|
||||||
let sort_aggregated_errors = aggregate_errors && syntastic#util#var('sort_aggregated_errors')
|
|
||||||
|
|
||||||
let names = []
|
|
||||||
let unavailable_checkers = 0
|
|
||||||
for checker in clist
|
|
||||||
let cname = checker.getCName()
|
|
||||||
if !checker.isAvailable()
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, 'CacheErrors: Checker ' . cname . ' is not available')
|
|
||||||
let unavailable_checkers += 1
|
|
||||||
continue
|
|
||||||
endif
|
|
||||||
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, '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.wantSort() && !sort_aggregated_errors
|
|
||||||
call loclist.sort()
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_LOCLIST, 'sorted:', loclist)
|
|
||||||
endif
|
|
||||||
|
|
||||||
call 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:_SYNTASTIC_DEBUG_TRACE, 'CacheErrors: no checkers available for ' . &filetype)
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
" }}}3
|
|
||||||
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_LOCLIST, 'aggregated:', newLoclist)
|
|
||||||
if sort_aggregated_errors
|
|
||||||
call newLoclist.sort()
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_LOCLIST, 'sorted:', newLoclist)
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
call newLoclist.deploy()
|
|
||||||
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) abort " {{{2
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, 'SyntasticMake: called with options:', a:options)
|
|
||||||
|
|
||||||
" save options and locale env variables {{{3
|
|
||||||
let old_local_errorformat = &l:errorformat
|
|
||||||
let old_errorformat = &errorformat
|
|
||||||
let old_cwd = getcwd()
|
|
||||||
" }}}3
|
|
||||||
|
|
||||||
if has_key(a:options, 'errorformat')
|
|
||||||
let &errorformat = a:options['errorformat']
|
|
||||||
set 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_][a-z0-9_]*$'
|
|
||||||
execute 'let env_save[' . string(key) . '] = $' . key
|
|
||||||
execute 'let $' . key . ' = ' . string(a:options['env'][key])
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
endif
|
|
||||||
" }}}3
|
|
||||||
|
|
||||||
let err_lines = split(syntastic#util#system(a:options['makeprg']), "\n", 1)
|
|
||||||
|
|
||||||
" restore environment variables {{{3
|
|
||||||
if len(env_save)
|
|
||||||
for key in keys(env_save)
|
|
||||||
execute 'let $' . key . ' = ' . string(env_save[key])
|
|
||||||
endfor
|
|
||||||
endif
|
|
||||||
" }}}3
|
|
||||||
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_LOCLIST, 'checker output:', err_lines)
|
|
||||||
|
|
||||||
" Does it still make sense to go on?
|
|
||||||
let bailout =
|
|
||||||
\ syntastic#util#var('exit_checks') &&
|
|
||||||
\ has_key(a:options, 'returns') &&
|
|
||||||
\ index(a:options['returns'], v:shell_error) == -1
|
|
||||||
|
|
||||||
if !bailout
|
|
||||||
if has_key(a:options, 'Preprocess')
|
|
||||||
let err_lines = call(a:options['Preprocess'], [err_lines])
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_LOCLIST, '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:_SYNTASTIC_DEBUG_LOCLIST, 'preprocess:', err_lines)
|
|
||||||
endif
|
|
||||||
noautocmd lgetexpr err_lines
|
|
||||||
|
|
||||||
let errors = deepcopy(getloclist(0))
|
|
||||||
|
|
||||||
if has_key(a:options, 'cwd')
|
|
||||||
execute 'lcd ' . fnameescape(old_cwd)
|
|
||||||
endif
|
|
||||||
|
|
||||||
try
|
|
||||||
silent lolder
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E380/
|
|
||||||
" E380: At bottom of quickfix stack
|
|
||||||
call setloclist(0, [], 'r')
|
|
||||||
try
|
|
||||||
" Vim 7.4.2200 or later
|
|
||||||
call setloclist(0, [], 'r', { 'title': '' })
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E\%(118\|731\)/
|
|
||||||
" do nothing
|
|
||||||
endtry
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E776/
|
|
||||||
" E776: No location list
|
|
||||||
" do nothing
|
|
||||||
endtry
|
|
||||||
else
|
|
||||||
let errors = []
|
|
||||||
endif
|
|
||||||
|
|
||||||
" restore options {{{3
|
|
||||||
let &errorformat = old_errorformat
|
|
||||||
let &l:errorformat = old_local_errorformat
|
|
||||||
" }}}3
|
|
||||||
|
|
||||||
if !s:_running_windows && (s:_os_name() =~? 'FreeBSD' || s:_os_name() =~? 'OpenBSD')
|
|
||||||
call syntastic#util#redraw(g:syntastic_full_redraws)
|
|
||||||
endif
|
|
||||||
|
|
||||||
if bailout
|
|
||||||
call syntastic#log#ndebug(g:_SYNTASTIC_DEBUG_LOCLIST, 'checker output:', err_lines)
|
|
||||||
throw 'Syntastic: checker error'
|
|
||||||
endif
|
|
||||||
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_LOCLIST, 'raw loclist:', errors)
|
|
||||||
|
|
||||||
if has_key(a:options, 'defaults')
|
|
||||||
call s:_add_to_errors(errors, a:options['defaults'])
|
|
||||||
endif
|
|
||||||
|
|
||||||
" Add subtype info if present.
|
|
||||||
if has_key(a:options, 'subtype')
|
|
||||||
call s:_add_to_errors(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:_SYNTASTIC_DEBUG_LOCLIST, '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:_SYNTASTIC_DEBUG_LOCLIST, '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() abort " {{{2
|
|
||||||
return g:SyntasticLoclist.current().getStatuslineFlag()
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Utilities {{{1
|
|
||||||
|
|
||||||
function! s:_ignore_file(filename) abort " {{{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
|
|
||||||
|
|
||||||
function! s:_is_quitting(buf) abort " {{{2
|
|
||||||
let quitting = 0
|
|
||||||
if exists('w:syntastic_wid')
|
|
||||||
let key = a:buf . '_' . getbufvar(a:buf, 'changetick') . '_' . w:syntastic_wid
|
|
||||||
let idx = index(s:_quit_pre, key)
|
|
||||||
if idx >= 0
|
|
||||||
call remove(s:_quit_pre, idx)
|
|
||||||
let quitting = 1
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
return quitting
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Skip running in special buffers
|
|
||||||
function! s:_skip_file(buf) abort " {{{2
|
|
||||||
let fname = bufname(a:buf)
|
|
||||||
let skip = s:_is_quitting(a:buf) || getbufvar(a:buf, 'syntastic_skip_checks') ||
|
|
||||||
\ (getbufvar(a:buf, '&buftype') !=# '') || !filereadable(fname) || getwinvar(0, '&diff') ||
|
|
||||||
\ getwinvar(0, '&previewwindow') || s:_ignore_file(fname) ||
|
|
||||||
\ fnamemodify(fname, ':e') =~? g:syntastic_ignore_extensions
|
|
||||||
if skip
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, '_skip_file: skipping checks')
|
|
||||||
endif
|
|
||||||
return skip
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Explain why checks will be skipped for the current file
|
|
||||||
function! s:_explain_skip(filetypes) abort " {{{2
|
|
||||||
let buf = bufnr('')
|
|
||||||
if empty(a:filetypes) && s:_skip_file(buf)
|
|
||||||
let why = []
|
|
||||||
let fname = bufname(buf)
|
|
||||||
let bt = getbufvar(buf, '&buftype')
|
|
||||||
|
|
||||||
if s:_is_quitting(buf)
|
|
||||||
call add(why, 'quitting buffer')
|
|
||||||
endif
|
|
||||||
if getbufvar(buf, 'syntastic_skip_checks')
|
|
||||||
call add(why, 'b:syntastic_skip_checks set')
|
|
||||||
endif
|
|
||||||
if bt !=# ''
|
|
||||||
call add(why, 'buftype = ' . string(&buftype))
|
|
||||||
endif
|
|
||||||
if !filereadable(fname)
|
|
||||||
call add(why, 'file not readable / not local')
|
|
||||||
endif
|
|
||||||
if getwinvar(0, '&diff')
|
|
||||||
call add(why, 'diff mode')
|
|
||||||
endif
|
|
||||||
if getwinvar(0, '&previewwindow')
|
|
||||||
call add(why, 'preview window')
|
|
||||||
endif
|
|
||||||
if s:_ignore_file(fname)
|
|
||||||
call add(why, 'filename matching g:syntastic_ignore_files')
|
|
||||||
endif
|
|
||||||
if fnamemodify(fname, ':e') =~? g:syntastic_ignore_extensions
|
|
||||||
call add(why, 'extension matching g:syntastic_ignore_extensions')
|
|
||||||
endif
|
|
||||||
|
|
||||||
echomsg 'The current file will not be checked (' . join(why, ', ') . ')'
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Take a list of errors and add default values to them from a:options
|
|
||||||
function! s:_add_to_errors(errors, options) abort " {{{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
|
|
||||||
|
|
||||||
function! s:_os_name() abort " {{{2
|
|
||||||
return g:_SYNTASTIC_UNAME
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,55 +0,0 @@
|
|||||||
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() abort " {{{2
|
|
||||||
let newObj = copy(self)
|
|
||||||
return newObj
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticAutoloclistNotifier.refresh(loclist) abort " {{{2
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, 'autoloclist: refresh')
|
|
||||||
call g:SyntasticAutoloclistNotifier.AutoToggle(a:loclist)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticAutoloclistNotifier.AutoToggle(loclist) abort " {{{2
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, 'autoloclist: toggle')
|
|
||||||
let auto_loc_list = syntastic#util#var('auto_loc_list')
|
|
||||||
if !a:loclist.isEmpty()
|
|
||||||
if auto_loc_list == 1 || auto_loc_list == 3
|
|
||||||
call a:loclist.show()
|
|
||||||
endif
|
|
||||||
else
|
|
||||||
if (auto_loc_list == 1 || auto_loc_list == 2) && !empty(get(w:, 'syntastic_loclist_set', []))
|
|
||||||
try
|
|
||||||
" Vim 7.4.2200 or later
|
|
||||||
let title = get(getloclist(0, { 'title': 1 }), 'title', ':SyntasticCheck ')
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E\%(118\|731\)/
|
|
||||||
let title = ':SyntasticCheck '
|
|
||||||
endtry
|
|
||||||
|
|
||||||
if strpart(title, 0, 16) ==# ':SyntasticCheck '
|
|
||||||
" TODO: this will close the loc list window if one was opened
|
|
||||||
" by something other than syntastic
|
|
||||||
call SyntasticLoclistHide()
|
|
||||||
|
|
||||||
try
|
|
||||||
" Vim 7.4.2200 or later
|
|
||||||
call setloclist(0, [], 'r', { 'title': '' })
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E\%(118\|731\)/
|
|
||||||
" do nothing
|
|
||||||
endtry
|
|
||||||
let w:syntastic_loclist_set = []
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,59 +0,0 @@
|
|||||||
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() abort " {{{2
|
|
||||||
let newObj = copy(self)
|
|
||||||
return newObj
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticBalloonsNotifier.enabled() abort " {{{2
|
|
||||||
return has('balloon_eval') && syntastic#util#var('enable_balloons')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Update the error balloons
|
|
||||||
function! g:SyntasticBalloonsNotifier.refresh(loclist) abort " {{{2
|
|
||||||
unlet! b:syntastic_private_balloons
|
|
||||||
if self.enabled() && !a:loclist.isEmpty()
|
|
||||||
let b:syntastic_private_balloons = a:loclist.balloons()
|
|
||||||
if !empty(b:syntastic_private_balloons)
|
|
||||||
set ballooneval balloonexpr=SyntasticBalloonsExprNotifier()
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Reset the error balloons
|
|
||||||
" @vimlint(EVL103, 1, a:loclist)
|
|
||||||
function! g:SyntasticBalloonsNotifier.reset(loclist) abort " {{{2
|
|
||||||
let b:syntastic_private_balloons = {}
|
|
||||||
if has('balloon_eval')
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, 'balloons: reset')
|
|
||||||
unlet! b:syntastic_private_balloons
|
|
||||||
set noballooneval
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
" @vimlint(EVL103, 0, a:loclist)
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Private functions {{{1
|
|
||||||
|
|
||||||
function! SyntasticBalloonsExprNotifier() abort " {{{2
|
|
||||||
if !exists('b:syntastic_private_balloons')
|
|
||||||
return ''
|
|
||||||
endif
|
|
||||||
return get(b:syntastic_private_balloons, v:beval_lnum, '')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,282 +0,0 @@
|
|||||||
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, ...) abort " {{{2
|
|
||||||
let newObj = copy(self)
|
|
||||||
|
|
||||||
let newObj._filetype = a:args['filetype']
|
|
||||||
let newObj._name = a:args['name']
|
|
||||||
|
|
||||||
if a:0
|
|
||||||
" redirected checker
|
|
||||||
let newObj._exec_default = get(a:args, 'exec', a:1['_exec_default'])
|
|
||||||
|
|
||||||
let filetype = a:1['_filetype']
|
|
||||||
let name = a:1['_name']
|
|
||||||
let prefix = 'SyntaxCheckers_' . filetype . '_' . name . '_'
|
|
||||||
|
|
||||||
if exists('g:syntastic_' . filetype . '_' . name . '_sort') && !exists('g:syntastic_' . newObj._filetype . '_' . newObj._name . '_sort')
|
|
||||||
let g:syntastic_{newObj._filetype}_{newObj._name}_sort = g:syntastic_{filetype}_{name}_sort
|
|
||||||
endif
|
|
||||||
|
|
||||||
if has_key(a:args, 'enable')
|
|
||||||
let newObj._enable = a:args['enable']
|
|
||||||
elseif has_key(a:1, '_enable')
|
|
||||||
let newObj._enable = a:1['_enable']
|
|
||||||
endif
|
|
||||||
else
|
|
||||||
let newObj._exec_default = get(a:args, 'exec', newObj._name)
|
|
||||||
if newObj._exec_default ==# ''
|
|
||||||
let newObj._exec_default = '<dummy>'
|
|
||||||
endif
|
|
||||||
let prefix = 'SyntaxCheckers_' . newObj._filetype . '_' . newObj._name . '_'
|
|
||||||
|
|
||||||
if has_key(a:args, 'enable')
|
|
||||||
let newObj._enable = a:args['enable']
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
let newObj._locListFunc = function(prefix . 'GetLocList')
|
|
||||||
|
|
||||||
if exists('*' . prefix . 'IsAvailable')
|
|
||||||
let newObj._isAvailableFunc = function(prefix . 'IsAvailable')
|
|
||||||
else
|
|
||||||
let newObj._isAvailableFunc = function('s:_isAvailableDefault')
|
|
||||||
endif
|
|
||||||
|
|
||||||
if exists('*' . prefix . 'GetHighlightRegex')
|
|
||||||
let newObj._highlightRegexFunc = function(prefix . 'GetHighlightRegex')
|
|
||||||
endif
|
|
||||||
|
|
||||||
return newObj
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker.getFiletype() abort " {{{2
|
|
||||||
return self._filetype
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker.getName() abort " {{{2
|
|
||||||
return self._name
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker.getCName() abort " {{{2
|
|
||||||
return self._filetype . '/' . self._name
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Synchronise _exec with user's setting. Force re-validation if needed.
|
|
||||||
"
|
|
||||||
" XXX: This function must be called at least once before calling either
|
|
||||||
" getExec() or getExecEscaped(). Normally isAvailable() does that for you
|
|
||||||
" automatically, but you should keep still this in mind if you change the
|
|
||||||
" current checker workflow.
|
|
||||||
function! g:SyntasticChecker.syncExec(...) abort " {{{2
|
|
||||||
if a:0
|
|
||||||
let self._exec = a:1
|
|
||||||
else
|
|
||||||
let suffix = self._name . '_exec'
|
|
||||||
let self._exec = expand(
|
|
||||||
\ syntastic#util#var(self._filetype . '_' . suffix,
|
|
||||||
\ syntastic#util#var(suffix, self._exec_default)), 1 )
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker.getExec() abort " {{{2
|
|
||||||
return self._exec
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker.getExecEscaped() abort " {{{2
|
|
||||||
return syntastic#util#shescape(self._exec)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker.getLocListRaw() abort " {{{2
|
|
||||||
let checker_start = reltime()
|
|
||||||
let name = self.getCName()
|
|
||||||
|
|
||||||
if has_key(self, '_enable')
|
|
||||||
let status = syntastic#util#var(self._enable, -1)
|
|
||||||
if type(status) != type(0)
|
|
||||||
call syntastic#log#error('checker ' . name . ': invalid value ' . strtrans(string(status)) .
|
|
||||||
\ ' for g:syntastic_' . self._enable . '; try 0 or 1 instead')
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
if status < 0
|
|
||||||
call syntastic#log#error('checker ' . name . ': checks disabled for security reasons; ' .
|
|
||||||
\ 'set g:syntastic_' . self._enable . ' to 1 to override')
|
|
||||||
endif
|
|
||||||
if status <= 0
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, 'getLocList: checker ' . name . ' enabled but not forced')
|
|
||||||
return []
|
|
||||||
else
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, 'getLocList: checker ' . name . ' forced')
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
try
|
|
||||||
let list = self._locListFunc()
|
|
||||||
if self._exec !=# ''
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE, 'getLocList: checker ' . name . ' returned ' . v:shell_error)
|
|
||||||
endif
|
|
||||||
catch /\m\C^Syntastic: checker error$/
|
|
||||||
let list = []
|
|
||||||
if self._exec !=# ''
|
|
||||||
call syntastic#log#error('checker ' . name . ' returned abnormal status ' . v:shell_error)
|
|
||||||
else
|
|
||||||
call syntastic#log#error('checker ' . name . ' aborted')
|
|
||||||
endif
|
|
||||||
endtry
|
|
||||||
call self._populateHighlightRegexes(list)
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_LOCLIST, name . ' raw:', list)
|
|
||||||
call self._quietMessages(list)
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_TRACE,
|
|
||||||
\ 'getLocList: checker ' . name . ' run in ' . split(reltimestr(reltime(checker_start)))[0] . 's')
|
|
||||||
return list
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker.getLocList() abort " {{{2
|
|
||||||
return g:SyntasticLoclist.New(self.getLocListRaw())
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker.getVersion(...) abort " {{{2
|
|
||||||
if !exists('self._version')
|
|
||||||
let command = a:0 ? a:1 : self.getExecEscaped() . ' --version'
|
|
||||||
let version_output = syntastic#util#system(command)
|
|
||||||
call self.log('getVersion: ' . string(command) . ': ' .
|
|
||||||
\ string(split(version_output, "\n", 1)) .
|
|
||||||
\ (v:shell_error ? ' (exit code ' . v:shell_error . ')' : '') )
|
|
||||||
let parsed_ver = syntastic#util#parseVersion(version_output)
|
|
||||||
if len(parsed_ver)
|
|
||||||
call self.setVersion(parsed_ver)
|
|
||||||
else
|
|
||||||
call syntastic#log#ndebug(g:_SYNTASTIC_DEBUG_LOCLIST, 'checker output:', split(version_output, "\n", 1))
|
|
||||||
call syntastic#log#error("checker " . self.getCName() . ": can't parse version string (abnormal termination?)")
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
return get(self, '_version', [])
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker.setVersion(version) abort " {{{2
|
|
||||||
if len(a:version)
|
|
||||||
let self._version = copy(a:version)
|
|
||||||
call self.log(self.getExec() . ' version =', a:version)
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker.log(msg, ...) abort " {{{2
|
|
||||||
let leader = self.getCName() . ': '
|
|
||||||
if a:0
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, leader . a:msg, a:1)
|
|
||||||
else
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_CHECKERS, leader . a:msg)
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker.makeprgBuild(opts) abort " {{{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() abort " {{{2
|
|
||||||
call self.syncExec()
|
|
||||||
|
|
||||||
if !has_key(self, '_available')
|
|
||||||
let self._available = {}
|
|
||||||
endif
|
|
||||||
if !has_key(self._available, self._exec)
|
|
||||||
let self._available[self._exec] = self._isAvailableFunc()
|
|
||||||
endif
|
|
||||||
|
|
||||||
return self._available[self._exec]
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker.isDisabled() abort " {{{2
|
|
||||||
return has_key(self, '_enable') && syntastic#util#var(self._enable, -1) <= 0
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker.wantSort() abort " {{{2
|
|
||||||
return syntastic#util#var(self._filetype . '_' . self._name . '_sort', 0)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" This method is no longer used by syntastic. It's here only to maintain
|
|
||||||
" backwards compatibility with external checkers which might depend on it.
|
|
||||||
function! g:SyntasticChecker.setWantSort(val) abort " {{{2
|
|
||||||
if !exists('g:syntastic_' . self._filetype . '_' . self._name . '_sort')
|
|
||||||
let g:syntastic_{self._filetype}_{self._name}_sort = a:val
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Private methods {{{1
|
|
||||||
|
|
||||||
function! g:SyntasticChecker._quietMessages(errors) abort " {{{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:_SYNTASTIC_DEBUG_LOCLIST, 'quiet_messages filter:', quiet_filters)
|
|
||||||
|
|
||||||
if !empty(quiet_filters)
|
|
||||||
call syntastic#util#dictFilter(a:errors, quiet_filters)
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_LOCLIST, 'filtered by quiet_messages:', a:errors)
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticChecker._populateHighlightRegexes(errors) abort " {{{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) abort " {{{2
|
|
||||||
let ret = []
|
|
||||||
call extend( ret, syntastic#util#argsescape(get(a:opts, a:name . '_before', '')) )
|
|
||||||
call extend( ret, syntastic#util#argsescape(syntastic#util#var( a:basename . a:name, get(a:opts, a:name, a:default) )) )
|
|
||||||
call extend( ret, syntastic#util#argsescape(get(a:opts, a:name . '_after', '')) )
|
|
||||||
|
|
||||||
return ret
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Private functions {{{1
|
|
||||||
|
|
||||||
function! s:_isAvailableDefault() dict " {{{2
|
|
||||||
return executable(self.getExec())
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,138 +0,0 @@
|
|||||||
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() abort " {{{2
|
|
||||||
let newObj = copy(self)
|
|
||||||
return newObj
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticCursorNotifier.enabled() abort " {{{2
|
|
||||||
return syntastic#util#var('echo_current_error')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticCursorNotifier.refresh(loclist) abort " {{{2
|
|
||||||
if self.enabled() && !a:loclist.isEmpty()
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, 'cursor: refresh')
|
|
||||||
let b:syntastic_private_messages = copy(a:loclist.messages(bufnr('')))
|
|
||||||
let b:syntastic_private_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) abort " {{{2
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, 'cursor: reset')
|
|
||||||
autocmd! syntastic CursorMoved
|
|
||||||
unlet! b:syntastic_private_messages
|
|
||||||
let b:syntastic_private_line = -1
|
|
||||||
endfunction " }}}2
|
|
||||||
" @vimlint(EVL103, 0, a:loclist)
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Private functions {{{1
|
|
||||||
|
|
||||||
function! SyntasticRefreshCursor() abort " {{{2
|
|
||||||
if !exists('b:syntastic_private_messages') || empty(b:syntastic_private_messages)
|
|
||||||
" file not checked
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
if !exists('b:syntastic_private_line')
|
|
||||||
let b:syntastic_private_line = -1
|
|
||||||
endif
|
|
||||||
let l = line('.')
|
|
||||||
let current_messages = get(b:syntastic_private_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_private_idx')
|
|
||||||
let b:syntastic_private_idx = -1
|
|
||||||
endif
|
|
||||||
|
|
||||||
if s:_is_same_index(l, b:syntastic_private_line, c, b:syntastic_private_idx, current_messages)
|
|
||||||
return
|
|
||||||
else
|
|
||||||
let b:syntastic_private_line = l
|
|
||||||
endif
|
|
||||||
|
|
||||||
if !empty(current_messages)
|
|
||||||
let b:syntastic_private_idx = s:_find_index(c, current_messages)
|
|
||||||
call syntastic#util#wideMsg(current_messages[b:syntastic_private_idx].text)
|
|
||||||
else
|
|
||||||
let b:syntastic_private_idx = -1
|
|
||||||
echo
|
|
||||||
endif
|
|
||||||
else
|
|
||||||
if l == b:syntastic_private_line
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
let b:syntastic_private_line = l
|
|
||||||
|
|
||||||
if !empty(current_messages)
|
|
||||||
call syntastic#util#wideMsg(current_messages[0].text)
|
|
||||||
else
|
|
||||||
echo
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Utilities {{{1
|
|
||||||
|
|
||||||
function! s:_is_same_index(line, old_line, column, idx, messages) abort " {{{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 || a:idx == 0
|
|
||||||
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:_find_index(column, messages) abort " {{{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:
|
|
@ -1,104 +0,0 @@
|
|||||||
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() abort " {{{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() abort " {{{2
|
|
||||||
return s:has_highlighting && syntastic#util#var('enable_highlighting')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Sets error highlights in the current window
|
|
||||||
function! g:SyntasticHighlightingNotifier.refresh(loclist) abort " {{{2
|
|
||||||
if self.enabled()
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, '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) abort " {{{2
|
|
||||||
if s:has_highlighting
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, '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() abort " {{{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() abort " {{{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:
|
|
@ -1,445 +0,0 @@
|
|||||||
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) abort " {{{2
|
|
||||||
let newObj = copy(self)
|
|
||||||
|
|
||||||
let llist = filter(copy(a:rawLoclist), 'v:val["valid"]')
|
|
||||||
|
|
||||||
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(...) abort " {{{2
|
|
||||||
let buf = a:0 ? a:1 : bufnr('')
|
|
||||||
let loclist = syntastic#util#getbufvar(buf, 'syntastic_loclist', {})
|
|
||||||
if type(loclist) != type({}) || empty(loclist)
|
|
||||||
unlet! loclist
|
|
||||||
let loclist = g:SyntasticLoclist.New([])
|
|
||||||
endif
|
|
||||||
return loclist
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.extend(other) abort " {{{2
|
|
||||||
call extend(self._rawLoclist, a:other.copyRaw())
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.sort() abort " {{{2
|
|
||||||
if !self._sorted
|
|
||||||
for e in self._rawLoclist
|
|
||||||
call s:_set_screen_column(e)
|
|
||||||
endfor
|
|
||||||
|
|
||||||
call sort(self._rawLoclist, self._columns ? 's:_compare_error_items_by_columns' : 's:_compare_error_items_by_lines')
|
|
||||||
|
|
||||||
let self._sorted = 1
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.isEmpty() abort " {{{2
|
|
||||||
return empty(self._rawLoclist)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.isNewerThan(stamp) abort " {{{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() abort " {{{2
|
|
||||||
return copy(self._rawLoclist)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.getRaw() abort " {{{2
|
|
||||||
return self._rawLoclist
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.getBuffers() abort " {{{2
|
|
||||||
return syntastic#util#unique(map(copy(self._rawLoclist), 'str2nr(v:val["bufnr"])') + [self._owner])
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.getCursorColumns() abort " {{{2
|
|
||||||
return self._columns
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.getStatuslineFlag() abort " {{{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')
|
|
||||||
|
|
||||||
let flags = {
|
|
||||||
\ '%': '%',
|
|
||||||
\ 't': num_issues,
|
|
||||||
\ 'e': num_errors,
|
|
||||||
\ 'w': num_warnings,
|
|
||||||
\ 'N': (num_issues ? fnamemodify( bufname(self._rawLoclist[0]['bufnr']), ':t') : ''),
|
|
||||||
\ 'P': (num_issues ? fnamemodify( bufname(self._rawLoclist[0]['bufnr']), ':p:~:.') : ''),
|
|
||||||
\ 'F': (num_issues ? self._rawLoclist[0]['lnum'] : ''),
|
|
||||||
\ 'ne': (num_errors ? fnamemodify( bufname(errors[0]['bufnr']), ':t') : ''),
|
|
||||||
\ 'pe': (num_errors ? fnamemodify( bufname(errors[0]['bufnr']), ':p:~:.') : ''),
|
|
||||||
\ 'fe': (num_errors ? errors[0]['lnum'] : ''),
|
|
||||||
\ 'nw': (num_warnings ? fnamemodify( bufname(warnings[0]['bufnr']), ':t') : ''),
|
|
||||||
\ 'pw': (num_warnings ? fnamemodify( bufname(warnings[0]['bufnr']), ':p:~:.') : ''),
|
|
||||||
\ 'fw': (num_warnings ? warnings[0]['lnum'] : '') }
|
|
||||||
let output = substitute(output, '\v\C\%(-?\d*%(\.\d+)?)([npf][ew]|[NPFtew%])', '\=syntastic#util#wformat(submatch(1), flags[submatch(2)])', 'g')
|
|
||||||
|
|
||||||
let self._stl_flag = output
|
|
||||||
else
|
|
||||||
let self._stl_flag = ''
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
return self._stl_flag
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.getFirstError(...) abort " {{{2
|
|
||||||
let max_issues = len(self._rawLoclist)
|
|
||||||
if a:0 && a:1 < max_issues
|
|
||||||
let max_issues = a:1
|
|
||||||
endif
|
|
||||||
|
|
||||||
for idx in range(max_issues)
|
|
||||||
if get(self._rawLoclist[idx], 'type', '') ==? 'E'
|
|
||||||
return idx + 1
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
|
|
||||||
return 0
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.getName() abort " {{{2
|
|
||||||
return len(self._name)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.setName(name) abort " {{{2
|
|
||||||
let self._name = a:name
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.getOwner() abort " {{{2
|
|
||||||
return self._owner
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.setOwner(buffer) abort " {{{2
|
|
||||||
let self._owner = type(a:buffer) == type(0) ? a:buffer : str2nr(a:buffer)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.deploy() abort " {{{2
|
|
||||||
let self._stamp = syntastic#util#stamp()
|
|
||||||
for buf in self.getBuffers()
|
|
||||||
call setbufvar(buf, 'syntastic_loclist', self)
|
|
||||||
endfor
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.destroy() abort " {{{2
|
|
||||||
for buf in self.getBuffers()
|
|
||||||
call setbufvar(buf, 'syntastic_loclist', {})
|
|
||||||
endfor
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.decorate(tag) abort " {{{2
|
|
||||||
for e in self._rawLoclist
|
|
||||||
let e['text'] .= ' [' . a:tag . ']'
|
|
||||||
endfor
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.balloons() abort " {{{2
|
|
||||||
if !exists('self._cachedBalloons')
|
|
||||||
let sep = has('balloon_multiline') ? "\n" : ' | '
|
|
||||||
|
|
||||||
let self._cachedBalloons = {}
|
|
||||||
for e in self._rawLoclist
|
|
||||||
let buf = e['bufnr']
|
|
||||||
|
|
||||||
if !has_key(self._cachedBalloons, buf)
|
|
||||||
let self._cachedBalloons[buf] = {}
|
|
||||||
endif
|
|
||||||
|
|
||||||
if has_key(self._cachedBalloons[buf], e['lnum'])
|
|
||||||
let self._cachedBalloons[buf][e['lnum']] .= sep . e['text']
|
|
||||||
else
|
|
||||||
let self._cachedBalloons[buf][e['lnum']] = e['text']
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
endif
|
|
||||||
|
|
||||||
return get(self._cachedBalloons, bufnr(''), {})
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.errors() abort " {{{2
|
|
||||||
if !exists('self._cachedErrors')
|
|
||||||
let self._cachedErrors = self.filter({'type': 'E'})
|
|
||||||
endif
|
|
||||||
return self._cachedErrors
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticLoclist.warnings() abort " {{{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() abort " {{{2
|
|
||||||
return !self.isEmpty()
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" cache used by EchoCurrentError()
|
|
||||||
function! g:SyntasticLoclist.messages(buf) abort " {{{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:_set_screen_column(e)
|
|
||||||
endfor
|
|
||||||
call sort(self._cachedMessages[b][l], 's:_compare_error_items_by_columns')
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
endfor
|
|
||||||
endif
|
|
||||||
|
|
||||||
for b in keys(self._cachedMessages)
|
|
||||||
for l in keys(self._cachedMessages[b])
|
|
||||||
call s:_remove_shadowed_items(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 string comparisons are done with ==?
|
|
||||||
function! g:SyntasticLoclist.filter(filters) abort " {{{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(new) abort " {{{2
|
|
||||||
if !exists('w:syntastic_loclist_set')
|
|
||||||
let w:syntastic_loclist_set = []
|
|
||||||
endif
|
|
||||||
if a:new || empty(w:syntastic_loclist_set) || w:syntastic_loclist_set != [self._owner, getbufvar(self._owner, 'changedtick')]
|
|
||||||
let replace = !a:new && g:syntastic_reuse_loc_lists && !empty(w:syntastic_loclist_set)
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, 'loclist: setloclist ' . (replace ? '(replace)' : '(new)'))
|
|
||||||
call setloclist(0, self.getRaw(), replace ? 'r' : ' ')
|
|
||||||
try
|
|
||||||
" Vim 7.4.2200 or later
|
|
||||||
call setloclist(0, [], 'r', { 'title': ':SyntasticCheck ' . self._name })
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E\%(118\|731\)/
|
|
||||||
" do nothing
|
|
||||||
endtry
|
|
||||||
call syntastic#util#setLastTick(self._owner)
|
|
||||||
let w:syntastic_loclist_set = [self._owner, getbufvar(self._owner, 'syntastic_lasttick')]
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
"display the cached errors for this buf in the location list
|
|
||||||
function! g:SyntasticLoclist.show() abort " {{{2
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, 'loclist: show')
|
|
||||||
call self.setloclist(0)
|
|
||||||
|
|
||||||
if !self.isEmpty()
|
|
||||||
let num = winnr()
|
|
||||||
execute 'lopen ' . syntastic#util#var('loc_list_height')
|
|
||||||
if num != winnr()
|
|
||||||
execute num . 'wincmd w'
|
|
||||||
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
|
|
||||||
|
|
||||||
" Public functions {{{1
|
|
||||||
|
|
||||||
function! SyntasticLoclistHide() abort " {{{2
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, 'loclist: hide')
|
|
||||||
silent! lclose
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Utilities {{{1
|
|
||||||
|
|
||||||
function! s:_translate(key, val) abort " {{{2
|
|
||||||
return 'get(v:val, ' . string(a:key) . ', "") ==? ' . string(a:val)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! s:_set_screen_column(item) abort " {{{2
|
|
||||||
if !has_key(a:item, 'scol')
|
|
||||||
let col = get(a:item, 'col', 0)
|
|
||||||
if col != 0 && get(a:item, 'vcol', 0) == 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:_remove_shadowed_items(errors) abort " {{{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:_compare_error_items_by_columns(a, b) abort " {{{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:_compare_error_items_by_lines(a, b) abort " {{{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:
|
|
@ -1,118 +0,0 @@
|
|||||||
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() abort " {{{2
|
|
||||||
if !exists('s:SyntasticModeMapInstance')
|
|
||||||
let s:SyntasticModeMapInstance = copy(self)
|
|
||||||
call s:SyntasticModeMapInstance.synch()
|
|
||||||
endif
|
|
||||||
|
|
||||||
return s:SyntasticModeMapInstance
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticModeMap.synch() abort " {{{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) abort " {{{2
|
|
||||||
let registry = g:SyntasticRegistry.Instance()
|
|
||||||
let fts = registry.resolveFiletypes(a:filetype)
|
|
||||||
|
|
||||||
if self.isPassive()
|
|
||||||
return self._isOneFiletypeActive(fts)
|
|
||||||
else
|
|
||||||
return self._noFiletypesArePassive(fts)
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticModeMap.doAutoChecking(buf) abort " {{{2
|
|
||||||
let local_mode = getbufvar(a:buf, 'syntastic_mode')
|
|
||||||
if local_mode ==# 'active' || local_mode ==# 'passive'
|
|
||||||
return local_mode ==# 'active'
|
|
||||||
endif
|
|
||||||
|
|
||||||
return self.allowsAutoChecking(getbufvar(a:buf, '&filetype'))
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticModeMap.isPassive() abort " {{{2
|
|
||||||
return self._mode ==# 'passive'
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticModeMap.toggleMode() abort " {{{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() abort " {{{2
|
|
||||||
echo 'Syntastic: ' . self._mode . ' mode enabled'
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticModeMap.modeInfo(filetypes) abort " {{{2
|
|
||||||
echomsg 'Syntastic version: ' . g:syntastic_version
|
|
||||||
let type = len(a:filetypes) ? a:filetypes[0] : &filetype
|
|
||||||
echomsg 'Info for filetype: ' . type
|
|
||||||
|
|
||||||
call self.synch()
|
|
||||||
echomsg 'Global 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')
|
|
||||||
|
|
||||||
if !len(a:filetypes)
|
|
||||||
if exists('b:syntastic_mode') && (b:syntastic_mode ==# 'active' || b:syntastic_mode ==# 'passive')
|
|
||||||
echomsg 'Local mode: ' . b:syntastic_mode
|
|
||||||
endif
|
|
||||||
|
|
||||||
echomsg 'The current file will ' . (self.doAutoChecking(bufnr('')) ? '' : 'not ') . 'be checked automatically'
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Private methods {{{1
|
|
||||||
|
|
||||||
function! g:SyntasticModeMap._isOneFiletypeActive(filetypes) abort " {{{2
|
|
||||||
return !empty(filter(copy(a:filetypes), 'index(self._activeFiletypes, v:val) != -1'))
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticModeMap._noFiletypesArePassive(filetypes) abort " {{{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:
|
|
@ -1,86 +0,0 @@
|
|||||||
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() abort " {{{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) abort " {{{2
|
|
||||||
if !syntastic#util#bufIsActive(bufnr('')) || (!a:loclist.isEmpty() && !a:loclist.isNewerThan([]))
|
|
||||||
" loclist not fully constructed yet
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, '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_private_' . type . '_stamp')
|
|
||||||
let b:syntastic_private_{type}_stamp = []
|
|
||||||
endif
|
|
||||||
if a:loclist.isNewerThan(b:syntastic_private_{type}_stamp) || a:loclist.isEmpty()
|
|
||||||
call self._notifier[type].refresh(a:loclist)
|
|
||||||
let b:syntastic_private_{type}_stamp = syntastic#util#stamp()
|
|
||||||
endif
|
|
||||||
else
|
|
||||||
call self._notifier[type].refresh(a:loclist)
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticNotifiers.reset(loclist) abort " {{{2
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, '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_private_{type}_stamp = []
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" Private methods {{{1
|
|
||||||
|
|
||||||
function! g:SyntasticNotifiers._initNotifiers() abort " {{{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:
|
|
@ -1,441 +0,0 @@
|
|||||||
if exists('g:loaded_syntastic_registry') || !exists('g:loaded_syntastic_plugin')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_registry = 1
|
|
||||||
|
|
||||||
" Initialisation {{{1
|
|
||||||
|
|
||||||
let s:_DEFAULT_CHECKERS = {
|
|
||||||
\ 'actionscript': ['mxmlc'],
|
|
||||||
\ 'ada': ['gcc'],
|
|
||||||
\ 'ansible': ['ansible_lint'],
|
|
||||||
\ 'apiblueprint': ['drafter'],
|
|
||||||
\ 'applescript': ['osacompile'],
|
|
||||||
\ 'asciidoc': ['asciidoc'],
|
|
||||||
\ 'asl': ['iasl'],
|
|
||||||
\ 'asm': ['gcc'],
|
|
||||||
\ 'bro': ['bro'],
|
|
||||||
\ 'bemhtml': ['bemhtmllint'],
|
|
||||||
\ 'c': ['gcc'],
|
|
||||||
\ 'cabal': ['cabal'],
|
|
||||||
\ 'chef': ['foodcritic'],
|
|
||||||
\ 'cmake': ['cmakelint'],
|
|
||||||
\ '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'],
|
|
||||||
\ 'dockerfile': ['dockerfile_lint'],
|
|
||||||
\ 'dustjs': ['swiffer'],
|
|
||||||
\ 'elixir': [],
|
|
||||||
\ 'erlang': ['escript'],
|
|
||||||
\ 'eruby': ['ruby'],
|
|
||||||
\ 'fortran': ['gfortran'],
|
|
||||||
\ 'glsl': ['cgc'],
|
|
||||||
\ 'go': [],
|
|
||||||
\ 'haml': ['haml'],
|
|
||||||
\ 'handlebars': ['handlebars'],
|
|
||||||
\ 'haskell': ['hdevtools', 'hlint'],
|
|
||||||
\ 'haxe': ['haxe'],
|
|
||||||
\ 'help': [],
|
|
||||||
\ 'hss': ['hss'],
|
|
||||||
\ 'html': ['tidy'],
|
|
||||||
\ 'jade': ['jade_lint'],
|
|
||||||
\ 'java': ['javac'],
|
|
||||||
\ 'javascript': ['jshint', 'jslint'],
|
|
||||||
\ 'json': ['jsonlint', 'jsonval'],
|
|
||||||
\ 'julia': [],
|
|
||||||
\ 'less': ['lessc'],
|
|
||||||
\ 'lex': ['flex'],
|
|
||||||
\ 'limbo': ['limbo'],
|
|
||||||
\ 'lisp': ['clisp'],
|
|
||||||
\ 'llvm': ['llvm'],
|
|
||||||
\ 'lua': ['luac'],
|
|
||||||
\ 'markdown': ['mdl'],
|
|
||||||
\ 'matlab': ['mlint'],
|
|
||||||
\ 'mercury': ['mmc'],
|
|
||||||
\ 'nasm': ['nasm'],
|
|
||||||
\ 'nix': ['nix'],
|
|
||||||
\ 'nroff': ['mandoc'],
|
|
||||||
\ 'objc': ['gcc'],
|
|
||||||
\ 'objcpp': ['gcc'],
|
|
||||||
\ 'ocaml': ['camlp4o'],
|
|
||||||
\ 'perl': ['perlcritic'],
|
|
||||||
\ 'php': ['php', 'phpcs', 'phpmd'],
|
|
||||||
\ 'po': ['msgfmt'],
|
|
||||||
\ 'pod': ['podchecker'],
|
|
||||||
\ 'puppet': ['puppet', 'puppetlint'],
|
|
||||||
\ 'pug': ['pug_lint'],
|
|
||||||
\ 'python': ['python', 'flake8', 'pylint'],
|
|
||||||
\ 'qml': ['qmllint'],
|
|
||||||
\ 'r': [],
|
|
||||||
\ 'rmd': [],
|
|
||||||
\ 'racket': ['racket'],
|
|
||||||
\ 'rnc': ['rnv'],
|
|
||||||
\ 'rst': ['rst2pseudoxml'],
|
|
||||||
\ 'ruby': ['mri'],
|
|
||||||
\ 'sass': ['sass'],
|
|
||||||
\ 'scala': ['fsc', 'scalac'],
|
|
||||||
\ 'scss': ['sass', 'scss_lint'],
|
|
||||||
\ 'sh': ['sh', 'shellcheck'],
|
|
||||||
\ 'slim': ['slimrb'],
|
|
||||||
\ 'sml': ['smlnj'],
|
|
||||||
\ 'spec': ['rpmlint'],
|
|
||||||
\ 'solidity': ['solc'],
|
|
||||||
\ 'sql': ['sqlint'],
|
|
||||||
\ 'stylus': ['stylint'],
|
|
||||||
\ 'tcl': ['nagelfar'],
|
|
||||||
\ 'tex': ['lacheck', 'chktex'],
|
|
||||||
\ 'texinfo': ['makeinfo'],
|
|
||||||
\ 'text': [],
|
|
||||||
\ 'trig': ['rapper'],
|
|
||||||
\ 'turtle': ['rapper'],
|
|
||||||
\ 'twig': ['twiglint'],
|
|
||||||
\ 'typescript': [],
|
|
||||||
\ 'vala': ['valac'],
|
|
||||||
\ 'verilog': ['verilator'],
|
|
||||||
\ 'vhdl': ['ghdl'],
|
|
||||||
\ 'vim': ['vimlint'],
|
|
||||||
\ 'xhtml': ['tidy'],
|
|
||||||
\ 'xml': ['xmllint'],
|
|
||||||
\ 'xslt': ['xmllint'],
|
|
||||||
\ 'xquery': ['basex'],
|
|
||||||
\ 'yacc': ['bison'],
|
|
||||||
\ 'yaml': ['jsyaml'],
|
|
||||||
\ 'yang': ['pyang'],
|
|
||||||
\ 'z80': ['z80syntaxchecker'],
|
|
||||||
\ 'zpt': ['zptlint'],
|
|
||||||
\ 'zsh': ['zsh'],
|
|
||||||
\ }
|
|
||||||
lockvar! s:_DEFAULT_CHECKERS
|
|
||||||
|
|
||||||
let s:_DEFAULT_FILETYPE_MAP = {
|
|
||||||
\ 'gentoo-metadata': 'xml',
|
|
||||||
\ 'groff': 'nroff',
|
|
||||||
\ 'lhaskell': 'haskell',
|
|
||||||
\ 'litcoffee': 'coffee',
|
|
||||||
\ 'mail': 'text',
|
|
||||||
\ 'mkd': 'markdown',
|
|
||||||
\ 'pe-puppet': 'puppet',
|
|
||||||
\ 'sgml': 'docbk',
|
|
||||||
\ 'sgmllnx': 'docbk',
|
|
||||||
\ }
|
|
||||||
lockvar! s:_DEFAULT_FILETYPE_MAP
|
|
||||||
|
|
||||||
let s:_ECLIM_TYPES = [
|
|
||||||
\ 'c',
|
|
||||||
\ 'cpp',
|
|
||||||
\ 'html',
|
|
||||||
\ 'java',
|
|
||||||
\ 'php',
|
|
||||||
\ 'python',
|
|
||||||
\ 'ruby',
|
|
||||||
\ ]
|
|
||||||
lockvar! s:_ECLIM_TYPES
|
|
||||||
|
|
||||||
let s:_YCM_TYPES = [
|
|
||||||
\ 'c',
|
|
||||||
\ 'cpp',
|
|
||||||
\ 'objc',
|
|
||||||
\ 'objcpp',
|
|
||||||
\ ]
|
|
||||||
lockvar! s:_YCM_TYPES
|
|
||||||
|
|
||||||
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() abort " {{{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) abort " {{{2
|
|
||||||
let registry = g:SyntasticRegistry.Instance()
|
|
||||||
|
|
||||||
if has_key(a:args, 'redirect')
|
|
||||||
let [ft, name] = split(a:args['redirect'], '/')
|
|
||||||
call registry._loadCheckersFor(ft, 1)
|
|
||||||
|
|
||||||
let clone = get(registry._checkerMap[ft], name, {})
|
|
||||||
if empty(clone)
|
|
||||||
throw 'Syntastic: Checker ' . a:args['redirect'] . ' redirects to unregistered checker ' . ft . '/' . name
|
|
||||||
endif
|
|
||||||
|
|
||||||
let checker = g:SyntasticChecker.New(a:args, clone)
|
|
||||||
else
|
|
||||||
let checker = g:SyntasticChecker.New(a:args)
|
|
||||||
endif
|
|
||||||
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) abort " {{{2
|
|
||||||
let ftlist = self.resolveFiletypes(a:ftalias)
|
|
||||||
|
|
||||||
let names =
|
|
||||||
\ !empty(a:hints_list) ? a:hints_list :
|
|
||||||
\ exists('b:syntastic_checkers') ? b:syntastic_checkers : []
|
|
||||||
|
|
||||||
let cnames = []
|
|
||||||
if !empty(names)
|
|
||||||
for name in names
|
|
||||||
if name !~# '/'
|
|
||||||
for ft in ftlist
|
|
||||||
call add(cnames, ft . '/' . name)
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
call add(cnames, name)
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
for ft in ftlist
|
|
||||||
call self._sanityCheck(ft)
|
|
||||||
let defs =
|
|
||||||
\ exists('g:syntastic_' . ft . '_checkers') ? g:syntastic_{ft}_checkers :
|
|
||||||
\ get(s:_DEFAULT_CHECKERS, ft, [])
|
|
||||||
call extend(cnames, map(copy(defs), 'stridx(v:val, "/") < 0 ? ft . "/" . v:val : v:val' ))
|
|
||||||
endfor
|
|
||||||
endif
|
|
||||||
let cnames = syntastic#util#unique(cnames)
|
|
||||||
|
|
||||||
for ft in syntastic#util#unique(map( copy(cnames), 'v:val[: stridx(v:val, "/")-1]' ))
|
|
||||||
call self._loadCheckersFor(ft, 0)
|
|
||||||
endfor
|
|
||||||
|
|
||||||
return self._filterCheckersByName(cnames)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Same as getCheckers(), but keep only the available checkers. This runs the
|
|
||||||
" corresponding IsAvailable() functions for all checkers.
|
|
||||||
function! g:SyntasticRegistry.getCheckersAvailable(ftalias, hints_list) abort " {{{2
|
|
||||||
return filter(self.getCheckers(a:ftalias, a:hints_list), 'v:val.isAvailable()')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" Same as getCheckers(), but keep only the checkers that are available and
|
|
||||||
" disabled. This runs the corresponding IsAvailable() functions for all checkers.
|
|
||||||
function! g:SyntasticRegistry.getCheckersDisabled(ftalias, hints_list) abort " {{{2
|
|
||||||
return filter(self.getCheckers(a:ftalias, a:hints_list), 'v:val.isDisabled() && v:val.isAvailable()')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticRegistry.getKnownFiletypes() abort " {{{2
|
|
||||||
let types = keys(s:_DEFAULT_CHECKERS)
|
|
||||||
|
|
||||||
call extend(types, keys(s:_DEFAULT_FILETYPE_MAP))
|
|
||||||
|
|
||||||
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) abort " {{{2
|
|
||||||
let ft = s:_normalise_filetype(a:ftalias)
|
|
||||||
call self._loadCheckersFor(ft, 0)
|
|
||||||
return keys(filter( copy(self._checkerMap[ft]), 'v:val.isAvailable()' ))
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticRegistry.resolveFiletypes(ftalias) abort " {{{2
|
|
||||||
return map(split( get(g:syntastic_filetype_map, a:ftalias, a:ftalias), '\m\.' ), 's:_normalise_filetype(v:val)')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticRegistry.echoInfoFor(ftalias_list) abort " {{{2
|
|
||||||
let ft_list = syntastic#util#unique(self.resolveFiletypes(empty(a:ftalias_list) ? &filetype : a:ftalias_list[0]))
|
|
||||||
if len(ft_list) != 1
|
|
||||||
let available = []
|
|
||||||
let active = []
|
|
||||||
let disabled = []
|
|
||||||
|
|
||||||
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()' ))
|
|
||||||
call extend(disabled, map( self.getCheckersDisabled(ft, []), 'ft . "/" . v:val.getName()' ))
|
|
||||||
endfor
|
|
||||||
else
|
|
||||||
let ft = ft_list[0]
|
|
||||||
let available = self.getNamesOfAvailableCheckers(ft)
|
|
||||||
let active = map(self.getCheckersAvailable(ft, []), 'ft ==# v:val.getFiletype() ? v:val.getName() : v:val.getCName()')
|
|
||||||
let disabled = map(self.getCheckersDisabled(ft, []), 'ft ==# v:val.getFiletype() ? v:val.getName() : v:val.getCName()')
|
|
||||||
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
|
|
||||||
|
|
||||||
let cnt = len(disabled)
|
|
||||||
let plural = cnt != 1 ? 's' : ''
|
|
||||||
if len(disabled)
|
|
||||||
let cklist = join(sort(disabled, 's:_compare_checker_names'))
|
|
||||||
echomsg 'Checker' . plural . ' disabled for security reasons: ' . cklist
|
|
||||||
endif
|
|
||||||
|
|
||||||
" Eclim feels entitled to mess with syntastic's variables {{{3
|
|
||||||
if exists(':EclimValidate') && get(g:, 'EclimFileTypeValidate', 1)
|
|
||||||
let disabled = filter(copy(ft_list), 's:_disabled_by_eclim(v:val)')
|
|
||||||
let cnt = len(disabled)
|
|
||||||
if cnt
|
|
||||||
let plural = cnt != 1 ? 's' : ''
|
|
||||||
let cklist = join(disabled, ', ')
|
|
||||||
echomsg 'Checkers for filetype' . plural . ' ' . cklist . ' possibly disabled by Eclim'
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
" }}}3
|
|
||||||
|
|
||||||
" So does YouCompleteMe {{{3
|
|
||||||
if exists('g:loaded_youcompleteme') && get(g:, 'ycm_show_diagnostics_ui', get(g:, 'ycm_register_as_syntastic_checker', 1))
|
|
||||||
let disabled = filter(copy(ft_list), 's:_disabled_by_ycm(v:val)')
|
|
||||||
let cnt = len(disabled)
|
|
||||||
if cnt
|
|
||||||
let plural = cnt != 1 ? 's' : ''
|
|
||||||
let cklist = join(disabled, ', ')
|
|
||||||
echomsg 'Checkers for filetype' . plural . ' ' . cklist . ' possibly disabled by YouCompleteMe'
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
" }}}3
|
|
||||||
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._findChecker(cname) abort " {{{2
|
|
||||||
let sep_idx = stridx(a:cname, '/')
|
|
||||||
if sep_idx > 0
|
|
||||||
let ft = a:cname[: sep_idx-1]
|
|
||||||
let name = a:cname[sep_idx+1 :]
|
|
||||||
else
|
|
||||||
let ft = &filetype
|
|
||||||
let name = a:cname
|
|
||||||
endif
|
|
||||||
return get(self._checkerMap[ft], name, {})
|
|
||||||
endfunction "}}}2
|
|
||||||
|
|
||||||
function! g:SyntasticRegistry._filterCheckersByName(cnames) abort " {{{2
|
|
||||||
return filter( map(copy(a:cnames), 'self._findChecker(v:val)'), '!empty(v:val)' )
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticRegistry._loadCheckersFor(filetype, force) abort " {{{2
|
|
||||||
if !a:force && 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._sanityCheck(filetype) abort " {{{2
|
|
||||||
if exists('g:syntastic_' . a:filetype . '_checkers') &&
|
|
||||||
\ type(g:syntastic_{a:filetype}_checkers) != type([])
|
|
||||||
|
|
||||||
unlet! g:syntastic_{a:filetype}_checkers
|
|
||||||
call syntastic#log#error('variable g:syntastic_' . a:filetype . '_checkers has to be a list of strings')
|
|
||||||
endif
|
|
||||||
|
|
||||||
if exists('g:syntastic_' . a:filetype . '_checker') &&
|
|
||||||
\ !exists('g:syntastic_' . a:filetype . '_checkers') &&
|
|
||||||
\ type(g:syntastic_{a:filetype}_checker) == type('')
|
|
||||||
|
|
||||||
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
|
|
||||||
|
|
||||||
" Utilities {{{1
|
|
||||||
|
|
||||||
"resolve filetype aliases, and replace - with _ otherwise we cant name
|
|
||||||
"syntax checker functions legally for filetypes like "gentoo-metadata"
|
|
||||||
function! s:_normalise_filetype(ftalias) abort " {{{2
|
|
||||||
let ft = get(s:_DEFAULT_FILETYPE_MAP, a:ftalias, a:ftalias)
|
|
||||||
let ft = get(g:syntastic_filetype_map, ft, ft)
|
|
||||||
let ft = substitute(ft, '\m-', '_', 'g')
|
|
||||||
return ft
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! s:_disabled_by_eclim(filetype) abort " {{{2
|
|
||||||
if index(s:_ECLIM_TYPES, a:filetype) >= 0
|
|
||||||
let lang = toupper(a:filetype[0]) . a:filetype[1:]
|
|
||||||
let ft = a:filetype !=# 'cpp' ? lang : 'C'
|
|
||||||
return get(g:, 'Eclim' . lang . 'Validate', 1) && !get(g:, 'Eclim' . ft . 'SyntasticEnabled', 0)
|
|
||||||
endif
|
|
||||||
|
|
||||||
return 0
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! s:_disabled_by_ycm(filetype) abort " {{{2
|
|
||||||
return index(s:_YCM_TYPES, a:filetype) >= 0
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! s:_compare_checker_names(a, b) abort " {{{2
|
|
||||||
if a:a ==# a:b
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
|
|
||||||
if stridx(a:a, '/') < 0
|
|
||||||
if stridx(a:b, '/') < 0
|
|
||||||
return a:a < a:b ? -1 : 1
|
|
||||||
else
|
|
||||||
return -1
|
|
||||||
endif
|
|
||||||
else
|
|
||||||
if stridx(a:b, '/') < 0
|
|
||||||
return 1
|
|
||||||
else
|
|
||||||
return a:a < a:b ? -1 : 1
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,138 +0,0 @@
|
|||||||
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() abort " {{{2
|
|
||||||
let newObj = copy(self)
|
|
||||||
return newObj
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticSignsNotifier.enabled() abort " {{{2
|
|
||||||
return has('signs') && syntastic#util#var('enable_signs')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! g:SyntasticSignsNotifier.refresh(loclist) abort " {{{2
|
|
||||||
call syntastic#log#debug(g:_SYNTASTIC_DEBUG_NOTIFICATIONS, 'signs: refresh')
|
|
||||||
|
|
||||||
let old_signs = copy(self._bufSignIds())
|
|
||||||
if self.enabled()
|
|
||||||
if !s:setup_done
|
|
||||||
call self._setup()
|
|
||||||
let s:setup_done = 1
|
|
||||||
lockvar s:setup_done
|
|
||||||
endif
|
|
||||||
|
|
||||||
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() abort " {{{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
|
|
||||||
execute 'sign define SyntasticError text=' . g:syntastic_error_symbol .
|
|
||||||
\ ' texthl=SyntasticErrorSign linehl=SyntasticErrorLine'
|
|
||||||
execute 'sign define SyntasticWarning text=' . g:syntastic_warning_symbol .
|
|
||||||
\ ' texthl=SyntasticWarningSign linehl=SyntasticWarningLine'
|
|
||||||
execute 'sign define SyntasticStyleError text=' . g:syntastic_style_error_symbol .
|
|
||||||
\ ' texthl=SyntasticStyleErrorSign linehl=SyntasticStyleErrorLine'
|
|
||||||
execute '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) abort " {{{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) abort " {{{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() abort " {{{2
|
|
||||||
if !exists('b:syntastic_private_sign_ids')
|
|
||||||
let b:syntastic_private_sign_ids = []
|
|
||||||
endif
|
|
||||||
return b:syntastic_private_sign_ids
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,67 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,47 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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, 1))
|
|
||||||
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 -gnats -gnatef',
|
|
||||||
\ 'header_flags': '-x ada -gnats -gnatef',
|
|
||||||
\ 'header_names': '\.ads$' })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'ada',
|
|
||||||
\ 'name': 'gcc' })
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,54 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: ansible_lint.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic.vim
|
|
||||||
"Maintainer: Erik Zaadi <erik.zaadi 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_ansible_ansible_lint_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_ansible_ansible_lint_checker = 1
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_ansible_ansible_lint_IsAvailable() dict
|
|
||||||
if !executable(self.getExec())
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
return syntastic#util#versionIsAtLeast(self.getVersion(), [2, 0, 4])
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function! SyntaxCheckers_ansible_ansible_lint_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({ 'args_after': '-p' })
|
|
||||||
|
|
||||||
let errorformat =
|
|
||||||
\ '%f:%l: [EANSIBLE%n] %m,' .
|
|
||||||
\ '%f:%l: [ANSIBLE%n] %m'
|
|
||||||
|
|
||||||
let env = syntastic#util#isRunningWindows() ? {} : { 'TERM': 'dumb' }
|
|
||||||
|
|
||||||
return SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'env': env,
|
|
||||||
\ 'defaults': {'type': 'E'},
|
|
||||||
\ 'subtype': 'Style',
|
|
||||||
\ 'returns': [0, 2] })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'ansible',
|
|
||||||
\ 'name': 'ansible_lint',
|
|
||||||
\ 'exec': 'ansible-lint'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,66 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: drafter.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_apiblueprint_drafter_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_apiblueprint_drafter_checker = 1
|
|
||||||
|
|
||||||
if !exists('g:syntastic_apiblueprint_drafter_sort')
|
|
||||||
let g:syntastic_apiblueprint_drafter_sort = 1
|
|
||||||
endif
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_apiblueprint_drafter_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({ 'post_args': '-u -l' })
|
|
||||||
|
|
||||||
let errorformat =
|
|
||||||
\ '%trror: (%n) %m,' .
|
|
||||||
\ '%tarning: (%n) %m,' .
|
|
||||||
\ '%-G%.%#'
|
|
||||||
|
|
||||||
let loclist = SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'defaults': {'bufnr': bufnr('')},
|
|
||||||
\ 'returns': [0, 2, 3, 4] })
|
|
||||||
|
|
||||||
for e in loclist
|
|
||||||
let matches = matchlist(e['text'], '\v^(.+); line (\d+), column (\d+) - line (\d+), column (\d+)$')
|
|
||||||
if len(matches) > 5
|
|
||||||
let e['lnum'] = str2nr(matches[2])
|
|
||||||
let e['col'] = str2nr(matches[3])
|
|
||||||
let e['vcol'] = 0
|
|
||||||
|
|
||||||
if matches[2] == matches[4]
|
|
||||||
let e['hl'] = '\%>' . (e['col'] - 1) . 'c\%<' . matches[5] . 'c'
|
|
||||||
endif
|
|
||||||
|
|
||||||
let e['text'] = matches[1]
|
|
||||||
else
|
|
||||||
let e['valid'] = 0
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
|
|
||||||
return loclist
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'apiblueprint',
|
|
||||||
\ 'name': 'drafter'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,49 +0,0 @@
|
|||||||
"==============================================================================
|
|
||||||
" 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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,47 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 =
|
|
||||||
\ '%E%\w%\+: %tRROR: %f: line %l: %m,' .
|
|
||||||
\ '%E%\w%\+: %tRROR: %f: %m,' .
|
|
||||||
\ '%E%\w%\+: FAILED: %f: line %l: %m,' .
|
|
||||||
\ '%E%\w%\+: FAILED: %f: %m,' .
|
|
||||||
\ '%W%\w%\+: %tARNING: %f: line %l: %m,' .
|
|
||||||
\ '%W%\w%\+: %tARNING: %f: %m,' .
|
|
||||||
\ '%W%\w%\+: DEPRECATED: %f: line %l: %m,' .
|
|
||||||
\ '%W%\w%\+: 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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,23 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: proselint.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic
|
|
||||||
"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_proselint_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_asciidoc_proselint_checker = 1
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'asciidoc',
|
|
||||||
\ 'name': 'proselint',
|
|
||||||
\ 'redirect': 'text/proselint'})
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,59 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: iasl.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic using iasl
|
|
||||||
"Maintainer: Peter Wu <peter@lekensteyn.nl>
|
|
||||||
"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_asl_iasl_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_asl_iasl_checker = 1
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_asl_iasl_GetLocList() dict
|
|
||||||
let tmpdir = syntastic#util#tmpdir() . syntastic#util#Slash()
|
|
||||||
let makeprg = self.makeprgBuild({
|
|
||||||
\ 'args': '-vi',
|
|
||||||
\ 'args_after': ['-p', tmpdir] })
|
|
||||||
|
|
||||||
let errorformat =
|
|
||||||
\ '%f(%l) : %trror %n - %m,' .
|
|
||||||
\ '%f(%l) : %tarning %n - %m,' .
|
|
||||||
\ '%f(%l) : %temark %n - %m,' .
|
|
||||||
\ '%f(%l) : %tptimize %n - %m,' .
|
|
||||||
\ '%f(%l) : %m'
|
|
||||||
|
|
||||||
let loclist = SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'returns': [0, 255] })
|
|
||||||
|
|
||||||
for e in loclist
|
|
||||||
if e['type'] =~? 'r'
|
|
||||||
let e['type'] = 'W'
|
|
||||||
elseif e['type'] =~? 'o'
|
|
||||||
let e['type'] = 'W'
|
|
||||||
let e['subtype'] = 'Style'
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
|
|
||||||
call syntastic#util#rmrf(tmpdir)
|
|
||||||
|
|
||||||
return loclist
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'asl',
|
|
||||||
\ 'name': 'iasl'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,62 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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
|
|
||||||
|
|
||||||
if !exists('g:syntastic_asm_generic')
|
|
||||||
let g:syntastic_asm_generic = 0
|
|
||||||
endif
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_asm_gcc_IsAvailable() dict " {{{1
|
|
||||||
if !exists('g:syntastic_asm_compiler')
|
|
||||||
let g:syntastic_asm_compiler = self.getExec()
|
|
||||||
endif
|
|
||||||
return executable(expand(g:syntastic_asm_compiler, 1))
|
|
||||||
endfunction " }}}1
|
|
||||||
|
|
||||||
function! SyntaxCheckers_asm_gcc_GetLocList() dict " {{{1
|
|
||||||
let buf = bufnr('')
|
|
||||||
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' . (g:syntastic_asm_generic ? '' : ' -masm=' . s:GetDialect(buf)) })
|
|
||||||
endfunction " }}}1
|
|
||||||
|
|
||||||
" Utilities {{{1
|
|
||||||
|
|
||||||
function! s:GetDialect(buf) " {{{2
|
|
||||||
return syntastic#util#bufVar(a:buf, 'asm_dialect', fnamemodify(bufname(a:buf), ':e') ==? 'asm' ? 'intel' : 'att')
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'asm',
|
|
||||||
\ 'name': 'gcc' })
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,35 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,58 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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_GetHighlightRegex(item)
|
|
||||||
let term = matchstr(a:item['text'], '\m at or near "\zs[^"]\+\ze"')
|
|
||||||
return term !=# '' ? '\V\<' . escape(term, '\') . '\>' : ''
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function! SyntaxCheckers_bro_bro_IsAvailable() dict
|
|
||||||
if !executable(self.getExec())
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
|
|
||||||
if syntastic#util#system(self.getExecEscaped() . ' --help') !~# '--parse-only'
|
|
||||||
call self.log('unknown option "--parse-only"')
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
|
|
||||||
return 1
|
|
||||||
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 = '%t:%f:%l:%m'
|
|
||||||
|
|
||||||
return SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'preprocess': 'bro' })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'bro',
|
|
||||||
\ 'name': 'bro'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,59 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: avrgcc.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic
|
|
||||||
"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
|
|
||||||
|
|
||||||
let s:opt_x = { 'c': 'c', 'cpp': 'c++' }
|
|
||||||
|
|
||||||
function! SyntaxCheckers_c_avrgcc_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({
|
|
||||||
\ 'args_before': syntastic#c#ReadConfig(g:syntastic_avrgcc_config_file),
|
|
||||||
\ 'args_after': '-x ' . get(s:opt_x, self.getFiletype(), '') . ' -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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,60 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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_exec')
|
|
||||||
|
|
||||||
if !exists('g:syntastic_c_checkpatch_exec') && !executable(self.getExec())
|
|
||||||
if executable('checkpatch')
|
|
||||||
let g:syntastic_c_checkpatch_exec = 'checkpatch'
|
|
||||||
elseif executable('./scripts/checkpatch.pl')
|
|
||||||
let g:syntastic_c_checkpatch_exec = fnamemodify('./scripts/checkpatch.pl', ':p')
|
|
||||||
elseif executable('./scripts/checkpatch')
|
|
||||||
let g:syntastic_c_checkpatch_exec = fnamemodify('./scripts/checkpatch', ':p')
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
call self.log('exec =', self.getExec())
|
|
||||||
|
|
||||||
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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,64 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: clang_check.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic.vim
|
|
||||||
"Maintainer: Benjamin Bannier <bbannier 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_clang_check_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_c_clang_check_checker = 1
|
|
||||||
|
|
||||||
if !exists('g:syntastic_clang_check_config_file')
|
|
||||||
let g:syntastic_clang_check_config_file = '.syntastic_clang_check_config'
|
|
||||||
endif
|
|
||||||
|
|
||||||
if !exists('g:syntastic_c_clang_check_sort')
|
|
||||||
let g:syntastic_c_clang_check_sort = 1
|
|
||||||
endif
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_c_clang_check_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({
|
|
||||||
\ 'post_args':
|
|
||||||
\ '-- ' .
|
|
||||||
\ syntastic#c#ReadConfig(g:syntastic_clang_check_config_file) . ' ' .
|
|
||||||
\ '-fshow-column ' .
|
|
||||||
\ '-fshow-source-location ' .
|
|
||||||
\ '-fno-caret-diagnostics ' .
|
|
||||||
\ '-fno-color-diagnostics ' .
|
|
||||||
\ '-fdiagnostics-format=clang' })
|
|
||||||
|
|
||||||
let errorformat =
|
|
||||||
\ '%E%f:%l:%c: fatal error: %m,' .
|
|
||||||
\ '%E%f:%l:%c: error: %m,' .
|
|
||||||
\ '%W%f:%l:%c: warning: %m,' .
|
|
||||||
\ '%-G%\m%\%%(LLVM ERROR:%\|No compilation database found%\)%\@!%.%#,' .
|
|
||||||
\ '%E%m'
|
|
||||||
|
|
||||||
let env = syntastic#util#isRunningWindows() ? {} : { 'TERM': 'dumb' }
|
|
||||||
|
|
||||||
return SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'env': env,
|
|
||||||
\ 'defaults': {'bufnr': bufnr('')},
|
|
||||||
\ 'returns': [0, 1] })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'c',
|
|
||||||
\ 'name': 'clang_check',
|
|
||||||
\ 'exec': 'clang-check'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,64 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: clang_tidy.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic.vim
|
|
||||||
"Maintainer: Benjamin Bannier <bbannier 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_clang_tidy_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_c_clang_tidy_checker = 1
|
|
||||||
|
|
||||||
if !exists('g:syntastic_clang_tidy_config_file')
|
|
||||||
let g:syntastic_clang_tidy_config_file = '.syntastic_clang_tidy_config'
|
|
||||||
endif
|
|
||||||
|
|
||||||
if !exists('g:syntastic_c_clang_tidy_sort')
|
|
||||||
let g:syntastic_c_clang_tidy_sort = 1
|
|
||||||
endif
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_c_clang_tidy_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({
|
|
||||||
\ 'post_args':
|
|
||||||
\ '-- ' .
|
|
||||||
\ syntastic#c#ReadConfig(g:syntastic_clang_tidy_config_file) . ' ' .
|
|
||||||
\ '-fshow-column ' .
|
|
||||||
\ '-fshow-source-location ' .
|
|
||||||
\ '-fno-caret-diagnostics ' .
|
|
||||||
\ '-fno-color-diagnostics ' .
|
|
||||||
\ '-fdiagnostics-format=clang' })
|
|
||||||
|
|
||||||
let errorformat =
|
|
||||||
\ '%E%f:%l:%c: fatal error: %m,' .
|
|
||||||
\ '%E%f:%l:%c: error: %m,' .
|
|
||||||
\ '%W%f:%l:%c: warning: %m,' .
|
|
||||||
\ '%-G%\m%\%%(LLVM ERROR:%\|No compilation database found%\)%\@!%.%#,' .
|
|
||||||
\ '%E%m'
|
|
||||||
|
|
||||||
let env = syntastic#util#isRunningWindows() ? {} : { 'TERM': 'dumb' }
|
|
||||||
|
|
||||||
return SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'env': env,
|
|
||||||
\ 'defaults': {'bufnr': bufnr('')},
|
|
||||||
\ 'returns': [0, 1] })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'c',
|
|
||||||
\ 'name': 'clang_tidy',
|
|
||||||
\ 'exec': 'clang-tidy'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,62 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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.
|
|
||||||
"============================================================================
|
|
||||||
|
|
||||||
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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,40 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: cppclean.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic
|
|
||||||
"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_c_cppclean_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_c_cppclean_checker = 1
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_c_cppclean_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({})
|
|
||||||
|
|
||||||
let errorformat = '%f:%l: %m'
|
|
||||||
|
|
||||||
return SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'subtype': 'Style',
|
|
||||||
\ 'returns': [0, 1] })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'c',
|
|
||||||
\ 'name': 'cppclean' })
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,61 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: flawfinder.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic
|
|
||||||
"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_c_flawfinder_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_c_flawfinder_checker = 1
|
|
||||||
|
|
||||||
if !exists('g:syntastic_c_flawfinder_sort')
|
|
||||||
let g:syntastic_c_flawfinder_sort = 1
|
|
||||||
endif
|
|
||||||
|
|
||||||
if !exists('g:syntastic_c_flawfinder_thres')
|
|
||||||
let g:syntastic_c_flawfinder_thres = 3
|
|
||||||
endif
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_c_flawfinder_GetHighlightRegex(item)
|
|
||||||
let term = matchstr(a:item['text'], '\m^(\S\+)\s\+\zs\S\+\ze:')
|
|
||||||
return term !=# '' ? '\V\<' . escape(term, '\') . '\>' : ''
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function! SyntaxCheckers_c_flawfinder_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({
|
|
||||||
\ 'args_after': '--columns --dataonly --singleline --quiet' })
|
|
||||||
|
|
||||||
let errorformat = '%f:%l:%c: [%n] %m'
|
|
||||||
|
|
||||||
let loclist = SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'subtype': 'Style',
|
|
||||||
\ 'returns': [0] })
|
|
||||||
|
|
||||||
for e in loclist
|
|
||||||
let e['type'] = e['nr'] < g:syntastic_{self.getFiletype()}_flawfinder_thres ? 'W' : 'E'
|
|
||||||
let e['nr'] = 0
|
|
||||||
endfor
|
|
||||||
|
|
||||||
return loclist
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'c',
|
|
||||||
\ 'name': 'flawfinder' })
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,59 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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
|
|
||||||
call self.log('g:syntastic_c_compiler =', g:syntastic_c_compiler)
|
|
||||||
return executable(expand(g:syntastic_c_compiler, 1))
|
|
||||||
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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,61 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,65 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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.
|
|
||||||
"============================================================================
|
|
||||||
|
|
||||||
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
|
|
||||||
|
|
||||||
if !exists('g:syntastic_c_oclint_sort')
|
|
||||||
let g:syntastic_c_oclint_sort = 1
|
|
||||||
endif
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_c_oclint_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({
|
|
||||||
\ 'post_args': '-- -c ' . syntastic#c#ReadConfig(g:syntastic_oclint_config_file) })
|
|
||||||
|
|
||||||
let errorformat =
|
|
||||||
\ '%E%f:%l:%c: fatal error: %m,' .
|
|
||||||
\ '%E%f:%l:%c: error: %m,' .
|
|
||||||
\ '%W%f:%l:%c: warning: %m,' .
|
|
||||||
\ '%E%f:%l:%c: %m,' .
|
|
||||||
\ '%-G%.%#'
|
|
||||||
|
|
||||||
let loclist = SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'subtype': 'Style',
|
|
||||||
\ 'postprocess': ['compressWhitespace'],
|
|
||||||
\ 'returns': [0, 3, 5] })
|
|
||||||
|
|
||||||
for e in loclist
|
|
||||||
if e['text'] =~# '\v P3( |$)'
|
|
||||||
let e['type'] = 'W'
|
|
||||||
endif
|
|
||||||
|
|
||||||
let e['text'] = substitute(e['text'], '\m\C P[1-3]$', '', '')
|
|
||||||
let e['text'] = substitute(e['text'], '\m\C P[1-3] ', ': ', '')
|
|
||||||
endfor
|
|
||||||
|
|
||||||
return loclist
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'c',
|
|
||||||
\ 'name': 'oclint'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,67 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: pc_lint.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic.vim
|
|
||||||
"Maintainer: Steve Bragg <steve at empresseffects 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_pc_lint_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_c_pc_lint_checker = 1
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
if !exists('g:syntastic_pc_lint_config_file')
|
|
||||||
let g:syntastic_pc_lint_config_file = 'options.lnt'
|
|
||||||
endif
|
|
||||||
|
|
||||||
function! SyntaxCheckers_c_pc_lint_GetLocList() dict
|
|
||||||
let buf = bufnr('')
|
|
||||||
let config = syntastic#util#findFileInParent(g:syntastic_pc_lint_config_file, fnamemodify(bufname(buf), ':p:h'))
|
|
||||||
call self.log('config =', config)
|
|
||||||
|
|
||||||
" -hFs1 - show filename, add space after messages, try to make message 1 line
|
|
||||||
" -width(0,0) - make sure there are no line breaks
|
|
||||||
" -t - set tab size
|
|
||||||
" -v - turn off verbosity
|
|
||||||
let makeprg = self.makeprgBuild({
|
|
||||||
\ 'args': (filereadable(config) ? syntastic#util#shescape(fnamemodify(config, ':p')) : ''),
|
|
||||||
\ 'args_after': ['-hFs1', '-width(0,0)', '-t' . &tabstop, '-format=%f:%l:%C:%t:%n:%m'] })
|
|
||||||
|
|
||||||
let errorformat =
|
|
||||||
\ '%E%f:%l:%v:Error:%n:%m,' .
|
|
||||||
\ '%W%f:%l:%v:Warning:%n:%m,' .
|
|
||||||
\ '%I%f:%l:%v:Info:%n:%m,' .
|
|
||||||
\ '%-G%.%#'
|
|
||||||
|
|
||||||
let loclist = SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'postprocess': ['cygwinRemoveCR'] })
|
|
||||||
|
|
||||||
for e in loclist
|
|
||||||
if e['type'] ==? 'I'
|
|
||||||
let e['type'] = 'W'
|
|
||||||
let e['subtype'] = 'Style'
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
|
|
||||||
return loclist
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'c',
|
|
||||||
\ 'name': 'pc_lint',
|
|
||||||
\ 'exec': 'lint-nt'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,48 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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.
|
|
||||||
"============================================================================
|
|
||||||
|
|
||||||
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, 1] })
|
|
||||||
return loclist
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'c',
|
|
||||||
\ 'name': 'sparse'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,55 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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.
|
|
||||||
"============================================================================
|
|
||||||
|
|
||||||
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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,56 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 buf = bufnr('')
|
|
||||||
let makeprg = self.getExecEscaped() . ' check'
|
|
||||||
|
|
||||||
let errorformat =
|
|
||||||
\ '%Ecabal: %f:%l: %m,' .
|
|
||||||
\ '%W* %m'
|
|
||||||
|
|
||||||
return SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'cwd': fnamemodify(bufname(buf), ':p:h'),
|
|
||||||
\ 'preprocess': 'cabal',
|
|
||||||
\ 'defaults': {'bufnr': buf} })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'cabal',
|
|
||||||
\ 'name': 'cabal'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,39 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,40 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: cmakelint.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic
|
|
||||||
"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_cmake_cmakelint_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_cmake_cmakelint_checker = 1
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_cmake_cmakelint_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({})
|
|
||||||
|
|
||||||
let errorformat = '%f:%l: %m'
|
|
||||||
|
|
||||||
return SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'subtype': 'Style',
|
|
||||||
\ 'returns': [0, 1] })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'cmake',
|
|
||||||
\ 'name': 'cmakelint' })
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,47 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 = syntastic#util#tmpdir()
|
|
||||||
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'
|
|
||||||
|
|
||||||
let loclist = SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat })
|
|
||||||
|
|
||||||
call syntastic#util#rmrf(tmpdir)
|
|
||||||
|
|
||||||
return loclist
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'co',
|
|
||||||
\ 'name': 'coco'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,47 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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
|
|
||||||
call self.log('g:syntastic_cobol_compiler =', g:syntastic_cobol_compiler)
|
|
||||||
return executable(expand(g:syntastic_cobol_compiler, 1))
|
|
||||||
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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,58 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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
|
|
||||||
if !executable(self.getExec())
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
let ver = self.getVersion(self.getExecEscaped() . ' --version 2>' . syntastic#util#DevNull())
|
|
||||||
return syntastic#util#versionIsAtLeast(ver, [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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,44 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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(self.getVersion(), [1, 4])
|
|
||||||
endif
|
|
||||||
let makeprg = self.makeprgBuild({ 'args_after': (s:coffeelint_new ? '--reporter csv' : '--csv') })
|
|
||||||
|
|
||||||
let errorformat = '%f:%l:%t:%m'
|
|
||||||
|
|
||||||
return SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'subtype': 'Style',
|
|
||||||
\ 'returns': [0, 1],
|
|
||||||
\ 'preprocess': 'coffeelint' })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'coffee',
|
|
||||||
\ 'name': 'coffeelint'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,40 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,24 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: avrgcc.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic
|
|
||||||
"Maintainer: Sławek Piotrowski <sentinel at atteo 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_avrgcc_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_cpp_avrgcc_checker = 1
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'cpp',
|
|
||||||
\ 'name': 'avrgcc',
|
|
||||||
\ 'exec': 'avr-g++',
|
|
||||||
\ 'redirect': 'c/avrgcc'})
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,22 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: clang_check.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic.vim
|
|
||||||
"Maintainer: Benjamin Bannier <bbannier 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_clang_check_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_cpp_clang_check_checker = 1
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'cpp',
|
|
||||||
\ 'name': 'clang_check',
|
|
||||||
\ 'redirect': 'c/clang_check'})
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,22 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: clang_tidy.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic.vim
|
|
||||||
"Maintainer: Benjamin Bannier <bbannier 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_clang_tidy_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_cpp_clang_tidy_checker = 1
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'cpp',
|
|
||||||
\ 'name': 'clang_tidy',
|
|
||||||
\ 'redirect': 'c/clang_tidy'})
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,22 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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.
|
|
||||||
"============================================================================
|
|
||||||
|
|
||||||
if exists('g:loaded_syntastic_cpp_cppcheck_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_cpp_cppcheck_checker = 1
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'cpp',
|
|
||||||
\ 'name': 'cppcheck',
|
|
||||||
\ 'redirect': 'c/cppcheck'})
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,22 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: cppclean.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic
|
|
||||||
"Maintainer: Benjamin Bannier <bbannier 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_cppclean_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_cpp_cppclean_checker = 1
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'cpp',
|
|
||||||
\ 'name': 'cppclean',
|
|
||||||
\ 'redirect': 'c/cppclean'})
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,52 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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.
|
|
||||||
"
|
|
||||||
"============================================================================
|
|
||||||
|
|
||||||
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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,26 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: flawfinder.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic
|
|
||||||
"Maintainer: Benjamin Bannier <bbannier 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_flawfinder_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_cpp_flawfinder_checker = 1
|
|
||||||
|
|
||||||
if !exists('g:syntastic_cpp_flawfinder_thres')
|
|
||||||
let g:syntastic_cpp_flawfinder_thres = 3
|
|
||||||
endif
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'cpp',
|
|
||||||
\ 'name': 'flawfinder',
|
|
||||||
\ 'redirect': 'c/flawfinder'})
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,56 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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
|
|
||||||
call self.log('g:syntastic_cpp_compiler =', g:syntastic_cpp_compiler)
|
|
||||||
return executable(expand(g:syntastic_cpp_compiler, 1))
|
|
||||||
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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,22 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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.
|
|
||||||
"============================================================================
|
|
||||||
|
|
||||||
if exists('g:loaded_syntastic_cpp_oclint_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_cpp_oclint_checker = 1
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'cpp',
|
|
||||||
\ 'name': 'oclint',
|
|
||||||
\ 'redirect': 'c/oclint'})
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,23 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: pc_lint.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic.vim
|
|
||||||
"Maintainer: Steve Bragg <steve at empresseffects 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_pc_lint_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_cpp_pc_lint_checker = 1
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'cpp',
|
|
||||||
\ 'name': 'pc_lint',
|
|
||||||
\ 'redirect': 'c/pc_lint'})
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,48 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: verapp.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic.vim
|
|
||||||
"Maintainer: Lucas Verney <phyks@phyks.me>
|
|
||||||
"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 Vera++ 1.3.0
|
|
||||||
"============================================================================
|
|
||||||
|
|
||||||
if exists('g:loaded_syntastic_cpp_verapp_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_cpp_verapp_checker = 1
|
|
||||||
|
|
||||||
if !exists('g:syntastic_verapp_config_file')
|
|
||||||
let g:syntastic_verapp_config_file = '.syntastic_verapp_config'
|
|
||||||
endif
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_cpp_verapp_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({
|
|
||||||
\ 'args': syntastic#c#ReadConfig(g:syntastic_verapp_config_file),
|
|
||||||
\ 'args_after': '--show-rule --no-duplicate -S -c -' })
|
|
||||||
|
|
||||||
let errorformat = '%f:%t:%l:%c:%m'
|
|
||||||
|
|
||||||
return SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'preprocess': 'checkstyle',
|
|
||||||
\ 'subtype': 'Style' })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'cpp',
|
|
||||||
\ 'name': 'verapp',
|
|
||||||
\ 'exec': 'vera++'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,39 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,47 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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.
|
|
||||||
"============================================================================
|
|
||||||
|
|
||||||
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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,22 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: mixedindentlint.vim
|
|
||||||
"Description: Mixed indentation linter for vim
|
|
||||||
"Maintainer: Payton Swick <payton@foolord.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_mixedindentlint_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_css_mixedindentlint_checker = 1
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'css',
|
|
||||||
\ 'name': 'mixedindentlint',
|
|
||||||
\ 'redirect': 'javascript/mixedindentlint'})
|
|
||||||
|
|
||||||
" vim: set et sts=4 sw=4:
|
|
@ -1,23 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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.
|
|
||||||
"
|
|
||||||
"============================================================================
|
|
||||||
|
|
||||||
if exists('g:loaded_syntastic_css_phpcs_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_css_phpcs_checker = 1
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'css',
|
|
||||||
\ 'name': 'phpcs',
|
|
||||||
\ 'redirect': 'php/phpcs'})
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,61 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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.
|
|
||||||
"
|
|
||||||
"============================================================================
|
|
||||||
|
|
||||||
if exists('g:loaded_syntastic_css_prettycss_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_css_prettycss_checker = 1
|
|
||||||
|
|
||||||
if !exists('g:syntastic_css_prettycss_sort')
|
|
||||||
let g:syntastic_css_prettycss_sort = 1
|
|
||||||
endif
|
|
||||||
|
|
||||||
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
|
|
||||||
|
|
||||||
return loclist
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'css',
|
|
||||||
\ 'name': 'prettycss'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,24 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'css',
|
|
||||||
\ 'name': 'recess',
|
|
||||||
\ 'redirect': 'less/recess'})
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,47 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: stylelint.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic.vim using `stylelint`
|
|
||||||
" (https://github.com/stylelint/stylelint).
|
|
||||||
"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_stylelint_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_css_stylelint_checker = 1
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
let s:args_after = {
|
|
||||||
\ 'css': '-f json',
|
|
||||||
\ 'scss': '-f json -s scss' }
|
|
||||||
|
|
||||||
function! SyntaxCheckers_css_stylelint_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({ 'args_after': get(s:args_after, self.getFiletype(), '') })
|
|
||||||
|
|
||||||
let errorformat = '%t:%f:%l:%c:%m'
|
|
||||||
|
|
||||||
return SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'subtype': 'Style',
|
|
||||||
\ 'preprocess': 'stylelint',
|
|
||||||
\ 'returns': [0, 1, 2] })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'css',
|
|
||||||
\ 'name': 'stylelint'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
||||||
|
|
@ -1,42 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,93 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: cuda.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic
|
|
||||||
"Author: Hannes Schulz <schulz at ais dot uni-bonn dot de>
|
|
||||||
"
|
|
||||||
"============================================================================
|
|
||||||
|
|
||||||
if exists('g:loaded_syntastic_cuda_nvcc_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_cuda_nvcc_checker = 1
|
|
||||||
|
|
||||||
if !exists('g:syntastic_cuda_config_file')
|
|
||||||
let g:syntastic_cuda_config_file = '.syntastic_cuda_config'
|
|
||||||
endif
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_cuda_nvcc_GetLocList() dict
|
|
||||||
let buf = bufnr('')
|
|
||||||
let arch_flag = syntastic#util#bufVar(buf, 'cuda_arch')
|
|
||||||
if arch_flag !=# ''
|
|
||||||
let arch_flag = '-arch=' . arch_flag
|
|
||||||
call syntastic#log#oneTimeWarn('variable g:syntastic_cuda_arch is deprecated, ' .
|
|
||||||
\ 'please add ' . string(arch_flag) . ' to g:syntastic_cuda_nvcc_args instead')
|
|
||||||
endif
|
|
||||||
|
|
||||||
let build_opts = {}
|
|
||||||
let dummy = ''
|
|
||||||
if index(['h', 'hpp', 'cuh'], fnamemodify(bufname(buf), ':e'), 0, 1) >= 0
|
|
||||||
if syntastic#util#bufVar(buf, 'cuda_check_header', 0)
|
|
||||||
let dummy = fnamemodify(bufname(buf), ':p:h') . syntastic#util#Slash() . '.syntastic_dummy.cu'
|
|
||||||
let build_opts = {
|
|
||||||
\ 'exe_before': 'echo > ' . syntastic#util#shescape(dummy) . ' ;',
|
|
||||||
\ 'fname_before': '.syntastic_dummy.cu -include' }
|
|
||||||
else
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
call extend(build_opts, {
|
|
||||||
\ 'args_before': arch_flag . ' --cuda -O0 -I .',
|
|
||||||
\ 'args': syntastic#c#ReadConfig(g:syntastic_cuda_config_file),
|
|
||||||
\ 'args_after': '-Xcompiler -fsyntax-only',
|
|
||||||
\ 'tail_after': syntastic#c#NullOutput() })
|
|
||||||
|
|
||||||
let makeprg = self.makeprgBuild(build_opts)
|
|
||||||
|
|
||||||
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'
|
|
||||||
|
|
||||||
let loclist = SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'defaults': {'type': 'E'} })
|
|
||||||
|
|
||||||
for e in loclist
|
|
||||||
let pat = matchstr(e['text'], '\m\c^\s*warning:\s*\zs.*')
|
|
||||||
if pat !=# ''
|
|
||||||
let e['text'] = pat
|
|
||||||
let e['type'] = 'W'
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
|
|
||||||
if dummy !=# ''
|
|
||||||
call delete(dummy)
|
|
||||||
endif
|
|
||||||
|
|
||||||
return loclist
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'cuda',
|
|
||||||
\ 'name': 'nvcc'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,133 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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
|
|
||||||
|
|
||||||
if !exists('g:syntastic_d_use_dub')
|
|
||||||
let g:syntastic_d_use_dub = 1
|
|
||||||
endif
|
|
||||||
|
|
||||||
if !exists('g:syntastic_d_dub_exec')
|
|
||||||
let g:syntastic_d_dub_exec = 'dub'
|
|
||||||
endif
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_d_dmd_IsAvailable() dict " {{{1
|
|
||||||
if !exists('g:syntastic_d_compiler')
|
|
||||||
let g:syntastic_d_compiler = self.getExec()
|
|
||||||
endif
|
|
||||||
call self.log('g:syntastic_d_compiler =', g:syntastic_d_compiler)
|
|
||||||
return executable(expand(g:syntastic_d_compiler, 1))
|
|
||||||
endfunction " }}}1
|
|
||||||
|
|
||||||
function! SyntaxCheckers_d_dmd_GetLocList() dict " {{{1
|
|
||||||
let buf = bufnr('')
|
|
||||||
if !exists('g:syntastic_d_include_dirs')
|
|
||||||
let g:syntastic_d_include_dirs = s:GetIncludes(self, fnamemodify(bufname(buf), ':p:h'))
|
|
||||||
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 " }}}1
|
|
||||||
|
|
||||||
" Utilities {{{1
|
|
||||||
|
|
||||||
function! s:GetIncludes(checker, base) " {{{2
|
|
||||||
let includes = []
|
|
||||||
|
|
||||||
if g:syntastic_d_use_dub && !exists('s:dub_ok')
|
|
||||||
let s:dub_ok = s:ValidateDub(a:checker)
|
|
||||||
endif
|
|
||||||
|
|
||||||
if g:syntastic_d_use_dub && s:dub_ok
|
|
||||||
let where = escape(a:base, ' ') . ';'
|
|
||||||
|
|
||||||
let old_suffixesadd = &suffixesadd
|
|
||||||
let dirs = syntastic#util#unique(map(filter(
|
|
||||||
\ findfile('dub.json', where, -1) +
|
|
||||||
\ findfile('dub.sdl', where, -1) +
|
|
||||||
\ findfile('package.json', where, -1),
|
|
||||||
\ 'filereadable(v:val)'), 'fnamemodify(v:val, ":h")'))
|
|
||||||
let &suffixesadd = old_suffixesadd
|
|
||||||
call a:checker.log('using dub: looking for includes in', dirs)
|
|
||||||
|
|
||||||
for dir in dirs
|
|
||||||
try
|
|
||||||
execute 'silent lcd ' . fnameescape(dir)
|
|
||||||
let paths = split(syntastic#util#system(syntastic#util#shescape(g:syntastic_d_dub_exec) . ' describe --import-paths'), "\n")
|
|
||||||
silent lcd -
|
|
||||||
if v:shell_error == 0
|
|
||||||
call extend(includes, paths)
|
|
||||||
call a:checker.log('using dub: found includes', paths)
|
|
||||||
endif
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E472/
|
|
||||||
" evil directory is evil
|
|
||||||
endtry
|
|
||||||
endfor
|
|
||||||
endif
|
|
||||||
|
|
||||||
if empty(includes)
|
|
||||||
let includes = filter(glob($HOME . '/.dub/packages/*', 1, 1), 'isdirectory(v:val)')
|
|
||||||
call map(includes, 'isdirectory(v:val . "/source") ? v:val . "/source" : v:val')
|
|
||||||
call add(includes, './source')
|
|
||||||
endif
|
|
||||||
|
|
||||||
return syntastic#util#unique(includes)
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
function! s:ValidateDub(checker) " {{{2
|
|
||||||
let ok = 0
|
|
||||||
|
|
||||||
if executable(g:syntastic_d_dub_exec)
|
|
||||||
let command = syntastic#util#shescape(g:syntastic_d_dub_exec) . ' --version'
|
|
||||||
let version_output = syntastic#util#system(command)
|
|
||||||
call a:checker.log('getVersion: ' . string(command) . ': ' .
|
|
||||||
\ string(split(version_output, "\n", 1)) .
|
|
||||||
\ (v:shell_error ? ' (exit code ' . v:shell_error . ')' : '') )
|
|
||||||
let parsed_ver = syntastic#util#parseVersion(version_output)
|
|
||||||
call a:checker.log(g:syntastic_d_dub_exec . ' version =', parsed_ver)
|
|
||||||
if len(parsed_ver)
|
|
||||||
let ok = syntastic#util#versionIsAtLeast(parsed_ver, [0, 9, 24])
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
return ok
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'd',
|
|
||||||
\ 'name': 'dmd' })
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,48 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: dscanner.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic
|
|
||||||
"Maintainer: ANtlord
|
|
||||||
"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_d_dscanner_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_d_dscanner_checker = 1
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_d_dscanner_GetHighlightRegex(i)
|
|
||||||
let term = matchstr(a:i['text'], '\m^.\{-}''\zs\S\+\ze''')
|
|
||||||
return term !=# '' ? '\V\<' . escape(term, '\') . '\>' : ''
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function! SyntaxCheckers_d_dscanner_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({
|
|
||||||
\ 'args_after': '--report',
|
|
||||||
\ 'tail': '2>' . syntastic#util#DevNull() })
|
|
||||||
|
|
||||||
let errorformat = '%f:%l:%c:%m'
|
|
||||||
|
|
||||||
return SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'preprocess': 'dscanner',
|
|
||||||
\ 'subtype': 'Style',
|
|
||||||
\ 'returns': [0] })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'd',
|
|
||||||
\ 'name': 'dscanner' })
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,79 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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
|
|
||||||
if !exists('s:format_machine')
|
|
||||||
let s:format_machine = syntastic#util#versionIsAtLeast(self.getVersion(), [1, 23]) ? '--format=machine' : '--machine'
|
|
||||||
endif
|
|
||||||
let makeprg = self.makeprgBuild({ 'args_after': s:format_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, 3] })
|
|
||||||
|
|
||||||
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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,55 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: igor.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_docbk_igor_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_docbk_igor_checker = 1
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_docbk_igor_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({})
|
|
||||||
|
|
||||||
let errorformat = '%f:%l:%m'
|
|
||||||
|
|
||||||
let loclist = SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'defaults': { 'type': 'W' },
|
|
||||||
\ 'subtype': 'Style',
|
|
||||||
\ 'returns': [0] })
|
|
||||||
|
|
||||||
let buf = bufnr('')
|
|
||||||
for e in loclist
|
|
||||||
" XXX: igor strips directories from filenames
|
|
||||||
let e['bufnr'] = buf
|
|
||||||
|
|
||||||
let e['hl'] = '\V' . escape( substitute(e['text'], '\m[^:]*:', '', ''), '\' )
|
|
||||||
let e['hl'] = substitute(e['hl'], '\V[', '\\zs', 'g')
|
|
||||||
let e['hl'] = substitute(e['hl'], '\V]', '\\ze', 'g')
|
|
||||||
|
|
||||||
" let e['text'] = substitute(e['text'], '\m:.*$', '', '')
|
|
||||||
endfor
|
|
||||||
|
|
||||||
return loclist
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'docbk',
|
|
||||||
\ 'name': 'igor'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,23 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'docbk',
|
|
||||||
\ 'name': 'xmllint',
|
|
||||||
\ 'redirect': 'xml/xmllint'})
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,53 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: dockerfile_lint.vim
|
|
||||||
"Description: Syntax checking plugin for syntastic.vim using dockerfile-lint
|
|
||||||
" (https://github.com/projectatomic/dockerfile_lint).
|
|
||||||
"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_dockerfile_dockerfile_lint_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_dockerfile_dockerfile_lint_checker = 1
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_dockerfile_dockerfile_lint_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({
|
|
||||||
\ 'args_after': '-j',
|
|
||||||
\ 'fname_before': '-f' })
|
|
||||||
|
|
||||||
let errorformat = '%t:%n:%l:%m'
|
|
||||||
|
|
||||||
let loclist = SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'preprocess': 'dockerfile_lint',
|
|
||||||
\ 'defaults': {'bufnr': bufnr('')},
|
|
||||||
\ 'returns': [0, 1] })
|
|
||||||
|
|
||||||
for e in loclist
|
|
||||||
if e['nr']
|
|
||||||
let e['subtype'] = 'Style'
|
|
||||||
endif
|
|
||||||
call remove(e, 'nr')
|
|
||||||
endfor
|
|
||||||
|
|
||||||
return loclist
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'dockerfile',
|
|
||||||
\ 'name': 'dockerfile_lint'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,41 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"File: hadolint.vim
|
|
||||||
"Description: Dockerfile linter written in Haskell
|
|
||||||
" (http://hadolint.lukasmartinelli.ch/).
|
|
||||||
"Maintainer: Jesper B. Rosenkilde <jbr at humppa dot dk>
|
|
||||||
"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_dockerfile_hadolint_checker')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_syntastic_dockerfile_hadolint_checker = 1
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_dockerfile_hadolint_GetLocList() dict
|
|
||||||
let makeprg = self.makeprgBuild({})
|
|
||||||
|
|
||||||
let errorformat = '%W%f:%l %m'
|
|
||||||
|
|
||||||
return SyntasticMake({
|
|
||||||
\ 'makeprg': makeprg,
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'subtype': 'Style',
|
|
||||||
\ 'returns': [0, 1] })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'dockerfile',
|
|
||||||
\ 'name': 'hadolint'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,38 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,57 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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
|
|
||||||
call self.log(
|
|
||||||
\ 'executable("elixir") = ' . executable('elixir') . ', ' .
|
|
||||||
\ 'executable("mix") = ' . executable('mix'))
|
|
||||||
return executable('elixir') && executable('mix')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function! SyntaxCheckers_elixir_elixir_GetLocList() dict
|
|
||||||
let buf = bufnr('')
|
|
||||||
let make_options = {}
|
|
||||||
let compile_command = 'elixir'
|
|
||||||
let mix_file = syntastic#util#findFileInParent('mix.exs', fnamemodify(bufname(buf), ':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'] =
|
|
||||||
\ '%E** %*[^\ ] %f:%l: %m,' .
|
|
||||||
\ '%W%f:%l: warning: %m'
|
|
||||||
|
|
||||||
return SyntasticMake(make_options)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'elixir',
|
|
||||||
\ 'name': 'elixir',
|
|
||||||
\ 'enable': 'enable_elixir_checker'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,284 +0,0 @@
|
|||||||
#!/usr/bin/env escript
|
|
||||||
|
|
||||||
main([File]) ->
|
|
||||||
Dir = get_root(filename:dirname(File)),
|
|
||||||
Defs = [strong_validation,
|
|
||||||
warn_export_all,
|
|
||||||
warn_export_vars,
|
|
||||||
warn_shadow_vars,
|
|
||||||
warn_obsolete_guard,
|
|
||||||
warn_unused_import,
|
|
||||||
report,
|
|
||||||
{i, Dir ++ "/include"}],
|
|
||||||
%% `rebar.config` is looked for,
|
|
||||||
%% but it is not necessarily the one in the project root.
|
|
||||||
%% I.e. it may be one deeper in the project file hierarchy.
|
|
||||||
Profile = which_compile_opts_profile(filename:absname(File)),
|
|
||||||
CompileOpts = case which_build_tool(Dir, Profile) of
|
|
||||||
{rebar, RebarFile} ->
|
|
||||||
%% `rebar.config` might contain relative paths.
|
|
||||||
%% They are relative to the file! Not to the project root.
|
|
||||||
%% rebar specific begin
|
|
||||||
rebar_opts(RebarFile);
|
|
||||||
%% rebar specific end
|
|
||||||
{erlangmk, ErlangMkDir} ->
|
|
||||||
%% Erlang.mk specific begin
|
|
||||||
erlangmk_opts(ErlangMkDir, Profile);
|
|
||||||
%% Erlang.mk specific end
|
|
||||||
undefined ->
|
|
||||||
fallback_opts()
|
|
||||||
end,
|
|
||||||
code:add_patha(filename:absname("ebin")),
|
|
||||||
%% `compile:file/2` requires the `{i, Path}` to be relative
|
|
||||||
%% to CWD - no surprise here.
|
|
||||||
compile:file(File, Defs ++ translate_paths(Dir, CompileOpts));
|
|
||||||
|
|
||||||
main(_) ->
|
|
||||||
io:format("Usage: ~s <file>~n", [escript:script_name()]),
|
|
||||||
halt(1).
|
|
||||||
|
|
||||||
which_compile_opts_profile(File) ->
|
|
||||||
case filename:basename(filename:dirname(File)) of
|
|
||||||
"test" -> test;
|
|
||||||
_ -> normal
|
|
||||||
end.
|
|
||||||
|
|
||||||
which_build_tool(Dir, Profile) ->
|
|
||||||
%% rebar specific begin
|
|
||||||
RebarFile = rebar_file(Dir, Profile),
|
|
||||||
%% rebar specific end
|
|
||||||
case filelib:is_file(RebarFile) of
|
|
||||||
true ->
|
|
||||||
{rebar, RebarFile};
|
|
||||||
false ->
|
|
||||||
%% Erlang.mk specific begin
|
|
||||||
ErlangMk = erlangmk_file(Dir),
|
|
||||||
%% Erlang.mk specific end
|
|
||||||
case filelib:is_file(ErlangMk) of
|
|
||||||
true -> {erlangmk, Dir};
|
|
||||||
false -> undefined
|
|
||||||
end
|
|
||||||
end.
|
|
||||||
|
|
||||||
rebar_file(Dir, normal) -> filename:join(Dir, "rebar.config");
|
|
||||||
rebar_file(Dir, test) -> filename:join(Dir, "rebar.test.config").
|
|
||||||
|
|
||||||
erlangmk_file(Dir) -> filename:join(Dir, "erlang.mk").
|
|
||||||
|
|
||||||
rebar_opts(RebarFile) ->
|
|
||||||
Dir = get_root(filename:dirname(RebarFile)),
|
|
||||||
case file:consult(RebarFile) of
|
|
||||||
{ok, Terms} ->
|
|
||||||
RebarLibDirs = proplists:get_value(lib_dirs, Terms, []),
|
|
||||||
lists:foreach(
|
|
||||||
fun(LibDir) ->
|
|
||||||
code:add_pathsa(filelib:wildcard(LibDir ++ "/*/ebin"))
|
|
||||||
end, RebarLibDirs),
|
|
||||||
RebarDepsDir = proplists:get_value(deps_dir, Terms, "deps"),
|
|
||||||
code:add_pathsa(filelib:wildcard(RebarDepsDir ++ "/*/ebin")),
|
|
||||||
IncludeDeps = {i, filename:join(Dir, RebarDepsDir)},
|
|
||||||
proplists:get_value(erl_opts, Terms, []) ++ [IncludeDeps];
|
|
||||||
{error, _} when RebarFile == "rebar.config" ->
|
|
||||||
fallback_opts();
|
|
||||||
{error, _} ->
|
|
||||||
rebar_opts("rebar.config")
|
|
||||||
end.
|
|
||||||
|
|
||||||
erlangmk_opts(BaseDir, Profile) ->
|
|
||||||
Make =
|
|
||||||
case os:getenv("MAKE") of
|
|
||||||
false ->
|
|
||||||
case os:find_executable("gmake") of
|
|
||||||
false -> "make";
|
|
||||||
Path -> Path
|
|
||||||
end;
|
|
||||||
Cmd ->
|
|
||||||
case (lists:member($/, Cmd) orelse lists:member($\\, Cmd)) of
|
|
||||||
true -> Cmd;
|
|
||||||
false -> os:find_executable(Cmd)
|
|
||||||
end
|
|
||||||
end,
|
|
||||||
ERLC_OPTS_Target =
|
|
||||||
case Profile of
|
|
||||||
normal -> "show-ERLC_OPTS";
|
|
||||||
test -> "show-TEST_ERLC_OPTS"
|
|
||||||
end,
|
|
||||||
Args = [
|
|
||||||
"--no-print-directory",
|
|
||||||
"-C", BaseDir,
|
|
||||||
"show-ERL_LIBS",
|
|
||||||
ERLC_OPTS_Target
|
|
||||||
],
|
|
||||||
try
|
|
||||||
Port = erlang:open_port({spawn_executable, Make}, [
|
|
||||||
{args, Args},
|
|
||||||
exit_status, use_stdio, stderr_to_stdout]),
|
|
||||||
case erlangmk_port_receive_loop(Port, "", BaseDir) of
|
|
||||||
{error, _} ->
|
|
||||||
fallback_opts();
|
|
||||||
{ok, {ErlLibs, ErlcOpts}} ->
|
|
||||||
[code:add_pathsa(filelib:wildcard(
|
|
||||||
filename:join([ErlLib, "*", "ebin"])))
|
|
||||||
|| ErlLib <- ErlLibs],
|
|
||||||
ErlcOpts
|
|
||||||
end
|
|
||||||
catch
|
|
||||||
error:_ ->
|
|
||||||
fallback_opts()
|
|
||||||
end.
|
|
||||||
|
|
||||||
erlangmk_port_receive_loop(Port, Stdout, BaseDir) ->
|
|
||||||
receive
|
|
||||||
{Port, {exit_status, 0}} ->
|
|
||||||
erlangmk_format_opts(Stdout, BaseDir);
|
|
||||||
{Port, {exit_status, _}} ->
|
|
||||||
{error, {erlangmk, make_target_failure}};
|
|
||||||
{Port, {data, Out}} ->
|
|
||||||
erlangmk_port_receive_loop(Port, Stdout ++ Out, BaseDir)
|
|
||||||
end.
|
|
||||||
|
|
||||||
erlangmk_format_opts(Stdout, BaseDir) ->
|
|
||||||
case string:tokens(Stdout, "\n") of
|
|
||||||
[ErlLibsLine | ErlcOptsLines] ->
|
|
||||||
ErlLibs = erlangmk_format_erl_libs(ErlLibsLine),
|
|
||||||
ErlcOpts = erlangmk_format_erlc_opts(ErlcOptsLines, BaseDir),
|
|
||||||
{ok, {ErlLibs, ErlcOpts}};
|
|
||||||
_ ->
|
|
||||||
{error, {erlangmk, incorrect_output}}
|
|
||||||
end.
|
|
||||||
|
|
||||||
erlangmk_format_erl_libs(ErlLibsLine) ->
|
|
||||||
case os:type() of
|
|
||||||
{win32, _} -> string:tokens(ErlLibsLine, ";");
|
|
||||||
_ -> string:tokens(ErlLibsLine, ":")
|
|
||||||
end.
|
|
||||||
|
|
||||||
erlangmk_format_erlc_opts(ErlcOptsLines, BaseDir) ->
|
|
||||||
erlangmk_format_erlc_opts(ErlcOptsLines, [], BaseDir).
|
|
||||||
|
|
||||||
erlangmk_format_erlc_opts(["+" ++ Option | Rest], Opts, BaseDir) ->
|
|
||||||
case make_term(Option) of
|
|
||||||
{error, _} -> erlangmk_format_erlc_opts(Rest, Opts, BaseDir);
|
|
||||||
Opt -> erlangmk_format_erlc_opts(Rest, [Opt | Opts], BaseDir)
|
|
||||||
end;
|
|
||||||
erlangmk_format_erlc_opts(["-I" ++ Opt | Rest], Opts, BaseDir)
|
|
||||||
when Opt =/= "" ->
|
|
||||||
erlangmk_format_erlc_opts(["-I", Opt | Rest], Opts, BaseDir);
|
|
||||||
erlangmk_format_erlc_opts(["-I", [C | _] = Dir | Rest], Opts, BaseDir)
|
|
||||||
when C =/= $- andalso C =/= $+ ->
|
|
||||||
AbsDir = filename:absname(Dir, BaseDir),
|
|
||||||
erlangmk_format_erlc_opts(Rest, [{i, AbsDir} | Opts], BaseDir);
|
|
||||||
erlangmk_format_erlc_opts(["-W" ++ Warn | Rest], Opts, BaseDir)
|
|
||||||
when Warn =/= "" ->
|
|
||||||
erlangmk_format_erlc_opts(["-W", Warn | Rest], Opts, BaseDir);
|
|
||||||
erlangmk_format_erlc_opts(["-W", Warn | Rest], Opts, BaseDir) ->
|
|
||||||
case Warn of
|
|
||||||
"all" ->
|
|
||||||
erlangmk_format_erlc_opts(Rest, [{warn_format, 999} | Opts],
|
|
||||||
BaseDir);
|
|
||||||
"error" ->
|
|
||||||
erlangmk_format_erlc_opts(Rest, [warnings_as_errors | Opts],
|
|
||||||
BaseDir);
|
|
||||||
"" ->
|
|
||||||
erlangmk_format_erlc_opts(Rest, [{warn_format, 1} | Opts],
|
|
||||||
BaseDir);
|
|
||||||
_ ->
|
|
||||||
try list_to_integer(Warn) of
|
|
||||||
Level ->
|
|
||||||
erlangmk_format_erlc_opts(Rest,
|
|
||||||
[{warn_format, Level} | Opts], BaseDir)
|
|
||||||
catch
|
|
||||||
error:badarg ->
|
|
||||||
erlangmk_format_erlc_opts(Rest, Opts, BaseDir)
|
|
||||||
end
|
|
||||||
end;
|
|
||||||
erlangmk_format_erlc_opts(["-D" ++ Opt | Rest], Opts, BaseDir)
|
|
||||||
when Opt =/= "" ->
|
|
||||||
erlangmk_format_erlc_opts(["-D", Opt | Rest], Opts, BaseDir);
|
|
||||||
erlangmk_format_erlc_opts(["-D", [C | _] = Val0 | Rest], Opts, BaseDir)
|
|
||||||
when C =/= $- andalso C =/= $+ ->
|
|
||||||
{Key0, Val1} = split_at_equals(Val0, []),
|
|
||||||
Key = list_to_atom(Key0),
|
|
||||||
case Val1 of
|
|
||||||
[] ->
|
|
||||||
erlangmk_format_erlc_opts(Rest, [{d, Key} | Opts], BaseDir);
|
|
||||||
Val2 ->
|
|
||||||
case make_term(Val2) of
|
|
||||||
{error, _} ->
|
|
||||||
erlangmk_format_erlc_opts(Rest, Opts, BaseDir);
|
|
||||||
Val ->
|
|
||||||
erlangmk_format_erlc_opts(Rest, [{d, Key, Val} | Opts], BaseDir)
|
|
||||||
end
|
|
||||||
end;
|
|
||||||
erlangmk_format_erlc_opts([PathFlag, [_ | _] = Dir | Rest], Opts, BaseDir)
|
|
||||||
when PathFlag =:= "-pa" orelse PathFlag =:= "-pz" ->
|
|
||||||
AbsDir = filename:absname(Dir, BaseDir),
|
|
||||||
case PathFlag of
|
|
||||||
"-pa" -> code:add_patha(AbsDir);
|
|
||||||
"-pz" -> code:add_pathz(AbsDir)
|
|
||||||
end,
|
|
||||||
erlangmk_format_erlc_opts(Rest, Opts, BaseDir);
|
|
||||||
erlangmk_format_erlc_opts([_ | Rest], Opts, BaseDir) ->
|
|
||||||
erlangmk_format_erlc_opts(Rest, Opts, BaseDir);
|
|
||||||
erlangmk_format_erlc_opts([], Opts, _) ->
|
|
||||||
lists:reverse(Opts).
|
|
||||||
|
|
||||||
%% Function imported from erl_compile.erl from Erlang 19.1.
|
|
||||||
make_term(Str) ->
|
|
||||||
case erl_scan:string(Str) of
|
|
||||||
{ok, Tokens, _} ->
|
|
||||||
case erl_parse:parse_term(Tokens ++ [{dot, 1}]) of
|
|
||||||
{ok, Term} -> Term;
|
|
||||||
{error, Reason} -> {error, Reason}
|
|
||||||
end;
|
|
||||||
{error, Reason, _} ->
|
|
||||||
{error, Reason}
|
|
||||||
end.
|
|
||||||
|
|
||||||
%% Function imported from erl_compile.erl from Erlang 19.1.
|
|
||||||
split_at_equals([$=|T], Acc) ->
|
|
||||||
{lists:reverse(Acc),T};
|
|
||||||
split_at_equals([H|T], Acc) ->
|
|
||||||
split_at_equals(T, [H|Acc]);
|
|
||||||
split_at_equals([], Acc) ->
|
|
||||||
{lists:reverse(Acc),[]}.
|
|
||||||
|
|
||||||
fallback_opts() ->
|
|
||||||
code:add_pathsa(filelib:wildcard("deps/*/ebin")),
|
|
||||||
code:add_pathsa(nested_app_ebins()),
|
|
||||||
[
|
|
||||||
{ i, filename:absname("apps") }, { i, filename:absname("deps") } | [ { i, filename:absname(Path) } || Path <- filelib:wildcard("deps/*/apps")]
|
|
||||||
].
|
|
||||||
|
|
||||||
nested_app_ebins() ->
|
|
||||||
DetectedAppSrcFiles = filelib:wildcard("deps/*/apps/**/*.app.src"),
|
|
||||||
[apps_dir_from_src(AppSrcFile)||AppSrcFile<-DetectedAppSrcFiles].
|
|
||||||
|
|
||||||
apps_dir_from_src(SrcFile) ->
|
|
||||||
SrcDir = filename:dirname(SrcFile),
|
|
||||||
filename:join(SrcDir, "../../ebin").
|
|
||||||
|
|
||||||
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).
|
|
||||||
|
|
||||||
translate_paths(Dir, RebarOpts) ->
|
|
||||||
[ translate_path(Dir, Opt) || Opt <- RebarOpts ].
|
|
||||||
|
|
||||||
translate_path(Dir, {i, Path}) ->
|
|
||||||
case Path of
|
|
||||||
%% absolute
|
|
||||||
"/" ++ _ -> {i, Path};
|
|
||||||
%% relative -> make absolute taking rebar.config location into account
|
|
||||||
_ -> {i, filename:join([Dir, Path])}
|
|
||||||
end;
|
|
||||||
translate_path(_, Other) -> Other.
|
|
@ -1,63 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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', 1) . syntastic#util#Slash() . 'erlang_check_file.erl')
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_erlang_escript_GetLocList() dict
|
|
||||||
let buf = bufnr('')
|
|
||||||
|
|
||||||
if fnamemodify(bufname(buf), ':e') ==# 'hrl'
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
|
|
||||||
let shebang = syntastic#util#parseShebang(buf)
|
|
||||||
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(fnamemodify(bufname(buf), ':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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,42 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,83 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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
|
|
||||||
call self.log('g:syntastic_eruby_ruby_exec =', g:syntastic_eruby_ruby_exec)
|
|
||||||
endif
|
|
||||||
return executable(self.getExec())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function! SyntaxCheckers_eruby_ruby_GetLocList() dict
|
|
||||||
if !exists('s:ruby_new')
|
|
||||||
let s:ruby_new = syntastic#util#versionIsAtLeast(self.getVersion(), [1, 9])
|
|
||||||
endif
|
|
||||||
|
|
||||||
let buf = bufnr('')
|
|
||||||
let fname = "'" . escape(bufname(buf), "\\'") . "'"
|
|
||||||
|
|
||||||
" TODO: encodings became useful in ruby 1.9 :)
|
|
||||||
if s:ruby_new
|
|
||||||
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() . ' -w -c'
|
|
||||||
|
|
||||||
let errorformat = '%-G%\m%.%#warning: %\%%(possibly %\)%\?useless use of a literal in void context,'
|
|
||||||
|
|
||||||
" filter out lines starting with ...
|
|
||||||
" long lines are truncated and wrapped in ... %p then returns the wrong
|
|
||||||
" column offset
|
|
||||||
let errorformat .= '%-G%\%.%\%.%\%.%.%#,'
|
|
||||||
|
|
||||||
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': buf, 'vcol': 1 } })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'eruby',
|
|
||||||
\ 'name': 'ruby'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,99 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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:type_map = {}
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
function! SyntaxCheckers_fortran_gfortran_IsAvailable() dict " {{{1
|
|
||||||
if !exists('g:syntastic_fortran_compiler')
|
|
||||||
let g:syntastic_fortran_compiler = self.getExec()
|
|
||||||
endif
|
|
||||||
call self.log('g:syntastic_fortran_compiler = ', g:syntastic_fortran_compiler)
|
|
||||||
return executable(expand(g:syntastic_fortran_compiler, 1))
|
|
||||||
endfunction " }}}1
|
|
||||||
|
|
||||||
" @vimlint(EVL104, 1, l:errorformat)
|
|
||||||
function! SyntaxCheckers_fortran_gfortran_GetLocList() dict " {{{1
|
|
||||||
call s:SetCompilerType(g:syntastic_fortran_compiler)
|
|
||||||
if !has_key(s:type_map, g:syntastic_fortran_compiler)
|
|
||||||
call syntastic#log#error("checker fortran/gfortran: can't parse version string (abnormal termination?)")
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
|
|
||||||
if s:type_map[g:syntastic_fortran_compiler] ==# 'gfortran'
|
|
||||||
let errorformat =
|
|
||||||
\ '%-C %#,'.
|
|
||||||
\ '%-C %#%.%#,'.
|
|
||||||
\ '%A%f:%l%[.:]%c:,'.
|
|
||||||
\ '%Z%\m%\%%(Fatal %\)%\?%trror: %m,'.
|
|
||||||
\ '%Z%tarning: %m,'.
|
|
||||||
\ '%-G%.%#'
|
|
||||||
if !exists('g:syntastic_fortran_gfortran_sort')
|
|
||||||
let g:syntastic_fortran_gfortran_sort = 0
|
|
||||||
endif
|
|
||||||
elseif s:type_map[g:syntastic_fortran_compiler] ==# 'ifort'
|
|
||||||
let errorformat =
|
|
||||||
\ '%E%f(%l): error #%n: %m,'.
|
|
||||||
\ '%W%f(%l): warning #%n: %m,'.
|
|
||||||
\ '%W%f(%l): remark #%n: %m,'.
|
|
||||||
\ '%-Z%p^,'.
|
|
||||||
\ '%-G%.%#'
|
|
||||||
if !exists('g:syntastic_fortran_gfortran_sort')
|
|
||||||
let g:syntastic_fortran_gfortran_sort = 1
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
return syntastic#c#GetLocList('fortran', 'gfortran', {
|
|
||||||
\ 'errorformat': errorformat,
|
|
||||||
\ 'main_flags': '-fsyntax-only' })
|
|
||||||
endfunction " }}}1
|
|
||||||
" @vimlint(EVL104, 0, l:errorformat)
|
|
||||||
|
|
||||||
" Utilities {{{1
|
|
||||||
|
|
||||||
function! s:SetCompilerType(exe) " {{{2
|
|
||||||
if !has_key(s:type_map, a:exe)
|
|
||||||
try
|
|
||||||
let ver = filter( split(syntastic#util#system(syntastic#util#shescape(a:exe) . ' --version'), '\n'),
|
|
||||||
\ 'v:val =~# "\\v^%(GNU Fortran|ifort) "' )[0]
|
|
||||||
if ver =~# '\m^GNU Fortran '
|
|
||||||
let s:type_map[a:exe] = 'gfortran'
|
|
||||||
elseif ver =~# '\m^ifort '
|
|
||||||
let s:type_map[a:exe] = 'ifort'
|
|
||||||
endif
|
|
||||||
catch /\m^Vim\%((\a\+)\)\=:E684/
|
|
||||||
" do nothing
|
|
||||||
endtry
|
|
||||||
endif
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'fortran',
|
|
||||||
\ 'name': 'gfortran' })
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,66 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 " {{{1
|
|
||||||
let buf = bufnr('')
|
|
||||||
let makeprg = self.makeprgBuild({
|
|
||||||
\ 'args_before': '-oglsl -profile ' . s:GetProfile(buf),
|
|
||||||
\ '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 " }}}1
|
|
||||||
|
|
||||||
" Utilities {{{1
|
|
||||||
|
|
||||||
function! s:GetProfile(buf) " {{{2
|
|
||||||
let profile = matchstr(get(filter(getbufline(a:buf, 1, 100), 'v:val =~# "\\m\\C^//\\s*profile:"'), 0, ''), '\m\C^//\s*profile:\s*\zs.*')
|
|
||||||
if profile ==# ''
|
|
||||||
let extensions = syntastic#util#bufVar(a:buf, 'glsl_extensions', s:glsl_extensions)
|
|
||||||
let profile = get(extensions, tolower(fnamemodify(bufname(a:buf), ':e')), 'gpu_vert')
|
|
||||||
endif
|
|
||||||
|
|
||||||
return profile
|
|
||||||
endfunction " }}}2
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\'filetype': 'glsl',
|
|
||||||
\'name': 'cgc'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,104 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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(self.getExec()) && executable('gofmt')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function! SyntaxCheckers_go_go_GetLocList() dict
|
|
||||||
if !exists('s:go_new')
|
|
||||||
let s:go_new = syntastic#util#versionIsAtLeast(self.getVersion(self.getExecEscaped() . ' version'), [1, 5])
|
|
||||||
endif
|
|
||||||
let buf = bufnr('')
|
|
||||||
|
|
||||||
" 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 bufname(buf) =~# '\m_test\.go$'
|
|
||||||
let cmd = 'test -c'
|
|
||||||
let opts = syntastic#util#bufVar(buf, 'go_go_test_args', s:go_new ? '-buildmode=archive' : '')
|
|
||||||
let cleanup = 1
|
|
||||||
else
|
|
||||||
let cmd = 'build'
|
|
||||||
let opts = syntastic#util#bufVar(buf, 'go_go_build_args', s:go_new ? '-buildmode=archive' : '')
|
|
||||||
let cleanup = 0
|
|
||||||
endif
|
|
||||||
let opt_str = (type(opts) != type('') || opts !=# '') ? join(syntastic#util#argsescape(opts)) : opts
|
|
||||||
let makeprg = self.getExecEscaped() . ' ' . cmd . ' ' . opt_str
|
|
||||||
|
|
||||||
" 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,' .
|
|
||||||
\ '%+Ecan''t load package: %m,' .
|
|
||||||
\ '%+Einternal error: %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': fnamemodify(bufname(buf), ':p:h'),
|
|
||||||
\ 'env': {'GOGC': 'off'},
|
|
||||||
\ 'defaults': {'type': 'e'} })
|
|
||||||
|
|
||||||
if cleanup
|
|
||||||
call delete(fnamemodify(bufname(buf), ':p:h') . syntastic#util#Slash() . fnamemodify(bufname(buf), ':p:h') . '.test')
|
|
||||||
endif
|
|
||||||
|
|
||||||
return errors
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'go',
|
|
||||||
\ 'name': 'go'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
@ -1,45 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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 sw=4 sts=4 et fdm=marker:
|
|
@ -1,42 +0,0 @@
|
|||||||
"============================================================================
|
|
||||||
"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,
|
|
||||||
\ 'defaults': {'type': 'w'},
|
|
||||||
\ 'subtype': 'Style' })
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
||||||
\ 'filetype': 'go',
|
|
||||||
\ 'name': 'golint'})
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
|
|
||||||
" vim: set sw=4 sts=4 et fdm=marker:
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user