Parse stacktraces from :make with lein

This commit is contained in:
Tim Pope 2014-01-30 23:13:35 -05:00
parent 7bc3ee4c1a
commit eb27299bd9
3 changed files with 60 additions and 31 deletions

9
compiler/lein.vim Normal file
View File

@ -0,0 +1,9 @@
" Vim compiler file
if exists("current_compiler")
finish
endif
let current_compiler = "lein"
CompilerSet makeprg=lein
CompilerSet errorformat=%+G,fireplace

View File

@ -45,9 +45,9 @@ middleware is loaded. https://github.com/cemerick/piggieback
LEININGEN *fireplace-leiningen*
In addition to automatic repl connection, Clojure buffers in a Leiningen
project will automatically have their 'makeprg' set to lein. This has the
nominal value of letting you call, for example, |:make| deps rather than
:!lein deps.
project will automatically have their 'makeprg' set to lein and 'efm' set to
"%+G,fireplace". This combination enables `:make test` to run `lein test` and
parse the stacktraces in the results.
DOCUMENTATION *fireplace-documentation*

View File

@ -511,34 +511,32 @@ function! fireplace#findresource(resource, ...) abort
return ''
endfunction
function! fireplace#quickfix_for(stacktrace) abort
let qflist = []
for line in a:stacktrace
let entry = {'text': line}
let match = matchlist(line, '\(.*\)(\(.*\))')
function! s:qfmassage(line, path) abort
let entry = {'text': a:line}
let match = matchlist(a:line, '\(\S\+\)\s\=(\(\S\+\))')
if !empty(match)
let [_, class, file; __] = match
if file =~# '^NO_SOURCE_FILE:' || file !~# ':'
let entry.resource = ''
let entry.lnum = 0
else
let truncated = substitute(class, '\.[A-Za-z0-9_]\+\%($.*\)$', '', '')
let truncated = substitute(class, '\.[A-Za-z0-9_]\+\%([$/].*\)$', '', '')
let entry.resource = tr(truncated, '.', '/').'/'.split(file, ':')[0]
let entry.lnum = split(file, ':')[-1]
endif
let qflist += [entry]
endif
endfor
let paths = map(copy(qflist), 'fireplace#findresource(v:val.resource)')
let i = 0
for i in range(len(qflist))
if !empty(paths[i])
let qflist[i].filename = paths[i]
let entry.filename = fireplace#findresource(entry.resource, a:path)
if empty(entry.filename)
let entry.lnum = 0
else
call remove(qflist[i], 'lnum')
let entry.text = class
endif
endfor
return qflist
endif
return entry
endfunction
function! fireplace#quickfix_for(stacktrace) abort
let path = fireplace#path()
return map(copy(a:stacktrace), 's:qfmassage(v:val, path)')
endfunction
function! s:output_response(response) abort
@ -1285,8 +1283,9 @@ function! s:hunt(start, anchor, pattern) abort
return ''
endfunction
if !exists('s:leiningen_repl_ports')
if !exists('s:leiningen_repls')
let s:leiningen_repls = {}
let s:leiningen_paths = {}
endif
function! s:portfile() abort
@ -1326,6 +1325,7 @@ function! s:leiningen_connect() abort
let conn = nrepl#fireplace_connection#open(port)
let s:leiningen_repls[b:leiningen_root].connection = conn
call s:register_connection(conn, b:leiningen_root)
let s:leiningen_paths[b:leiningen_root] = conn.path()
catch /^nREPL Connection Error:/
if &verbose
echohl WarningMSG
@ -1350,15 +1350,35 @@ function! s:leiningen_init() abort
let b:java_root = b:leiningen_root
setlocal makeprg=lein efm=%+G
compiler lein
if exists('classpath#from_vim')
let s:leiningen_paths[b:leiningen_root] = classpath#from_vim(&path)
endif
call s:leiningen_connect()
endfunction
function! s:massage_quickfix() abort
if &errorformat !~# 'fireplace$'
return
endif
if has_key(s:leiningen_paths, getcwd())
let path = s:leiningen_paths[getcwd()]
else
return
endif
let qflist = getqflist()
for entry in qflist
call extend(entry, s:qfmassage(get(entry, 'text', ''), path))
endfor
call setqflist(qflist, 'replace')
endfunction
augroup fireplace_leiningen
autocmd!
autocmd User FireplacePreConnect call s:leiningen_connect()
autocmd FileType clojure call s:leiningen_init()
autocmd QuickFixCmdPost make,cfile,cgetfile call s:massage_quickfix()
augroup END
" }}}1