summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNic West <nicwest.cb@gmail.com>2017-11-15 21:46:51 +0000
committerNic West <nicwest.cb@gmail.com>2017-11-15 22:23:46 +0000
commiteda20d0585567b22befa0e011324aaa91b9bebca (patch)
tree75b74d084e741a73afe379f10428b12f4ddf5c98
parent1d65e5692f7075bad6806d88eb11961ea32d3e7d (diff)
downloadale-eda20d0585567b22befa0e011324aaa91b9bebca.zip
add joker handler for clojure
Adds new linter for clojure using joker https://github.com/candid82/joker fixes #975 ref #544 #1040
-rw-r--r--README.md1
-rw-r--r--ale_linters/clojure/joker.vim32
-rw-r--r--doc/ale-clojure.txt21
-rw-r--r--doc/ale.txt3
-rw-r--r--test/handler/test_clojure_joker_handler.vader75
5 files changed, 132 insertions, 0 deletions
diff --git a/README.md b/README.md
index cf812aff..6084ccea 100644
--- a/README.md
+++ b/README.md
@@ -81,6 +81,7 @@ formatting.
| CUDA | [nvcc](http://docs.nvidia.com/cuda/cuda-compiler-driver-nvcc/index.html) |
| C# | [mcs](http://www.mono-project.com/docs/about-mono/languages/csharp/) see:`help ale-cs-mcs` for details, [mcsc](http://www.mono-project.com/docs/about-mono/languages/csharp/) !! see:`help ale-cs-mcsc` for details and configuration|
| Chef | [foodcritic](http://www.foodcritic.io/) |
+| Clojure | [joker](https://github.com/candid82/joker) |
| CMake | [cmakelint](https://github.com/richq/cmake-lint) |
| CoffeeScript | [coffee](http://coffeescript.org/), [coffeelint](https://www.npmjs.com/package/coffeelint) |
| Crystal | [crystal](https://crystal-lang.org/) !! |
diff --git a/ale_linters/clojure/joker.vim b/ale_linters/clojure/joker.vim
new file mode 100644
index 00000000..e78066fe
--- /dev/null
+++ b/ale_linters/clojure/joker.vim
@@ -0,0 +1,32 @@
+" Author: Nic West <nicwest@mailbox.org>
+" Description: linter for clojure using joker https://github.com/candid82/joker
+
+function! ale_linters#clojure#joker#HandleJokerFormat(buffer, lines) abort
+ " output format
+ " <filename>:<line>:<column>: <issue type>: <message>
+ let l:pattern = '\v^[a-zA-Z]?:?[^:]+:(\d+):(\d+):? ((Read error|Parse error|Parse warning|Exception): ?(.+))$'
+ let l:output = []
+
+ for l:match in ale#util#GetMatches(a:lines, l:pattern)
+ let l:type = 'E'
+ if l:match[4] is? 'Parse warning'
+ let l:type = 'W'
+ endif
+ call add(l:output, {
+ \ 'lnum': l:match[1] + 0,
+ \ 'col': l:match[2] + 0,
+ \ 'text': l:match[3],
+ \ 'type': l:type,
+ \})
+ endfor
+
+ return l:output
+endfunction
+
+call ale#linter#Define('clojure', {
+\ 'name': 'joker',
+\ 'output_stream': 'stderr',
+\ 'executable': 'joker',
+\ 'command': 'joker --lint %t',
+\ 'callback': 'ale_linters#clojure#joker#HandleJokerFormat',
+\})
diff --git a/doc/ale-clojure.txt b/doc/ale-clojure.txt
new file mode 100644
index 00000000..a83e336f
--- /dev/null
+++ b/doc/ale-clojure.txt
@@ -0,0 +1,21 @@
+===============================================================================
+ALE Clojure Integration *ale-clojure-options*
+
+
+===============================================================================
+joker *ale-clojure-joker*
+
+Joker is a small Clojure interpreter and linter written in Go.
+
+https://github.com/candid82/joker
+
+Linting options are not configurable by ale, but instead are controlled by a
+`.joker` file in same directory as the file (or current working directory if
+linting stdin), a parent directory relative to the file, or the users home
+directory.
+
+see https://github.com/candid82/joker#linter-mode for more information.
+
+===============================================================================
+ vim:tw=78:ts=2:sts=2:sw=2:ft=help:norl:
+
diff --git a/doc/ale.txt b/doc/ale.txt
index 9947d091..3290721a 100644
--- a/doc/ale.txt
+++ b/doc/ale.txt
@@ -29,6 +29,8 @@ CONTENTS *ale-contents*
gcc.................................|ale-c-gcc|
chef..................................|ale-chef-options|
foodcritic..........................|ale-chef-foodcritic|
+ clojure...............................|ale-clojure-options|
+ joker...............................|ale-clojure-joker|
cmake.................................|ale-cmake-options|
cmakelint...........................|ale-cmake-cmakelint|
cpp...................................|ale-cpp-options|
@@ -271,6 +273,7 @@ Notes:
* CUDA: `nvcc`!!
* C#: `mcs`, `mcsc`!!
* Chef: `foodcritic`
+* Clojure: `joker`
* CMake: `cmakelint`
* CoffeeScript: `coffee`, `coffeelint`
* Crystal: `crystal`!!
diff --git a/test/handler/test_clojure_joker_handler.vader b/test/handler/test_clojure_joker_handler.vader
new file mode 100644
index 00000000..460c62e8
--- /dev/null
+++ b/test/handler/test_clojure_joker_handler.vader
@@ -0,0 +1,75 @@
+Before:
+ runtime ale_linters/clojure/joker.vim
+
+After:
+ call ale#linter#Reset()
+
+Execute(the clojure joker handler should be able to handle errors):
+ AssertEqual
+ \ [
+ \ {
+ \ 'lnum': 123,
+ \ 'col': 44,
+ \ 'type': 'E',
+ \ 'text': 'Read error: Unexpected )',
+ \ },
+ \ ],
+ \ ale_linters#clojure#joker#HandleJokerFormat(0, [
+ \ 'test.clj:123:44: Read error: Unexpected )',
+ \ ])
+
+Execute(the clojure joker handler should be able to handle warnings):
+ AssertEqual
+ \ [
+ \ {
+ \ 'lnum': 654,
+ \ 'col': 321,
+ \ 'type': 'W',
+ \ 'text': 'Parse warning: let form with empty body',
+ \ }
+ \ ],
+ \ ale_linters#clojure#joker#HandleJokerFormat(0, [
+ \ 'test.clj:654:321: Parse warning: let form with empty body'
+ \ ])
+
+Execute(the clojure joker handler should be able to handle exceptions):
+ AssertEqual
+ \ [
+ \ {
+ \ 'lnum': 123,
+ \ 'col': 321,
+ \ 'type': 'E',
+ \ 'text': 'Exception: something horrible happen',
+ \ }
+ \ ],
+ \ ale_linters#clojure#joker#HandleJokerFormat(0, [
+ \ 'test.clj:123:321: Exception: something horrible happen'
+ \ ])
+
+Execute(the clojure joker handler should be able to handle errors from stdin):
+ AssertEqual
+ \ [
+ \ {
+ \ 'lnum': 16,
+ \ 'col': 1,
+ \ 'type': 'E',
+ \ 'text': 'Read error: Unexpected )',
+ \ },
+ \ ],
+ \ ale_linters#clojure#joker#HandleJokerFormat(0, [
+ \ '<stdin>:16:1: Read error: Unexpected )',
+ \ ])
+
+Execute(the clojure joker handler should be able to handle windows files):
+ AssertEqual
+ \ [
+ \ {
+ \ 'lnum': 123,
+ \ 'col': 44,
+ \ 'type': 'E',
+ \ 'text': 'Read error: Unexpected )',
+ \ }
+ \ ],
+ \ ale_linters#clojure#joker#HandleJokerFormat(0, [
+ \ 'C:\my\operating\system\is\silly\core.clj:123:44: Read error: Unexpected )',
+ \ ])