summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authortatsuya <t2h5k0@gmail.com>2021-01-06 13:22:08 +0900
committertatsuya <t2h5k0@gmail.com>2021-01-23 11:56:10 +0900
commit997dd7f8fe45030e65b418c5f46e20d808b1c5eb (patch)
treee096a71b750d6a6826410d983287766237c4f0c2
parent5a47d878fbb837af4c89ab545f473f8526bd4d64 (diff)
downloadale-997dd7f8fe45030e65b418c5f46e20d808b1c5eb.zip
add spectral handler
-rw-r--r--ale_linters/yaml/spectral.vim30
-rw-r--r--autoload/ale/handlers/spectral.vim31
-rw-r--r--test/handler/test_spectral_handler.vader2
3 files changed, 33 insertions, 30 deletions
diff --git a/ale_linters/yaml/spectral.vim b/ale_linters/yaml/spectral.vim
index c1644f3e..bd4623a5 100644
--- a/ale_linters/yaml/spectral.vim
+++ b/ale_linters/yaml/spectral.vim
@@ -4,39 +4,11 @@
call ale#Set('yaml_spectral_executable', 'spectral')
call ale#Set('yaml_spectral_use_global', get(g:, 'ale_use_global_executables', 0))
-function! ale_linters#yaml#spectral#Handle(buffer, lines) abort
- " Matches patterns like the following:
- " openapi.yml:1:1 error oas3-schema "Object should have required property `info`."
- " openapi.yml:1:1 warning oas3-api-servers "OpenAPI `servers` must be present and non-empty array."
- let l:pattern = '\v^.*:(\d+):(\d+) (error|warning) (.*)$'
- let l:output = []
-
- for l:match in ale#util#GetMatches(a:lines, l:pattern)
- let l:obj = {
- \ 'lnum': l:match[1] + 0,
- \ 'col': l:match[2] + 0,
- \ 'type': l:match[3] is# 'error' ? 'E' : 'W',
- \ 'text': l:match[4],
- \}
-
- let l:code_match = matchlist(l:obj.text, '\v^(.+) "(.+)"$')
-
- if !empty(l:code_match)
- let l:obj.code = l:code_match[1]
- let l:obj.text = l:code_match[2]
- endif
-
- call add(l:output, l:obj)
- endfor
-
- return l:output
-endfunction
-
call ale#linter#Define('yaml', {
\ 'name': 'spectral',
\ 'executable': {b -> ale#node#FindExecutable(b, 'yaml_spectral', [
\ 'node_modules/.bin/spectral',
\ ])},
\ 'command': '%e lint --ignore-unknown-format -q -f text %t',
-\ 'callback': 'ale_linters#yaml#spectral#Handle'
+\ 'callback': 'ale#handlers#spectral#HandleSpectralOutput'
\})
diff --git a/autoload/ale/handlers/spectral.vim b/autoload/ale/handlers/spectral.vim
new file mode 100644
index 00000000..1eb4a5de
--- /dev/null
+++ b/autoload/ale/handlers/spectral.vim
@@ -0,0 +1,31 @@
+" Author: t2h5 <https://github.com/t2h5>
+" Description: Integration of Stoplight Spectral CLI with ALE.
+
+function! ale#handlers#spectral#HandleSpectralOutput(buffer, lines) abort
+ " Matches patterns like the following:
+ " openapi.yml:1:1 error oas3-schema "Object should have required property `info`."
+ " openapi.yml:1:1 warning oas3-api-servers "OpenAPI `servers` must be present and non-empty array."
+ let l:pattern = '\v^.*:(\d+):(\d+) (error|warning) (.*)$'
+ let l:output = []
+
+ for l:match in ale#util#GetMatches(a:lines, l:pattern)
+ let l:obj = {
+ \ 'lnum': l:match[1] + 0,
+ \ 'col': l:match[2] + 0,
+ \ 'type': l:match[3] is# 'error' ? 'E' : 'W',
+ \ 'text': l:match[4],
+ \}
+
+ let l:code_match = matchlist(l:obj.text, '\v^(.+) "(.+)"$')
+
+ if !empty(l:code_match)
+ let l:obj.code = l:code_match[1]
+ let l:obj.text = l:code_match[2]
+ endif
+
+ call add(l:output, l:obj)
+ endfor
+
+ return l:output
+endfunction
+
diff --git a/test/handler/test_spectral_handler.vader b/test/handler/test_spectral_handler.vader
index b315168f..89a3ff1b 100644
--- a/test/handler/test_spectral_handler.vader
+++ b/test/handler/test_spectral_handler.vader
@@ -43,7 +43,7 @@ Execute(spectral handler should parse lines correctly):
\ 'type': 'E'
\ },
\ ],
- \ ale_linters#yaml#spectral#Handle(bufnr(''), [
+ \ ale#handlers#spectral#HandleSpectralOutput(bufnr(''), [
\ 'openapi.yml:1:1 warning oas3-api-servers "OpenAPI `servers` must be present and non-empty array."',
\ 'openapi.yml:1:1 error oas3-schema "Object should have required property `paths`."',
\ 'openapi.yml:1:1 warning openapi-tags "OpenAPI object should have non-empty `tags` array."',