b44bd4e24f
* handle column number in javac linter * Updated tests with column number for javac errors. * Updated tests with column number for javac errors.
95 lines
3.2 KiB
VimL
95 lines
3.2 KiB
VimL
" Author: farenjihn <farenjihn@gmail.com>, w0rp <devw0rp@gmail.com>
|
|
" Description: Lints java files using javac
|
|
|
|
let s:classpath_sep = has('unix') ? ':' : ';'
|
|
|
|
let g:ale_java_javac_options = get(g:, 'ale_java_javac_options', '')
|
|
let g:ale_java_javac_classpath = get(g:, 'ale_java_javac_classpath', '')
|
|
|
|
function! ale_linters#java#javac#GetImportPaths(buffer) abort
|
|
let l:pom_path = ale#path#FindNearestFile(a:buffer, 'pom.xml')
|
|
|
|
if !empty(l:pom_path) && executable('mvn')
|
|
return ale#path#CdString(fnamemodify(l:pom_path, ':h'))
|
|
\ . 'mvn dependency:build-classpath'
|
|
endif
|
|
|
|
return ''
|
|
endfunction
|
|
|
|
function! s:BuildClassPathOption(buffer, import_paths) abort
|
|
" Filter out lines like [INFO], etc.
|
|
let l:class_paths = filter(a:import_paths[:], 'v:val !~# ''[''')
|
|
call extend(
|
|
\ l:class_paths,
|
|
\ split(ale#Var(a:buffer, 'java_javac_classpath'), s:classpath_sep),
|
|
\)
|
|
|
|
return !empty(l:class_paths)
|
|
\ ? '-cp ' . ale#Escape(join(l:class_paths, s:classpath_sep))
|
|
\ : ''
|
|
endfunction
|
|
|
|
function! ale_linters#java#javac#GetCommand(buffer, import_paths) abort
|
|
let l:cp_option = s:BuildClassPathOption(a:buffer, a:import_paths)
|
|
let l:sp_option = ''
|
|
|
|
" Find the src directory, for files in this project.
|
|
let l:src_dir = ale#path#FindNearestDirectory(a:buffer, 'src/main/java')
|
|
|
|
if !empty(l:src_dir)
|
|
let l:sp_option = '-sourcepath ' . ale#Escape(l:src_dir)
|
|
endif
|
|
|
|
" Create .class files in a temporary directory, which we will delete later.
|
|
let l:class_file_directory = ale#engine#CreateDirectory(a:buffer)
|
|
|
|
return 'javac -Xlint'
|
|
\ . ' ' . l:cp_option
|
|
\ . ' ' . l:sp_option
|
|
\ . ' -d ' . ale#Escape(l:class_file_directory)
|
|
\ . ' ' . ale#Var(a:buffer, 'java_javac_options')
|
|
\ . ' %t'
|
|
endfunction
|
|
|
|
function! ale_linters#java#javac#Handle(buffer, lines) abort
|
|
" Look for lines like the following.
|
|
"
|
|
" Main.java:13: warning: [deprecation] donaught() in Testclass has been deprecated
|
|
" Main.java:16: error: ';' expected
|
|
|
|
let l:pattern = '\v^.*:(\d+): (.+):(.+)$'
|
|
let l:col_pattern = '\v^(\s*\^)$'
|
|
let l:symbol_pattern = '\v^ +symbol: *(class|method) +([^ ]+)'
|
|
let l:output = []
|
|
|
|
for l:match in ale#util#GetMatches(a:lines, [l:pattern, l:col_pattern, l:symbol_pattern])
|
|
if empty(l:match[2]) && empty(l:match[3])
|
|
let l:output[-1].col = len(l:match[1])
|
|
elseif empty(l:match[3])
|
|
" Add symbols to 'cannot find symbol' errors.
|
|
if l:output[-1].text ==# 'error: cannot find symbol'
|
|
let l:output[-1].text .= ': ' . l:match[2]
|
|
endif
|
|
else
|
|
call add(l:output, {
|
|
\ 'lnum': l:match[1] + 0,
|
|
\ 'text': l:match[2] . ':' . l:match[3],
|
|
\ 'type': l:match[2] ==# 'error' ? 'E' : 'W',
|
|
\})
|
|
endif
|
|
endfor
|
|
|
|
return l:output
|
|
endfunction
|
|
|
|
call ale#linter#Define('java', {
|
|
\ 'name': 'javac',
|
|
\ 'executable': 'javac',
|
|
\ 'command_chain': [
|
|
\ {'callback': 'ale_linters#java#javac#GetImportPaths', 'output_stream': 'stdout'},
|
|
\ {'callback': 'ale_linters#java#javac#GetCommand', 'output_stream': 'stderr'},
|
|
\ ],
|
|
\ 'callback': 'ale_linters#java#javac#Handle',
|
|
\})
|