Fix #308 - Check Dart files with dartanalyzer
This commit is contained in:
parent
aa94d0902a
commit
235fc90e22
@ -71,6 +71,7 @@ name. That seems to be the fairest way to arrange this table.
|
|||||||
| CSS | [csslint](http://csslint.net/), [stylelint](https://github.com/stylelint/stylelint) |
|
| CSS | [csslint](http://csslint.net/), [stylelint](https://github.com/stylelint/stylelint) |
|
||||||
| Cython (pyrex filetype) | [cython](http://cython.org/) |
|
| Cython (pyrex filetype) | [cython](http://cython.org/) |
|
||||||
| D | [dmd](https://dlang.org/dmd-linux.html) |
|
| D | [dmd](https://dlang.org/dmd-linux.html) |
|
||||||
|
| Dart | [dartanalyzer](https://github.com/dart-lang/sdk/tree/master/pkg/analyzer_cli) |
|
||||||
| Dockerfile | [hadolint](https://github.com/lukasmartinelli/hadolint) |
|
| Dockerfile | [hadolint](https://github.com/lukasmartinelli/hadolint) |
|
||||||
| Elixir | [credo](https://github.com/rrrene/credo), [dogma](https://github.com/lpil/dogma) |
|
| Elixir | [credo](https://github.com/rrrene/credo), [dogma](https://github.com/lpil/dogma) |
|
||||||
| Elm | [elm-make](https://github.com/elm-lang/elm-make) |
|
| Elm | [elm-make](https://github.com/elm-lang/elm-make) |
|
||||||
|
40
ale_linters/dart/dartanalyzer.vim
Normal file
40
ale_linters/dart/dartanalyzer.vim
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
" Author: w0rp <devw0rp@gmail.com>
|
||||||
|
" Description: Check Dart files with dartanalyzer
|
||||||
|
|
||||||
|
call ale#Set('dart_dartanalyzer_executable', 'dartanalyzer')
|
||||||
|
|
||||||
|
function! ale_linters#dart#dartanalyzer#GetExecutable(buffer) abort
|
||||||
|
return ale#Var(a:buffer, 'dart_dartanalyzer_executable')
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! ale_linters#dart#dartanalyzer#GetCommand(buffer) abort
|
||||||
|
let l:executable = ale_linters#dart#dartanalyzer#GetExecutable(a:buffer)
|
||||||
|
let l:path = ale#path#FindNearestFile(a:buffer, '.packages')
|
||||||
|
|
||||||
|
return ale#Escape(l:executable)
|
||||||
|
\ . (!empty(l:path) ? ' --packages ' . ale#Escape(l:path) : '')
|
||||||
|
\ . ' %t'
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! ale_linters#dart#dartanalyzer#Handle(buffer, lines) abort
|
||||||
|
let l:pattern = '\v^ ([a-z]+) . (.+) at (.+):(\d+):(\d+) . (.+)$'
|
||||||
|
let l:output = []
|
||||||
|
|
||||||
|
for l:match in ale#util#GetMatches(a:lines, l:pattern)
|
||||||
|
call add(l:output, {
|
||||||
|
\ 'type': l:match[1] ==# 'error' ? 'E' : 'W',
|
||||||
|
\ 'text': l:match[6] . ': ' . l:match[2],
|
||||||
|
\ 'lnum': str2nr(l:match[4]),
|
||||||
|
\ 'col': str2nr(l:match[5]),
|
||||||
|
\})
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return l:output
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call ale#linter#Define('dart', {
|
||||||
|
\ 'name': 'dartanalyzer',
|
||||||
|
\ 'executable_callback': 'ale_linters#dart#dartanalyzer#GetExecutable',
|
||||||
|
\ 'command_callback': 'ale_linters#dart#dartanalyzer#GetCommand',
|
||||||
|
\ 'callback': 'ale_linters#dart#dartanalyzer#Handle',
|
||||||
|
\})
|
36
doc/ale-dart.txt
Normal file
36
doc/ale-dart.txt
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
===============================================================================
|
||||||
|
ALE Dart Integration *ale-dart-options*
|
||||||
|
|
||||||
|
|
||||||
|
===============================================================================
|
||||||
|
dartanalyzer *ale-dart-dartanalyzer*
|
||||||
|
|
||||||
|
Installation
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Install Dart via whatever means. `dartanalyzer` will be included in the SDK.
|
||||||
|
|
||||||
|
You can add the SDK to `$PATH`, as described here:
|
||||||
|
https://www.dartlang.org/tools/sdk
|
||||||
|
|
||||||
|
If you have installed Dart on Linux, you can also try the following: >
|
||||||
|
" Set the executable path for dartanalyzer to the absolute path to it.
|
||||||
|
let g:ale_dart_dartanalyzer_executable = '/usr/lib/dart/bin/dartanalyzer'
|
||||||
|
<
|
||||||
|
... or similarly for wherever your Dart SDK lives. This should work without
|
||||||
|
having to modify `$PATH`.
|
||||||
|
|
||||||
|
|
||||||
|
Options
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
g:ale_dart_dartanalyzer_executable *g:ale_dart_dartanalyzer_executable*
|
||||||
|
*b:ale_dart_dartanalyzer_executable*
|
||||||
|
Type: |String|
|
||||||
|
Default: `'dartanalyzer'`
|
||||||
|
|
||||||
|
This variable can be set to change the path to dartanalyzer.
|
||||||
|
|
||||||
|
|
||||||
|
===============================================================================
|
||||||
|
vim:tw=78:ts=2:sts=2:sw=2:ft=help:norl:
|
@ -31,6 +31,8 @@ CONTENTS *ale-contents*
|
|||||||
stylelint...........................|ale-css-stylelint|
|
stylelint...........................|ale-css-stylelint|
|
||||||
cmake.................................|ale-cmake-options|
|
cmake.................................|ale-cmake-options|
|
||||||
cmakelint...........................|ale-cmake-cmakelint|
|
cmakelint...........................|ale-cmake-cmakelint|
|
||||||
|
dart..................................|ale-dart-options|
|
||||||
|
dartanalyzer........................|ale-dart-dartanalyzer|
|
||||||
erlang................................|ale-erlang-options|
|
erlang................................|ale-erlang-options|
|
||||||
erlc................................|ale-erlang-erlc|
|
erlc................................|ale-erlang-erlc|
|
||||||
syntaxerl...........................|ale-erlang-syntaxerl|
|
syntaxerl...........................|ale-erlang-syntaxerl|
|
||||||
@ -172,6 +174,7 @@ The following languages and tools are supported.
|
|||||||
* CSS: 'csslint', 'stylelint'
|
* CSS: 'csslint', 'stylelint'
|
||||||
* Cython (pyrex filetype): 'cython'
|
* Cython (pyrex filetype): 'cython'
|
||||||
* D: 'dmd'
|
* D: 'dmd'
|
||||||
|
* Dart: 'dartanalyzer'
|
||||||
* Dockerfile: 'hadolint'
|
* Dockerfile: 'hadolint'
|
||||||
* Elixir: 'credo', 'dogma'
|
* Elixir: 'credo', 'dogma'
|
||||||
* Elm: 'elm-make'
|
* Elm: 'elm-make'
|
||||||
|
0
test/command_callback/dart_paths/.packages
Normal file
0
test/command_callback/dart_paths/.packages
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
Before:
|
||||||
|
Save g:ale_dart_dartanalyzer_executable
|
||||||
|
unlet! g:ale_dart_dartanalyzer_executable
|
||||||
|
|
||||||
|
runtime ale_linters/dart/dartanalyzer.vim
|
||||||
|
|
||||||
|
call ale#test#SetDirectory('/testplugin/test/command_callback')
|
||||||
|
|
||||||
|
After:
|
||||||
|
Restore
|
||||||
|
|
||||||
|
call ale#test#RestoreDirectory()
|
||||||
|
call ale#linter#Reset()
|
||||||
|
|
||||||
|
Execute(The default command and executable should be correct):
|
||||||
|
AssertEqual
|
||||||
|
\ 'dartanalyzer',
|
||||||
|
\ ale_linters#dart#dartanalyzer#GetExecutable(bufnr(''))
|
||||||
|
AssertEqual
|
||||||
|
\ ale#Escape('dartanalyzer') . ' %t',
|
||||||
|
\ ale_linters#dart#dartanalyzer#GetCommand(bufnr(''))
|
||||||
|
|
||||||
|
Execute(The executable should be configurable):
|
||||||
|
let g:ale_dart_dartanalyzer_executable = '/usr/lib/dart/bin/dartanalyzer'
|
||||||
|
|
||||||
|
AssertEqual
|
||||||
|
\ '/usr/lib/dart/bin/dartanalyzer',
|
||||||
|
\ ale_linters#dart#dartanalyzer#GetExecutable(bufnr(''))
|
||||||
|
AssertEqual
|
||||||
|
\ ale#Escape('/usr/lib/dart/bin/dartanalyzer') . ' %t',
|
||||||
|
\ ale_linters#dart#dartanalyzer#GetCommand(bufnr(''))
|
||||||
|
|
||||||
|
Execute(The .packages file should be set if detected):
|
||||||
|
call ale#test#SetFilename('dart_paths/foo')
|
||||||
|
|
||||||
|
AssertEqual
|
||||||
|
\ ale#Escape('dartanalyzer')
|
||||||
|
\ . ' --packages ' . ale#Escape(g:dir . '/dart_paths/.packages')
|
||||||
|
\ . ' %t',
|
||||||
|
\ ale_linters#dart#dartanalyzer#GetCommand(bufnr(''))
|
28
test/handler/test_dartanalyzer_handler.vader
Normal file
28
test/handler/test_dartanalyzer_handler.vader
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
Before:
|
||||||
|
runtime ale_linters/dart/dartanalyzer.vim
|
||||||
|
|
||||||
|
After:
|
||||||
|
call ale#linter#Reset()
|
||||||
|
|
||||||
|
Execute(Basic problems should be parsed correctly):
|
||||||
|
AssertEqual
|
||||||
|
\ [
|
||||||
|
\ {
|
||||||
|
\ 'type': 'E',
|
||||||
|
\ 'text': 'expected_token: Expected to find ''}''',
|
||||||
|
\ 'lnum': 5,
|
||||||
|
\ 'col': 1,
|
||||||
|
\ },
|
||||||
|
\ {
|
||||||
|
\ 'type': 'W',
|
||||||
|
\ 'text': 'invalid_assignment: A value of type ''String'' can''t be assigned to a variable of type ''int''',
|
||||||
|
\ 'lnum': 2,
|
||||||
|
\ 'col': 16,
|
||||||
|
\ },
|
||||||
|
\ ],
|
||||||
|
\ ale_linters#dart#dartanalyzer#Handle(bufnr(''), [
|
||||||
|
\ 'Analyzing main.dart...',
|
||||||
|
\ ' error • Expected to find ''}'' at main.dart:5:1 • expected_token',
|
||||||
|
\ ' warning • A value of type ''String'' can''t be assigned to a variable of type ''int'' at main.dart:2:16 • invalid_assignment',
|
||||||
|
\ '1 error and 1 warning found.',
|
||||||
|
\ ])
|
Loading…
Reference in New Issue
Block a user