split up php checker into php, phpmd and phpcs

This commit is contained in:
Martin Grenfell 2013-01-31 17:31:40 +00:00
parent 05feca29d7
commit 653611ccac
4 changed files with 65 additions and 64 deletions

View File

@ -6,8 +6,9 @@ let g:loaded_syntastic_registry=1
let s:defaultCheckers = { let s:defaultCheckers = {
\ 'c': ['gcc'], \ 'c': ['gcc'],
\ 'cpp': ['gcc'], \ 'cpp': ['gcc'],
\ 'objc': ['gcc'],
\ 'java': ['javac'], \ 'java': ['javac'],
\ 'objc': ['gcc'],
\ 'php': ['php', 'phpcs', 'phpmd'],
\ 'ruby': ['mri'] \ 'ruby': ['mri']
\ } \ }

View File

@ -10,41 +10,10 @@
" "
"============================================================================ "============================================================================
" "
"This syntax checker is composed of three checkers:
" - php -l
" - phpcs (see http://pear.php.net/package/PHP_CodeSniffer)
" - phpmd (see http://phpmd.org)
"
"If any of these checkers are installed then they will be used. Phpcs and
"Phpmd are 'style checkers' and will only be called if `php -l` doesnt find
"any syntax errors.
"
"There are options below to config and disable phpcs and phpmd.
function! SyntaxCheckers_php_php_IsAvailable() function! SyntaxCheckers_php_php_IsAvailable()
return executable("php") return executable("php")
endfunction endfunction
"Support passing configuration directives to phpcs
if !exists("g:syntastic_phpcs_conf")
let g:syntastic_phpcs_conf = ""
endif
if !exists("g:syntastic_phpcs_disable") || !executable('phpcs')
let g:syntastic_phpcs_disable = 0
endif
if !exists("g:syntastic_phpmd_disable") || !executable('phpmd')
let g:syntastic_phpmd_disable = 0
endif
"Support passing selected rules to phpmd
if !exists("g:syntastic_phpmd_rules")
let g:syntastic_phpmd_rules = "codesize,design,unusedcode,naming"
endif
function! SyntaxCheckers_php_GetHighlightRegex(item) function! SyntaxCheckers_php_GetHighlightRegex(item)
let unexpected = matchstr(a:item['text'], "unexpected '[^']\\+'") let unexpected = matchstr(a:item['text'], "unexpected '[^']\\+'")
if len(unexpected) < 1 if len(unexpected) < 1
@ -59,38 +28,7 @@ function! SyntaxCheckers_php_php_GetLocList()
\ 'args': '-l -d error_reporting=E_ALL -d display_errors=1 -d log_errors=0', \ 'args': '-l -d error_reporting=E_ALL -d display_errors=1 -d log_errors=0',
\ 'subchecker': 'php' }) \ 'subchecker': 'php' })
let errorformat='%-GNo syntax errors detected in%.%#,Parse error: %#syntax %trror\ , %m in %f on line %l,Parse %trror: %m in %f on line %l,Fatal %trror: %m in %f on line %l,%-G\s%#,%-GErrors parsing %.%#' let errorformat='%-GNo syntax errors detected in%.%#,Parse error: %#syntax %trror\ , %m in %f on line %l,Parse %trror: %m in %f on line %l,Fatal %trror: %m in %f on line %l,%-G\s%#,%-GErrors parsing %.%#'
let errors = SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat }) return SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat })
if empty(errors)
if !g:syntastic_phpcs_disable
let errors = errors + s:GetPHPCSErrors()
endif
if !g:syntastic_phpmd_disable
let errors = errors + s:GetPHPMDErrors()
endif
end
return errors
endfunction
function! s:GetPHPCSErrors()
let makeprg = syntastic#makeprg#build({
\ 'exe': 'phpcs',
\ 'args': g:syntastic_phpcs_conf . " --report=csv",
\ 'subchecker': 'phpcs' })
let errorformat = '%-GFile\,Line\,Column\,Type\,Message\,Source\,Severity,"%f"\,%l\,%c\,%t%*[a-zA-Z]\,"%m"\,%*[a-zA-Z0-9_.-]\,%*[0-9]'
return SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat, 'subtype': 'Style' })
endfunction
"Helper function. This one runs and parses phpmd tool output.
function! s:GetPHPMDErrors()
let makeprg = syntastic#makeprg#build({
\ 'exe': 'phpmd',
\ 'post_args': 'text ' . g:syntastic_phpmd_rules,
\ 'subchecker': 'phpmd' })
let errorformat = '%E%f:%l%m'
return SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat, 'subtype' : 'Style' })
endfunction endfunction
call g:SyntasticRegistry.CreateAndRegisterChecker({ call g:SyntasticRegistry.CreateAndRegisterChecker({

View File

@ -0,0 +1,31 @@
"============================================================================
"File: phpcs.vim
"Description: Syntax checking plugin for syntastic.vim
"Maintainer: Martin Grenfell <martin.grenfell at gmail dot com>
"License: This program is free software. It comes without any warranty,
" to the extent permitted by applicable law. You can redistribute
" it and/or modify it under the terms of the Do What The Fuck You
" Want To Public License, Version 2, as published by Sam Hocevar.
" See http://sam.zoy.org/wtfpl/COPYING for more details.
"
"============================================================================
"
" See here for details of phpcs
" - phpcs (see http://pear.php.net/package/PHP_CodeSniffer)
"
function! SyntaxCheckers_php_phpcs_IsAvailable()
return executable('phpcs')
endfunction
function! SyntaxCheckers_php_phpcs_GetLocList()
let makeprg = syntastic#makeprg#build({
\ 'exe': 'phpcs',
\ 'args': '--report=csv',
\ 'subchecker': 'phpcs' })
let errorformat = '%-GFile\,Line\,Column\,Type\,Message\,Source\,Severity,"%f"\,%l\,%c\,%t%*[a-zA-Z]\,"%m"\,%*[a-zA-Z0-9_.-]\,%*[0-9]'
return SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat, 'subtype': 'Style' })
endfunction
call g:SyntasticRegistry.CreateAndRegisterChecker({
\ 'filetype': 'php',
\ 'name': 'phpcs'})

View File

@ -0,0 +1,31 @@
"============================================================================
"File: phpmd.vim
"Description: Syntax checking plugin for syntastic.vim
"Maintainer: Martin Grenfell <martin.grenfell at gmail dot com>
"License: This program is free software. It comes without any warranty,
" to the extent permitted by applicable law. You can redistribute
" it and/or modify it under the terms of the Do What The Fuck You
" Want To Public License, Version 2, as published by Sam Hocevar.
" See http://sam.zoy.org/wtfpl/COPYING for more details.
"
"============================================================================
"
" See here for details of phpmd
" - phpmd (see http://phpmd.org)
function! SyntaxCheckers_php_phpmd_IsAvailable()
return executable('phpmd')
endfunction
function! SyntaxCheckers_php_phpmd_GetLocList()
let makeprg = syntastic#makeprg#build({
\ 'exe': 'phpmd',
\ 'post_args': 'text codesize,design,unusedcode,naming',
\ 'subchecker': 'phpmd' })
let errorformat = '%E%f:%l%m'
return SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat, 'subtype' : 'Style' })
endfunction
call g:SyntasticRegistry.CreateAndRegisterChecker({
\ 'filetype': 'php',
\ 'name': 'phpmd'})