3694908d05
(1) Checkers now have an _exec attribute, and an accessor getExec(). (2) CreateAndRegisterChecker() initializes _exec from an optional argument 'exec'. If this argument is missing, 'name' is used instead. (3) Functions SyntaxCheckers_*_IsAvailable() are now dictionary functions. (4) Functions SyntaxCheckers_*_IsAvailable() are now optional. When they are missing, they are assumed to return executable(expand(self.getExec())). (5) Argument 'exe' of function syntastic#makeprg#build() is now optional. If this argument is missing, expand(self.getExec()) is used to set checker executables.
66 lines
2.3 KiB
VimL
66 lines
2.3 KiB
VimL
"============================================================================
|
|
"File: w3.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.
|
|
"
|
|
"============================================================================
|
|
"
|
|
" Checker option:
|
|
"
|
|
" - g:syntastic_html_w3_api (string; default: 'http://validator.w3.org/check')
|
|
" URL of the service to use for checking; leave it to the default to run the
|
|
" checks against http://validator.w3.org/, or set it to
|
|
" 'http://localhost/w3c-validator/check' if you're running a local service
|
|
|
|
if exists("g:loaded_syntastic_html_w3_checker")
|
|
finish
|
|
endif
|
|
let g:loaded_syntastic_html_w3_checker = 1
|
|
|
|
if !exists('g:syntastic_html_w3_api')
|
|
let g:syntastic_html_w3_api = 'http://validator.w3.org/check'
|
|
endif
|
|
|
|
function! SyntaxCheckers_html_w3_IsAvailable() dict
|
|
return executable('curl')
|
|
endfunction
|
|
|
|
function! SyntaxCheckers_html_w3_GetLocList() dict
|
|
let makeprg = 'curl -s -F output=json ' .
|
|
\ '-F uploaded_file=@' . syntastic#util#shexpand('%:p') . '\;type=text/html ' .
|
|
\ g:syntastic_html_w3_api
|
|
|
|
let errorformat =
|
|
\ '%A %\+{,' .
|
|
\ '%C %\+"lastLine": %l\,%\?,' .
|
|
\ '%C %\+"lastColumn": %c\,%\?,' .
|
|
\ '%C %\+"message": "%m"\,%\?,' .
|
|
\ '%C %\+"type": "%trror"\,%\?,' .
|
|
\ '%-G %\+"type": "%tnfo"\,%\?,' .
|
|
\ '%C %\+"subtype": "%tarning"\,%\?,' .
|
|
\ '%Z %\+}\,,' .
|
|
\ '%-G%.%#'
|
|
|
|
let loclist = SyntasticMake({
|
|
\ 'makeprg': makeprg,
|
|
\ 'errorformat': errorformat,
|
|
\ 'defaults': {'bufnr': bufnr("")},
|
|
\ 'returns': [0] })
|
|
|
|
for n in range(len(loclist))
|
|
let loclist[n]['text'] = substitute(loclist[n]['text'], '\m\\\([\"]\)', '\1', 'g')
|
|
endfor
|
|
|
|
return loclist
|
|
endfunction
|
|
|
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
\ 'filetype': 'html',
|
|
\ 'name': 'w3'})
|
|
|