summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKabbaj Amine <amine.kabb@gmail.com>2016-10-03 22:24:04 +0300
committerKabbaj Amine <amine.kabb@gmail.com>2016-10-03 22:24:04 +0300
commit5db4710e6d5054013ceb2f6716f65c35ffa2a820 (patch)
tree2d8398f52cbc9028ca958db16203873cb207a5b5
parent60a03cb933d09b9d32bdaee001cfa6435c3a5593 (diff)
downloadale-5db4710e6d5054013ceb2f6716f65c35ffa2a820.zip
Add linter jsonlint for json
-rw-r--r--README.md1
-rw-r--r--ale_linters/json/jsonlint.vim44
2 files changed, 45 insertions, 0 deletions
diff --git a/README.md b/README.md
index 002a6043..a1e4dd8b 100644
--- a/README.md
+++ b/README.md
@@ -33,6 +33,7 @@ name. That seems to be the fairest way to arrange this table.
| Fortran | [gcc](https://gcc.gnu.org/) |
| Haskell | [ghc](https://www.haskell.org/ghc/)^ |
| JavaScript | [eslint](http://eslint.org/), [jscs](http://jscs.info/), [jshint](http://jshint.com/) |
+| Json | [jsonlint](http://zaa.ch/jsonlint/) |
| Python | [flake8](http://flake8.pycqa.org/en/latest/) |
| Ruby | [rubocop](https://github.com/bbatsov/rubocop) |
| Vim | [vint](https://github.com/Kuniwak/vint)^ |
diff --git a/ale_linters/json/jsonlint.vim b/ale_linters/json/jsonlint.vim
new file mode 100644
index 00000000..bacb87bf
--- /dev/null
+++ b/ale_linters/json/jsonlint.vim
@@ -0,0 +1,44 @@
+" Author: KabbAmine <amine.kabb@gmail.com>
+
+if exists('g:loaded_ale_linters_json_jsonlint')
+ finish
+endif
+
+let g:loaded_ale_linters_json_jsonlint = 1
+
+function! ale_linters#json#jsonlint#Handle(buffer, lines)
+ " Matches patterns like the following:
+ " line 2, col 15, found: 'STRING' - expected: 'EOF', '}', ',', ']'.
+
+ let pattern = 'line \(\d\+\), col \(\d*\), \(.\+\)'
+ let output = []
+
+ for line in a:lines
+ let match = matchlist(line, pattern)
+
+ if len(l:match) == 0
+ continue
+ endif
+
+ " vcol is needed to indicate that the column is a character
+ call add(output, {
+ \ 'bufnr': a:buffer,
+ \ 'lnum': match[1] + 0,
+ \ 'vcol': 0,
+ \ 'col': match[2] + 0,
+ \ 'text': match[3],
+ \ 'type': 'E',
+ \ 'nr': -1,
+ \})
+ endfor
+
+ return output
+endfunction
+
+call ALEAddLinter('json', {
+\ 'name': 'jsonlint',
+\ 'executable': 'jsonlint',
+\ 'output_stream': 'stderr',
+\ 'command': 'jsonlint --compact -',
+\ 'callback': 'ale_linters#json#jsonlint#Handle',
+\})