summaryrefslogtreecommitdiff
path: root/ale_linters/elixir
diff options
context:
space:
mode:
authorAxel Clark <axel.clark@pm.me>2023-09-11 05:48:11 -0700
committerGitHub <noreply@github.com>2023-09-11 13:48:11 +0100
commitac615e7f656fb379cfe7cd205842b0f089a060d6 (patch)
tree9363c3295776dda51848c4cf3efd84eb48ea46fb /ale_linters/elixir
parent1bf445c6d5c805db0e0733846538fa4bfd5d8a68 (diff)
downloadale-ac615e7f656fb379cfe7cd205842b0f089a060d6.zip
Add lexical for linting elixir projects (#4580)
Diffstat (limited to 'ale_linters/elixir')
-rw-r--r--ale_linters/elixir/lexical.vim19
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'),
+\})