summaryrefslogtreecommitdiff
path: root/ale_linters
diff options
context:
space:
mode:
authorHoracio Sanson <horacio@allm.net>2019-05-08 11:46:19 +0900
committerHoracio Sanson <horacio@allm.net>2019-05-08 13:24:34 +0900
commit53db52e713ca1848e72ffaea0bff1c415cfa5cee (patch)
treeeaa6ccff9614416d2f1e923705980b1ed00fa9eb /ale_linters
parent63abd2dfefa96b3ee279ff7f42e4e918d5619ce6 (diff)
downloadale-53db52e713ca1848e72ffaea0bff1c415cfa5cee.zip
Improve eclipselsp jar search logic.
- Set default value to $HOME/eclipse.jdt.ls - Make JAR search regexp more specific. - Allow to set the VSCode extensions folder as ale_java_eclipselsp_path.
Diffstat (limited to 'ale_linters')
-rw-r--r--ale_linters/java/eclipselsp.vim23
1 files changed, 15 insertions, 8 deletions
diff --git a/ale_linters/java/eclipselsp.vim b/ale_linters/java/eclipselsp.vim
index af9a325e..d0ea9d6c 100644
--- a/ale_linters/java/eclipselsp.vim
+++ b/ale_linters/java/eclipselsp.vim
@@ -3,7 +3,7 @@
let s:version_cache = {}
-call ale#Set('java_eclipselsp_path', 'eclipse.jdt.ls')
+call ale#Set('java_eclipselsp_path', ale#path#Simplify($HOME . '/eclipse.jdt.ls'))
call ale#Set('java_eclipselsp_executable', 'java')
function! ale_linters#java#eclipselsp#Executable(buffer) abort
@@ -16,20 +16,27 @@ endfunction
function! ale_linters#java#eclipselsp#JarPath(buffer) abort
let l:path = ale_linters#java#eclipselsp#TargetPath(a:buffer)
- let l:path = l:path . '/org.eclipse.jdt.ls.product/target/repository/plugins'
- let l:files = globpath(l:path, 'org.eclipse.equinox.launcher_*.jar', 1, 1)
+ " Search jar file within repository path when manually built using mvn
+ let l:repo_path = l:path . '/org.eclipse.jdt.ls.product/target/repository'
+ let l:files = globpath(l:repo_path, '**/plugins/org.eclipse.equinox.launcher_\d\.\d\.\d\d\d\.*\.jar', 1, 1)
- if empty(l:files)
- return ''
+ if len(l:files) == 1
+ return l:files[0]
endif
- return l:files[0]
+ " Search jar file within VSCode extensions folder.
+ let l:files = globpath(l:path, '**/plugins/org.eclipse.equinox.launcher_\d\.\d\.\d\d\d\.*\.jar', 1, 1)
+
+ if len(l:files) == 1
+ return l:files[0]
+ endif
+
+ return ''
endfunction
function! ale_linters#java#eclipselsp#ConfigurationPath(buffer) abort
- let l:path = ale_linters#java#eclipselsp#TargetPath(a:buffer)
- let l:path = l:path . '/org.eclipse.jdt.ls.product/target/repository'
+ let l:path = fnamemodify(ale_linters#java#eclipselsp#JarPath(a:buffer), ':p:h:h')
if has('win32')
let l:path = l:path . '/config_win'