Added puppet-lint support with the use of subtypes
This commit is contained in:
parent
9f1cdfd92c
commit
ca6a4b23c3
@ -19,21 +19,46 @@ if !executable("puppet")
|
|||||||
finish
|
finish
|
||||||
endif
|
endif
|
||||||
|
|
||||||
function! s:ExtractVersion()
|
if !exists("g:syntastic_puppet_lint_disable")
|
||||||
|
let g:syntastic_puppet_lint_disable = 0
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !executable("puppet-lint")
|
||||||
|
let g:syntastic_puppet_lint_disable = 0
|
||||||
|
endif
|
||||||
|
|
||||||
|
function! s:PuppetExtractVersion()
|
||||||
let output = system("puppet --version")
|
let output = system("puppet --version")
|
||||||
let output = substitute(output, '\n$', '', '')
|
let output = substitute(output, '\n$', '', '')
|
||||||
return split(output, '\.')
|
return split(output, '\.')
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
let s:puppetVersion = s:ExtractVersion()
|
function! s:PuppetLintExtractVersion()
|
||||||
|
let output = system("puppet-lint --version")
|
||||||
|
let output = substitute(output, '\n$', '', '')
|
||||||
|
let output = substitute(output, '^puppet-lint ', '', 'i')
|
||||||
|
return split(output, '\.')
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
let s:puppetVersion = s:PuppetExtractVersion()
|
||||||
|
let s:lintVersion = s:PuppetLintExtractVersion()
|
||||||
|
|
||||||
|
if !(s:lintVersion[0] >= '0' && s:lintVersion[1] >= '1' && s:lintVersion[2] >= '10')
|
||||||
|
let g:syntastic_puppet_lint_disable = 0
|
||||||
|
endif
|
||||||
|
|
||||||
|
function! s:getPuppetLintErrors()
|
||||||
|
let makeprg = 'puppet-lint --log-format "\%{KIND} [\%{check}] \%{message} at \%{fullpath}:\%{linenumber}" '.shellescape(expand('%'))
|
||||||
|
let errorformat = '%t%*[a-zA-Z] %m at %f:%l'
|
||||||
|
return SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat, 'subtype': 'Style' })
|
||||||
|
endfunction
|
||||||
|
|
||||||
function! SyntaxCheckers_puppet_GetLocList()
|
function! SyntaxCheckers_puppet_GetLocList()
|
||||||
"If puppet is >= version 2.7 then use the new executable
|
"If puppet is >= version 2.7 then use the new executable
|
||||||
if s:puppetVersion[0] >= '2' && s:puppetVersion[1] >= '7'
|
if s:puppetVersion[0] >= '2' && s:puppetVersion[1] >= '7'
|
||||||
let makeprg = 'puppet parser validate ' .
|
let makeprg = 'puppet parser validate ' .
|
||||||
\ shellescape(expand('%')) .
|
\ shellescape(expand('%')) .
|
||||||
\ ' --color=false' .
|
\ ' --color=false'
|
||||||
\ ' --storeconfigs'
|
|
||||||
|
|
||||||
"add --ignoreimport for versions < 2.7.10
|
"add --ignoreimport for versions < 2.7.10
|
||||||
if s:puppetVersion[2] < '10'
|
if s:puppetVersion[2] < '10'
|
||||||
@ -50,5 +75,11 @@ function! SyntaxCheckers_puppet_GetLocList()
|
|||||||
|
|
||||||
let errorformat .= 'err: Could not parse for environment %*[a-z]: %m at %f:%l'
|
let errorformat .= 'err: Could not parse for environment %*[a-z]: %m at %f:%l'
|
||||||
|
|
||||||
return SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat })
|
let errors = SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat })
|
||||||
|
|
||||||
|
if !g:syntastic_puppet_lint_disable
|
||||||
|
let errors = errors + s:getPuppetLintErrors()
|
||||||
|
endif
|
||||||
|
return errors
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user