From 2b7ce6c09707fcb6317b7ff83269a47effc5f509 Mon Sep 17 00:00:00 2001 From: millermedeiros Date: Mon, 5 Sep 2011 12:41:11 -0300 Subject: [PATCH 1/2] improve support for HTML5 attributes and refactor html.vim logic to allow adding new grep rules easily. see #53 --- syntax_checkers/html.vim | 20 +++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/syntax_checkers/html.vim b/syntax_checkers/html.vim index ba32ef43..d9253929 100644 --- a/syntax_checkers/html.vim +++ b/syntax_checkers/html.vim @@ -39,10 +39,24 @@ endfunction function! SyntaxCheckers_html_GetLocList() - "grep out the ' lacks "summary" attribute' since it is almost - "always present and almost always useless let encopt = s:TidyEncOptByFenc() - let makeprg="tidy ".encopt." --new-blocklevel-tags 'section, article, aside, hgroup, header, footer, nav, figure, figcaption' --new-inline-tags 'video, audio, embed, mark, progress, meter, time, ruby, rt, rp, canvas, command, details, datalist' --new-empty-tags 'wbr, keygen' -e ".shellescape(expand('%'))." 2>&1 \\| grep -v '\ lacks \"summary\" attribute' \\| grep -v 'not approved by W3C' \\| grep -v 'attribute \"placeholder\"'" + "grep out not helpful errors and avoid reporting errors for new HTML5 + "attibutes (like 'data-' attibutes) and optional attributes like 'type' on + "script and link tags. + let ignore_html_errors = [ + \ " lacks \"summary\" attribute", + \ "not approved by W3C", + \ "attribute \"placeholder\"", + \ " proprietary attribute \"charset\"", + \ " lacks \"content\" attribute", + \ " inserting \"type\" attribute", + \ " inserting \"type\" attribute", + \ "proprietary attribute \"data-" + \] + let makeprg = "tidy ". encopt ." --new-blocklevel-tags 'section, article, aside, hgroup, header, footer, nav, figure, figcaption' --new-inline-tags 'video, audio, embed, mark, progress, meter, time, ruby, rt, rp, canvas, command, details, datalist' --new-empty-tags 'wbr, keygen' -e ". shellescape(expand('%')) ." 2>&1" + for item in ignore_html_errors + let makeprg = makeprg ." \\| grep -v '". item ."'" + endfor let errorformat='%Wline %l column %c - Warning: %m,%Eline %l column %c - Error: %m,%-G%.%#,%-G%.%#' let loclist = SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat }) From d2250151f07d55c81a45d489b935906b300e0976 Mon Sep 17 00:00:00 2001 From: millermedeiros Date: Fri, 2 Dec 2011 00:34:01 -0200 Subject: [PATCH 2/2] filter HTML5 warnings without using grep. see #53. see #81. --- syntax_checkers/html.vim | 59 ++++++++++++++++++++++++++-------------- 1 file changed, 38 insertions(+), 21 deletions(-) diff --git a/syntax_checkers/html.vim b/syntax_checkers/html.vim index d9253929..a5dbfedf 100644 --- a/syntax_checkers/html.vim +++ b/syntax_checkers/html.vim @@ -37,33 +37,50 @@ function! s:TidyEncOptByFenc() return get(tidy_opts, &fileencoding, '-utf8') endfunction +let s:ignore_html_errors = [ + \ "
lacks \"summary\" attribute", + \ "not approved by W3C", + \ "attribute \"placeholder\"", + \ " proprietary attribute \"charset\"", + \ " lacks \"content\" attribute", + \ "inserting \"type\" attribute", + \ "proprietary attribute \"data-" + \] + +function! s:ValidateError(text) + let valid = 0 + for i in s:ignore_html_errors + if stridx(a:text, i) != -1 + let valid = 1 + break + endif + endfor + return valid +endfunction + + function! SyntaxCheckers_html_GetLocList() let encopt = s:TidyEncOptByFenc() - "grep out not helpful errors and avoid reporting errors for new HTML5 - "attibutes (like 'data-' attibutes) and optional attributes like 'type' on - "script and link tags. - let ignore_html_errors = [ - \ " lacks \"summary\" attribute", - \ "not approved by W3C", - \ "attribute \"placeholder\"", - \ " proprietary attribute \"charset\"", - \ " lacks \"content\" attribute", - \ " inserting \"type\" attribute", - \ " inserting \"type\" attribute", - \ "proprietary attribute \"data-" - \] - let makeprg = "tidy ". encopt ." --new-blocklevel-tags 'section, article, aside, hgroup, header, footer, nav, figure, figcaption' --new-inline-tags 'video, audio, embed, mark, progress, meter, time, ruby, rt, rp, canvas, command, details, datalist' --new-empty-tags 'wbr, keygen' -e ". shellescape(expand('%')) ." 2>&1" - for item in ignore_html_errors - let makeprg = makeprg ." \\| grep -v '". item ."'" - endfor + let makeprg="tidy ".encopt." --new-blocklevel-tags 'section, article, aside, hgroup, header, footer, nav, figure, figcaption' --new-inline-tags 'video, audio, embed, mark, progress, meter, time, ruby, rt, rp, canvas, command, details, datalist' --new-empty-tags 'wbr, keygen' -e ".shellescape(expand('%'))." 2>&1" let errorformat='%Wline %l column %c - Warning: %m,%Eline %l column %c - Error: %m,%-G%.%#,%-G%.%#' let loclist = SyntasticMake({ 'makeprg': makeprg, 'errorformat': errorformat }) - "the file name isnt in the output so stick in the buf num manually - for i in loclist - let i['bufnr'] = bufnr("") - endfor + " process loclist since we need to add some info and filter out valid HTML5 + " from the errors + let n = len(loclist) - 1 + let bufnum = bufnr("") + while n >= 0 + let i = loclist[n] + " filter out valid HTML5 + if s:ValidateError(i['text']) == 1 + unlet loclist[n] + else + "the file name isnt in the output so stick in the buf num manually + let i['bufnr'] = bufnum + endif + let n -= 1 + endwhile return loclist endfunction