diff options
author | Axel Clark <axel.clark@pm.me> | 2023-09-11 05:48:11 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-09-11 13:48:11 +0100 |
commit | ac615e7f656fb379cfe7cd205842b0f089a060d6 (patch) | |
tree | 9363c3295776dda51848c4cf3efd84eb48ea46fb /ale_linters/elixir | |
parent | 1bf445c6d5c805db0e0733846538fa4bfd5d8a68 (diff) | |
download | ale-ac615e7f656fb379cfe7cd205842b0f089a060d6.zip |
Add lexical for linting elixir projects (#4580)
Diffstat (limited to 'ale_linters/elixir')
-rw-r--r-- | ale_linters/elixir/lexical.vim | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/ale_linters/elixir/lexical.vim b/ale_linters/elixir/lexical.vim new file mode 100644 index 00000000..ea13142e --- /dev/null +++ b/ale_linters/elixir/lexical.vim @@ -0,0 +1,19 @@ +" Author: Axel Clark <axelclark@pm.me> +" Description: Lexical integration (https://github.com/lexical-lsp/lexical) + +call ale#Set('elixir_lexical_release', 'lexical') + +function! ale_linters#elixir#lexical#GetExecutable(buffer) abort + let l:dir = ale#path#Simplify(ale#Var(a:buffer, 'elixir_lexical_release')) + let l:cmd = has('win32') ? '\start_lexical.bat' : '/start_lexical.sh' + + return l:dir . l:cmd +endfunction + +call ale#linter#Define('elixir', { +\ 'name': 'lexical', +\ 'lsp': 'stdio', +\ 'executable': function('ale_linters#elixir#lexical#GetExecutable'), +\ 'command': function('ale_linters#elixir#lexical#GetExecutable'), +\ 'project_root': function('ale#handlers#elixir#FindMixUmbrellaRoot'), +\}) |