mirror of
https://github.com/dense-analysis/ale
synced 2024-12-16 19:35:42 +00:00
f49f615ef6
This PR first and formost implements support for dot-seperate filetypes, a very trivial change. This closes #132 But more importantly, this PR vastly improves the test quality for `ale#linter#Get`. It enables us to reset the state of ale's internal linter cache, to facilitate better testing, as well as making use of mocked linters instead of depending on linters on disk (which may change). In addition, a dummy linter is defined to test the autoloading behavior. Header guards were removed from all linters as: * A: ale won't try and load linters if they already exist in memory * B: we can't reset state for testing if they can't be loaded again
65 lines
1.9 KiB
VimL
65 lines
1.9 KiB
VimL
" Author: w0rp <devw0rp@gmail.com>
|
|
" Description: "dmd for D files"
|
|
|
|
" A function for finding the dmd-wrapper script in the Vim runtime paths
|
|
function! s:FindWrapperScript()
|
|
for l:parent in split(&runtimepath, ',')
|
|
" Expand the path to deal with ~ issues.
|
|
let l:path = expand(l:parent . '/' . 'dmd-wrapper')
|
|
|
|
if filereadable(l:path)
|
|
return l:path
|
|
endif
|
|
endfor
|
|
endfunction
|
|
|
|
function! ale_linters#d#dmd#GetCommand(buffer)
|
|
let l:wrapper_script = s:FindWrapperScript()
|
|
|
|
let l:command = l:wrapper_script . ' -o- -vcolumns -c'
|
|
|
|
return l:command
|
|
endfunction
|
|
|
|
function! ale_linters#d#dmd#Handle(buffer, lines)
|
|
" Matches patterns lines like the following:
|
|
" /tmp/tmp.qclsa7qLP7/file.d(1): Error: function declaration without return type. (Note that constructors are always named 'this')
|
|
" /tmp/tmp.G1L5xIizvB.d(8,8): Error: module weak_reference is in file 'dstruct/weak_reference.d' which cannot be read
|
|
let l:pattern = '^[^(]\+(\([0-9]\+\)\,\?\([0-9]*\)): \([^:]\+\): \(.\+\)'
|
|
let l:output = []
|
|
|
|
for l:line in a:lines
|
|
let l:match = matchlist(l:line, l:pattern)
|
|
|
|
if len(l:match) == 0
|
|
break
|
|
endif
|
|
|
|
let l:line = l:match[1] + 0
|
|
let l:column = l:match[2] + 0
|
|
let l:type = l:match[3]
|
|
let l:text = l:match[4]
|
|
|
|
" vcol is Needed to indicate that the column is a character.
|
|
call add(l:output, {
|
|
\ 'bufnr': bufnr('%'),
|
|
\ 'lnum': l:line,
|
|
\ 'vcol': 0,
|
|
\ 'col': l:column,
|
|
\ 'text': l:text,
|
|
\ 'type': l:type ==# 'Warning' ? 'W' : 'E',
|
|
\ 'nr': -1,
|
|
\})
|
|
endfor
|
|
|
|
return l:output
|
|
endfunction
|
|
|
|
call ale#linter#Define('d', {
|
|
\ 'name': 'dmd',
|
|
\ 'output_stream': 'stderr',
|
|
\ 'executable': 'dmd',
|
|
\ 'command_callback': 'ale_linters#d#dmd#GetCommand',
|
|
\ 'callback': 'ale_linters#d#dmd#Handle',
|
|
\})
|