Compare commits

...

3 Commits

Author SHA1 Message Date
7e7201f6d7
Deoplete logging 2018-06-20 15:50:00 +02:00
2f0190fad6
Update argon 2018-06-20 15:49:50 +02:00
c58eab1c0e
Brittany 2018-06-20 15:49:42 +02:00
2 changed files with 27 additions and 22 deletions

View File

@ -78,7 +78,7 @@ call deoplete#custom#option('sources',{
\ }) \ })
" inoremap <expr><tab> pumvisible() ? "\<c-n>" : "\<tab>" " inoremap <expr><tab> pumvisible() ? "\<c-n>" : "\<tab>"
call deoplete#enable() call deoplete#enable()
call deoplete#enable_logging('DEBUG', $HOME . '/deoplete.log')
let g:ghcmod_hlint_options = ['--ignore=Eta reduce $'] let g:ghcmod_hlint_options = ['--ignore=Eta reduce $']
@ -87,7 +87,7 @@ let g:ale_enabled = 1
let g:ale_linters = {'haskell':['ghc-mod', 'hdevtools'], 'c':['clang']} let g:ale_linters = {'haskell':['ghc-mod', 'hdevtools'], 'c':['clang']}
" let g:ale_linters = {'haskell':['ghc-mod', 'hdevtools', 'argon'], 'c':['clang']} " let g:ale_linters = {'haskell':['ghc-mod', 'hdevtools', 'argon'], 'c':['clang']}
" let g:ale_fixers = { " let g:ale_fixers = {
" \ 'go': ['gofmt', 'goimports'], " \ 'haskell': ['brittany'],
" \} " \}
let g:ale_haskell_hdevtools_options = "-g '-Wall' -g '-Wno-orphans'" let g:ale_haskell_hdevtools_options = "-g '-Wall' -g '-Wno-orphans'"
let g:ale_haskell_argon_error_level = 14 let g:ale_haskell_argon_error_level = 14

View File

@ -27,28 +27,33 @@ function! ale_linters#haskell#argon#Handle(buffer, lines) abort
let l:output = [] let l:output = []
for l:error in ale#util#FuzzyJSONDecode(a:lines, []) for l:error in ale#util#FuzzyJSONDecode(a:lines, [])
for l:block in l:error.blocks if !has_key(l:error, 'blocks')
let l:complexity = l:block.complexity " this cannot be formatted properly into an ALE error
execute 'echom ''[argon] '' l:error.message'
return l:output
endif
for l:block in l:error.blocks
let l:complexity = l:block.complexity
if l:complexity >= ale#Var(a:buffer, 'haskell_argon_error_level') if l:complexity >= ale#Var(a:buffer, 'haskell_argon_error_level')
let l:type = 'E' let l:type = 'E'
let l:max_c = ale#Var(a:buffer, 'haskell_argon_error_level') let l:max_c = ale#Var(a:buffer, 'haskell_argon_error_level')
elseif l:complexity >= ale#Var(a:buffer, 'haskell_argon_warn_level') elseif l:complexity >= ale#Var(a:buffer, 'haskell_argon_warn_level')
let l:type = 'W' let l:type = 'W'
let l:max_c = ale#Var(a:buffer, 'haskell_argon_warn_level') let l:max_c = ale#Var(a:buffer, 'haskell_argon_warn_level')
else else
let l:type = 'I' let l:type = 'I'
let l:max_c = ale#Var(a:buffer, 'haskell_argon_info_level') let l:max_c = ale#Var(a:buffer, 'haskell_argon_info_level')
endif endif
call add(l:output, { call add(l:output, {
\ 'filename': l:error.path, \ 'filename': l:error.path,
\ 'lnum': str2nr(l:block.lineno), \ 'lnum': l:block.lineno,
\ 'col': str2nr(l:block.col), \ 'col': l:block.col,
\ 'text': l:block.name . ': cyclomatic complexity of ' . l:complexity, \ 'text': l:block.name . ': cyclomatic complexity of ' . l:complexity,
\ 'type': l:type, \ 'type': l:type,
\}) \})
endfor endfor
endfor endfor
return l:output return l:output