Merge branch 'linter-sasslint'
This commit is contained in:
commit
c102fbe70a
@ -35,6 +35,7 @@ name. That seems to be the fairest way to arrange this table.
|
|||||||
| JavaScript | [eslint](http://eslint.org/), [jscs](http://jscs.info/), [jshint](http://jshint.com/) |
|
| JavaScript | [eslint](http://eslint.org/), [jscs](http://jscs.info/), [jshint](http://jshint.com/) |
|
||||||
| Python | [flake8](http://flake8.pycqa.org/en/latest/) |
|
| Python | [flake8](http://flake8.pycqa.org/en/latest/) |
|
||||||
| Ruby | [rubocop](https://github.com/bbatsov/rubocop) |
|
| Ruby | [rubocop](https://github.com/bbatsov/rubocop) |
|
||||||
|
| SASS/SCSS | [sass-lint](https://www.npmjs.com/package/sass-lint) |
|
||||||
| TypeScript | [tslint](https://github.com/palantir/tslint)^ |
|
| TypeScript | [tslint](https://github.com/palantir/tslint)^ |
|
||||||
| Vim | [vint](https://github.com/Kuniwak/vint)^ |
|
| Vim | [vint](https://github.com/Kuniwak/vint)^ |
|
||||||
|
|
||||||
|
@ -7,56 +7,9 @@ endif
|
|||||||
|
|
||||||
let g:loaded_ale_linters_css_csslint = 1
|
let g:loaded_ale_linters_css_csslint = 1
|
||||||
|
|
||||||
function! ale_linters#css#csslint#Handle(buffer, lines)
|
|
||||||
" Matches patterns line the following:
|
|
||||||
"
|
|
||||||
" something.css: line 2, col 1, Error - Expected RBRACE at line 2, col 1. (errors)
|
|
||||||
" something.css: line 2, col 5, Warning - Expected (inline | block | list-item | inline-block | table | inline-table | table-row-group | table-header-group | table-footer-group | table-row | table-column-group | table-column | table-cell | table-caption | grid | inline-grid | run-in | ruby | ruby-base | ruby-text | ruby-base-container | ruby-text-container | contents | none | -moz-box | -moz-inline-block | -moz-inline-box | -moz-inline-grid | -moz-inline-stack | -moz-inline-table | -moz-grid | -moz-grid-group | -moz-grid-line | -moz-groupbox | -moz-deck | -moz-popup | -moz-stack | -moz-marker | -webkit-box | -webkit-inline-box | -ms-flexbox | -ms-inline-flexbox | flex | -webkit-flex | inline-flex | -webkit-inline-flex) but found 'wat'. (known-properties)
|
|
||||||
"
|
|
||||||
" These errors can be very massive, so the type will be moved to the front
|
|
||||||
" so you can actually read the error type.
|
|
||||||
let pattern = '^.*: line \(\d\+\), col \(\d\+\), \(Error\|Warning\) - \(.\+\) (\([^)]\+\))$'
|
|
||||||
let output = []
|
|
||||||
" Some errors have line numbers beyond the end of the file,
|
|
||||||
" so we need to adjust them so they set the error at the last line
|
|
||||||
" of the file instead.
|
|
||||||
"
|
|
||||||
" TODO: Find a faster way to compute this.
|
|
||||||
let last_line_number = len(getbufline(a:buffer, 1, '$'))
|
|
||||||
|
|
||||||
for line in a:lines
|
|
||||||
let l:match = matchlist(line, pattern)
|
|
||||||
|
|
||||||
if len(l:match) == 0
|
|
||||||
continue
|
|
||||||
endif
|
|
||||||
|
|
||||||
let text = l:match[4]
|
|
||||||
let type = l:match[3]
|
|
||||||
let errorGroup = l:match[5]
|
|
||||||
|
|
||||||
" Put the error group at the front, so we can see what kind of error
|
|
||||||
" it is on small echo lines.
|
|
||||||
let text = '(' . errorGroup . ') ' . text
|
|
||||||
|
|
||||||
" vcol is Needed to indicate that the column is a character.
|
|
||||||
call add(output, {
|
|
||||||
\ 'bufnr': a:buffer,
|
|
||||||
\ 'lnum': min([l:match[1] + 0, last_line_number]),
|
|
||||||
\ 'vcol': 0,
|
|
||||||
\ 'col': l:match[2] + 0,
|
|
||||||
\ 'text': text,
|
|
||||||
\ 'type': type ==# 'Warning' ? 'W' : 'E',
|
|
||||||
\ 'nr': -1,
|
|
||||||
\})
|
|
||||||
endfor
|
|
||||||
|
|
||||||
return output
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call ALEAddLinter('css', {
|
call ALEAddLinter('css', {
|
||||||
\ 'name': 'csslint',
|
\ 'name': 'csslint',
|
||||||
\ 'executable': 'csslint',
|
\ 'executable': 'csslint',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .css csslint --format=compact',
|
\ 'command': g:ale#util#stdin_wrapper . ' .css csslint --format=compact',
|
||||||
\ 'callback': 'ale_linters#css#csslint#Handle',
|
\ 'callback': 'ale#handlers#HandleCSSLintFormat',
|
||||||
\})
|
\})
|
||||||
|
14
ale_linters/sass/sasslint.vim
Normal file
14
ale_linters/sass/sasslint.vim
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
" Author: KabbAmine - https://github.com/KabbAmine
|
||||||
|
|
||||||
|
if exists('g:loaded_ale_linters_sass_sasslint')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
|
||||||
|
let g:loaded_ale_linters_sass_sasslint = 1
|
||||||
|
|
||||||
|
call ALEAddLinter('sass', {
|
||||||
|
\ 'name': 'sassLint',
|
||||||
|
\ 'executable': 'sass-lint',
|
||||||
|
\ 'command': g:ale#util#stdin_wrapper . ' .sass sass-lint -v -q -f compact',
|
||||||
|
\ 'callback': 'ale#handlers#HandleCSSLintFormat',
|
||||||
|
\})
|
14
ale_linters/scss/sasslint.vim
Normal file
14
ale_linters/scss/sasslint.vim
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
" Author: KabbAmine - https://github.com/KabbAmine
|
||||||
|
|
||||||
|
if exists('g:loaded_ale_linters_scss_sasslint')
|
||||||
|
finish
|
||||||
|
endif
|
||||||
|
|
||||||
|
let g:loaded_ale_linters_scss_sasslint = 1
|
||||||
|
|
||||||
|
call ALEAddLinter('scss', {
|
||||||
|
\ 'name': 'sassLint',
|
||||||
|
\ 'executable': 'sass-lint',
|
||||||
|
\ 'command': g:ale#util#stdin_wrapper . ' .scss sass-lint -v -q -f compact',
|
||||||
|
\ 'callback': 'ale#handlers#HandleCSSLintFormat',
|
||||||
|
\})
|
@ -38,3 +38,50 @@ function! ale#handlers#HandleGCCFormat(buffer, lines)
|
|||||||
|
|
||||||
return output
|
return output
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
function! ale#handlers#HandleCSSLintFormat(buffer, lines)
|
||||||
|
" Matches patterns line the following:
|
||||||
|
"
|
||||||
|
" something.css: line 2, col 1, Error - Expected RBRACE at line 2, col 1. (errors)
|
||||||
|
" something.css: line 2, col 5, Warning - Expected (inline | block | list-item | inline-block | table | inline-table | table-row-group | table-header-group | table-footer-group | table-row | table-column-group | table-column | table-cell | table-caption | grid | inline-grid | run-in | ruby | ruby-base | ruby-text | ruby-base-container | ruby-text-container | contents | none | -moz-box | -moz-inline-block | -moz-inline-box | -moz-inline-grid | -moz-inline-stack | -moz-inline-table | -moz-grid | -moz-grid-group | -moz-grid-line | -moz-groupbox | -moz-deck | -moz-popup | -moz-stack | -moz-marker | -webkit-box | -webkit-inline-box | -ms-flexbox | -ms-inline-flexbox | flex | -webkit-flex | inline-flex | -webkit-inline-flex) but found 'wat'. (known-properties)
|
||||||
|
"
|
||||||
|
" These errors can be very massive, so the type will be moved to the front
|
||||||
|
" so you can actually read the error type.
|
||||||
|
let pattern = '^.*: line \(\d\+\), col \(\d\+\), \(Error\|Warning\) - \(.\+\) (\([^)]\+\))$'
|
||||||
|
let output = []
|
||||||
|
" Some errors have line numbers beyond the end of the file,
|
||||||
|
" so we need to adjust them so they set the error at the last line
|
||||||
|
" of the file instead.
|
||||||
|
"
|
||||||
|
" TODO: Find a faster way to compute this.
|
||||||
|
let last_line_number = len(getbufline(a:buffer, 1, '$'))
|
||||||
|
|
||||||
|
for line in a:lines
|
||||||
|
let l:match = matchlist(line, pattern)
|
||||||
|
|
||||||
|
if len(l:match) == 0
|
||||||
|
continue
|
||||||
|
endif
|
||||||
|
|
||||||
|
let text = l:match[4]
|
||||||
|
let type = l:match[3]
|
||||||
|
let errorGroup = l:match[5]
|
||||||
|
|
||||||
|
" Put the error group at the front, so we can see what kind of error
|
||||||
|
" it is on small echo lines.
|
||||||
|
let text = '(' . errorGroup . ') ' . text
|
||||||
|
|
||||||
|
" vcol is Needed to indicate that the column is a character.
|
||||||
|
call add(output, {
|
||||||
|
\ 'bufnr': a:buffer,
|
||||||
|
\ 'lnum': min([l:match[1] + 0, last_line_number]),
|
||||||
|
\ 'vcol': 0,
|
||||||
|
\ 'col': l:match[2] + 0,
|
||||||
|
\ 'text': text,
|
||||||
|
\ 'type': type ==# 'Warning' ? 'W' : 'E',
|
||||||
|
\ 'nr': -1,
|
||||||
|
\})
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return output
|
||||||
|
endfunction
|
||||||
|
Loading…
Reference in New Issue
Block a user