summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorw0rp <w0rp@users.noreply.github.com>2017-11-07 11:54:00 +0000
committerGitHub <noreply@github.com>2017-11-07 11:54:00 +0000
commite4cd371621ff2617e42ff5178b4690ebc00f67a4 (patch)
tree671afe847806a5de17196b23ef2a3a604e5ce435
parent8e71f82f8f4f0336ae74fe0e77398c27ea0c5309 (diff)
parent3a57e4d1516c31e305d9f374d2f83a9a541afa52 (diff)
downloadale-e4cd371621ff2617e42ff5178b4690ebc00f67a4.zip
Merge pull request #1063 from aurieh/master
Add dart LSP (resolves #1006)
-rw-r--r--README.md2
-rw-r--r--ale_linters/dart/language_server.vim30
-rw-r--r--doc/ale.txt2
3 files changed, 32 insertions, 2 deletions
diff --git a/README.md b/README.md
index b8be4752..088c08cf 100644
--- a/README.md
+++ b/README.md
@@ -87,7 +87,7 @@ formatting.
| CSS | [csslint](http://csslint.net/), [stylelint](https://github.com/stylelint/stylelint), [prettier](https://github.com/prettier/prettier) |
| Cython (pyrex filetype) | [cython](http://cython.org/) |
| D | [dmd](https://dlang.org/dmd-linux.html) |
-| Dart | [dartanalyzer](https://github.com/dart-lang/sdk/tree/master/pkg/analyzer_cli) !! |
+| Dart | [dartanalyzer](https://github.com/dart-lang/sdk/tree/master/pkg/analyzer_cli) !!, [language_server](https://github.com/natebosch/dart_language_server) |
| Dockerfile | [hadolint](https://github.com/lukasmartinelli/hadolint) |
| Elixir | [credo](https://github.com/rrrene/credo), [dogma](https://github.com/lpil/dogma) !! |
| Elm | [elm-format](https://github.com/avh4/elm-format), [elm-make](https://github.com/elm-lang/elm-make) |
diff --git a/ale_linters/dart/language_server.vim b/ale_linters/dart/language_server.vim
new file mode 100644
index 00000000..15c77017
--- /dev/null
+++ b/ale_linters/dart/language_server.vim
@@ -0,0 +1,30 @@
+" Author: aurieh <me@aurieh.me>
+" Description: A language server for dart
+
+call ale#Set('dart_language_server_executable', 'dart_language_server')
+
+function! ale_linters#dart#language_server#GetExecutable(buffer) abort
+ return ale#Var(a:buffer, 'dart_language_server_executable')
+endfunction
+
+function! ale_linters#dart#language_server#GetLanguage(buffer) abort
+ return 'dart'
+endfunction
+
+function! ale_linters#dart#language_server#GetProjectRoot(buffer) abort
+ " Note: pub only looks for pubspec.yaml, there's no point in adding
+ " support for pubspec.yml
+ let l:pubspec = ale#path#FindNearestFile(a:buffer, 'pubspec.yaml')
+
+ return !empty(l:pubspec) ? fnamemodify(l:pubspec, ':h:h') : ''
+endfunction
+
+call ale#linter#Define('dart', {
+\ 'name': 'language_server',
+\ 'lsp': 'stdio',
+\ 'executable_callback': 'ale_linters#dart#language_server#GetExecutable',
+\ 'command_callback': 'ale_linters#dart#language_server#GetExecutable',
+\ 'language_callback': 'ale_linters#dart#language_server#GetLanguage',
+\ 'project_root_callback': 'ale_linters#dart#language_server#GetProjectRoot',
+\})
+
diff --git a/doc/ale.txt b/doc/ale.txt
index f00e1ac2..67a5a130 100644
--- a/doc/ale.txt
+++ b/doc/ale.txt
@@ -270,7 +270,7 @@ Notes:
* CSS: `csslint`, `stylelint`, `prettier`
* Cython (pyrex filetype): `cython`
* D: `dmd`
-* Dart: `dartanalyzer`!!
+* Dart: `dartanalyzer`!!, `language_server`
* Dockerfile: `hadolint`
* Elixir: `credo`, `dogma`!!
* Elm: `elm-format, elm-make`