diff options
author | Shogo NAMEKI <nametake.kyarabuki@gmail.com> | 2017-11-20 19:57:13 +0900 |
---|---|---|
committer | w0rp <w0rp@users.noreply.github.com> | 2017-11-20 10:57:13 +0000 |
commit | f20e5a4cf0e56c3c89ef7be4730924be377e5f61 (patch) | |
tree | 71abbae0f375fca62cf335f2cfc95b80aa2f31c3 /ale_linters | |
parent | f224ce8a377bbb3a0deb78b98fdc6c43555791e2 (diff) | |
download | ale-f20e5a4cf0e56c3c89ef7be4730924be377e5f61.zip |
Add `drafter` for checking API Blueprint files (#1152)
Diffstat (limited to 'ale_linters')
-rw-r--r-- | ale_linters/apiblueprint/drafter.vim | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/ale_linters/apiblueprint/drafter.vim b/ale_linters/apiblueprint/drafter.vim new file mode 100644 index 00000000..9cded359 --- /dev/null +++ b/ale_linters/apiblueprint/drafter.vim @@ -0,0 +1,36 @@ +" Author: nametake https://nametake.github.io +" Description: apiblueprint parser + +function! ale_linters#apiblueprint#drafter#HandleErrors(buffer, lines) abort + " Matches patterns line the following: + " + " warning: (3) unable to parse response signature, expected 'response [<HTTP status code>] [(<media type>)]'; line 4, column 3k - line 4, column 22 + " warning: (10) message-body asset is expected to be a pre-formatted code block, separate it by a newline and indent every of its line by 12 spaces or 3 tabs; line 30, column 5 - line 30, column 9; line 31, column 9 - line 31, column 14; line 32, column 9 - line 32, column 14 + let l:pattern = '\(^.*\): (\d\+) \(.\{-\}\); line \(\d\+\), column \(\d\+\) - line \d\+, column \d\+\(.*; line \d\+, column \d\+ - line \(\d\+\), column \(\d\+\)\)\{-\}$' + let l:output = [] + + for l:match in ale#util#GetMatches(a:lines[2:], l:pattern) + let l:item = { + \ 'type': l:match[1] is# 'warning' ? 'W' : 'E', + \ 'text': l:match[2], + \ 'lnum': l:match[3] + 0, + \ 'col': l:match[4] + 0, + \} + if l:match[5] isnot# '' + let l:item.end_lnum = l:match[6] + 0 + let l:item.end_col = l:match[7] + 0 + endif + call add(l:output, l:item) + endfor + + return l:output +endfunction + + +call ale#linter#Define('apiblueprint', { +\ 'name': 'drafter', +\ 'output_stream': 'stderr', +\ 'executable': 'drafter', +\ 'command': 'drafter --use-line-num --validate %t', +\ 'callback': 'ale_linters#apiblueprint#drafter#HandleErrors', +\}) |