summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ale_linters/julia/languageserver.vim30
-rw-r--r--autoload/ale/julia.vim21
2 files changed, 51 insertions, 0 deletions
diff --git a/ale_linters/julia/languageserver.vim b/ale_linters/julia/languageserver.vim
new file mode 100644
index 00000000..1755c794
--- /dev/null
+++ b/ale_linters/julia/languageserver.vim
@@ -0,0 +1,30 @@
+" Author: Bartolomeo Stellato <bartolomeo.stellato@gmail.com>
+" Description: A language server for Julia
+
+call ale#Set('julia_languageserver_executable', 'julia')
+call ale#Set('julia_languageserver_use_global', get(g:, 'ale_use_global_executables', 0))
+
+function! ale_linters#julia#languageserver#GetExecutable(buffer) abort
+ let l:binary = ale#Var(a:buffer, 'julia_languageserver_executable')
+ return ale#Escape(l:binary)
+endfunction
+
+function! ale_linters#julia#languageserver#GetCommand(buffer) abort
+ let l:executable = ale_linters#julia#languageserver#GetExecutable(a:buffer)
+ let l:options = '--startup-file=no --history-file=no -e ' . '"
+\ using LanguageServer;
+\ server = LanguageServer.LanguageServerInstance(STDIN, STDOUT, false);
+\ server.runlinter = true;
+\ run(server);"'
+
+ return ale#Escape(l:executable) . ale#Escape(l:options)
+
+endfunction
+
+call ale#linter#Define('julia', {
+\ 'name': 'languageserver',
+\ 'lsp': 'stdio',
+\ 'executable_callback': 'ale_linters#julia#languageserver#GetExecutable',
+\ 'command_callback': 'ale_linters#julia#languageserver#GetCommand',
+\ 'project_root_callback': 'ale#julia#FindProjectRoot',
+\})
diff --git a/autoload/ale/julia.vim b/autoload/ale/julia.vim
new file mode 100644
index 00000000..a6c0ee4a
--- /dev/null
+++ b/autoload/ale/julia.vim
@@ -0,0 +1,21 @@
+" Set just so tests can override it.
+let g:__ale_julia_project_filenames = ['.git/HEAD']
+function! ale#julia#FindProjectRoot(buffer) abort
+ for l:project_filename in g:__ale_julia_project_filenames
+ let l:full_path = ale#path#FindNearestFile(a:buffer, l:project_filename)
+
+ if !empty(l:full_path)
+ let l:path = fnamemodify(l:full_path, ':h')
+
+ " Correct .git path detection.
+ if fnamemodify(l:path, ':t') is# '.git'
+ let l:path = fnamemodify(l:path, ':h')
+ endif
+
+ return l:path
+ endif
+ endfor
+
+ return ''
+endfunction
+