All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@git.madduck.net.
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
2 " Description: dockerlinter linter for dockerfile
4 call ale#Set('dockerfile_dockerlinter_executable', 'dockerlinter')
5 call ale#Set('dockerfile_dockerlinter_options', '')
7 function! ale_linters#dockerfile#dockerlinter#GetType(type) abort
10 elseif a:type is? 'warning'
17 function! ale_linters#dockerfile#dockerlinter#Handle(buffer, lines) abort
19 let l:data = json_decode(join(a:lines, ''))
25 " Should never happen, but it's better to be on the safe side
31 for l:object in l:data
32 let l:line = get(l:object, 'lineNumber', -1)
33 let l:message = l:object['message']
34 let l:type = l:object['level']
35 let l:detail = l:message
36 let l:code = l:object['code']
39 let l:link = 'https://www.shellcheck.net/wiki/' . l:code
41 let l:link = 'https://github.com/buddy-works/dockerfile-linter/blob/master/Rules.md#' . l:code
44 let l:detail = l:message . "\n\n" . l:link
46 call add(l:messages, {
50 \ 'type': ale_linters#dockerfile#dockerlinter#GetType(l:type),
58 function! ale_linters#dockerfile#dockerlinter#GetCommand(buffer) abort
59 return '%e' . ale#Pad(ale#Var(a:buffer, 'dockerfile_dockerlinter_options'))
64 call ale#linter#Define('dockerfile', {
65 \ 'name': 'dockerlinter',
66 \ 'executable': {b -> ale#Var(b, 'dockerfile_dockerlinter_executable')},
67 \ 'command': function('ale_linters#dockerfile#dockerlinter#GetCommand'),
68 \ 'callback': 'ale_linters#dockerfile#dockerlinter#Handle',