summaryrefslogtreecommitdiff
path: root/ale_linters
diff options
context:
space:
mode:
authorMatthias Günther <matze@wikimatze.de>2017-04-25 19:38:02 +0200
committerw0rp <w0rp@users.noreply.github.com>2017-04-25 18:38:02 +0100
commitc55064881db1543aa6dbbf2490623064daa6b935 (patch)
treec6d7012272a33ccd963c74021f2fb9e9c52e6dba /ale_linters
parenta25b55b954730b4cce2af358f56d3ba2f663ebf5 (diff)
downloadale-c55064881db1543aa6dbbf2490623064daa6b935.zip
Add erb linter (#497)
* Add eruby linter * Update README with erb linter * Fix example and contributions * Remove trailing newline * Fix for Vimscript style guide * Eruby-linter: codereview with @w0rp - read from stderro output_stream * Eruby-linter: codereview => add handler for ruby * Eruby-linter: codereview - eruby and ruby lint use the same ruby-handler (removes duplicated handling logic) * Eruby-linter: try to fix tests
Diffstat (limited to 'ale_linters')
-rw-r--r--ale_linters/eruby/erubylint.vim11
-rw-r--r--ale_linters/ruby/ruby.vim31
2 files changed, 12 insertions, 30 deletions
diff --git a/ale_linters/eruby/erubylint.vim b/ale_linters/eruby/erubylint.vim
new file mode 100644
index 00000000..2ff03c32
--- /dev/null
+++ b/ale_linters/eruby/erubylint.vim
@@ -0,0 +1,11 @@
+" Author: Matthias Guenther - https://wikimatze.de
+" Description: erb-lint for eruby/erb files
+
+call ale#linter#Define('eruby', {
+\ 'name': 'erubylint',
+\ 'executable': 'erb',
+\ 'output_stream': 'stderr',
+\ 'command': 'erb -P -x %t | ruby -c',
+\ 'callback': 'ale#handlers#ruby#HandleSyntaxErrors',
+\})
+
diff --git a/ale_linters/ruby/ruby.vim b/ale_linters/ruby/ruby.vim
index 1ed9d429..a9f7b51b 100644
--- a/ale_linters/ruby/ruby.vim
+++ b/ale_linters/ruby/ruby.vim
@@ -1,39 +1,10 @@
" Author: Brandon Roehl - https://github.com/BrandonRoehl
" Description: Ruby MRI for Ruby files
-function! ale_linters#ruby#ruby#Handle(buffer, lines) abort
- " Matches patterns line the following:
- "
- " test.rb:3: warning: parentheses after method name is interpreted as an argument list, not a decomposed argument
- " test.rb:8: syntax error, unexpected keyword_end, expecting end-of-input
- let l:pattern = '\v^.+:(\d+): (warning: )?(.+)$'
- let l:column = '\v^(\s+)\^$'
- let l:output = []
-
- for l:line in a:lines
- let l:match = matchlist(l:line, l:pattern)
- if len(l:match) == 0
- let l:match = matchlist(l:line, l:column)
- if len(l:match) != 0
- let l:output[len(l:output) - 1]['col'] = len(l:match[1])
- endif
- else
- call add(l:output, {
- \ 'lnum': l:match[1] + 0,
- \ 'col': 0,
- \ 'text': l:match[2] . l:match[3],
- \ 'type': empty(l:match[2]) ? 'E' : 'W',
- \})
- endif
- endfor
-
- return l:output
-endfunction
-
call ale#linter#Define('ruby', {
\ 'name': 'ruby',
\ 'executable': 'ruby',
\ 'output_stream': 'stderr',
\ 'command': 'ruby -w -c -T1 %t',
-\ 'callback': 'ale_linters#ruby#ruby#Handle',
+\ 'callback': 'ale#handlers#ruby#HandleSyntaxErrors',
\})