2018-03-31 10:55:20 -04:00
|
|
|
" Author: Matthew Turland <https://github.com/elazar>
|
|
|
|
" Description: This file adds support for linting Swagger / OpenAPI documents using swaglint
|
|
|
|
|
|
|
|
call ale#Set('yaml_swaglint_executable', 'swaglint')
|
2018-06-14 06:31:12 -04:00
|
|
|
call ale#Set('yaml_swaglint_use_global', get(g:, 'ale_use_global_executables', 0))
|
2018-03-31 10:55:20 -04:00
|
|
|
|
|
|
|
function! ale_linters#yaml#swaglint#GetExecutable(buffer) abort
|
|
|
|
return ale#node#FindExecutable(a:buffer, 'yaml_swaglint', [
|
|
|
|
\ 'node_modules/.bin/swaglint',
|
|
|
|
\])
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
function! ale_linters#yaml#swaglint#GetCommand(buffer) abort
|
|
|
|
return ale_linters#yaml#swaglint#GetExecutable(a:buffer)
|
|
|
|
\ . ' -r compact --stdin'
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
function! ale_linters#yaml#swaglint#Handle(buffer, lines) abort
|
|
|
|
let l:pattern = ': \([^\s]\+\) @ \(\d\+\):\(\d\+\) - \(.\+\)$'
|
|
|
|
let l:output = []
|
|
|
|
|
|
|
|
for l:match in ale#util#GetMatches(a:lines, l:pattern)
|
|
|
|
let l:obj = {
|
|
|
|
\ 'type': l:match[1] is# 'error' ? 'E' : 'W',
|
|
|
|
\ 'lnum': l:match[2] + 0,
|
|
|
|
\ 'col': l:match[3] + 0,
|
|
|
|
\ 'text': l:match[4],
|
|
|
|
\}
|
|
|
|
|
|
|
|
" Parse the code if it's there.
|
|
|
|
let l:code_match = matchlist(l:obj.text, '\v^(.+) \(([^ (]+)\)$')
|
|
|
|
|
|
|
|
if !empty(l:code_match)
|
|
|
|
let l:obj.text = l:code_match[1]
|
|
|
|
let l:obj.code = l:code_match[2]
|
|
|
|
endif
|
|
|
|
|
|
|
|
call add(l:output, l:obj)
|
|
|
|
endfor
|
|
|
|
|
|
|
|
return l:output
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
call ale#linter#Define('yaml', {
|
|
|
|
\ 'name': 'swaglint',
|
|
|
|
\ 'executable_callback': 'ale_linters#yaml#swaglint#GetExecutable',
|
|
|
|
\ 'command_callback': 'ale_linters#yaml#swaglint#GetCommand',
|
|
|
|
\ 'callback': 'ale_linters#yaml#swaglint#Handle',
|
|
|
|
\})
|