Skip to content

Commit

Permalink
Add foldtext for testrunner folds
Browse files Browse the repository at this point in the history
  • Loading branch information
nickspoons committed Jul 13, 2022
1 parent e023a08 commit fe8658e
Show file tree
Hide file tree
Showing 2 changed files with 47 additions and 9 deletions.
54 changes: 45 additions & 9 deletions autoload/OmniSharp/testrunner.vim
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,42 @@ function! OmniSharp#testrunner#Init(buffers) abort
endfunction


function! OmniSharp#testrunner#FoldText() abort
let line = getline(v:foldstart)
if line =~# '^;'
" Project
let projectkey = matchlist(line, '^\S\+')[0]
let [assembly, _] = split(projectkey, ';')
let ntests = 0
for filename in keys(s:tests[projectkey].files)
let ntests += len(s:tests[projectkey].files[filename].tests)
endfor
let err = match(line, '; ERROR$') == -1 ? '' : ' ERROR'
return printf('%s [%d]%s', assembly, ntests, err)
elseif line =~# '^ \f'
" File
let filename = trim(line)
let fullpath = fnamemodify(filename, ':p')
let displayname = matchlist(filename, '^\f\{-}\([^/\\]\+\)\.csx\?$')[1]
" Position the cursor so that search() is relative to the fold, not the
" actual cursor position
let winview = winsaveview()
call cursor(v:foldstart, 0)
let projectline = search('^;', 'bcnWz')
call winrestview(winview)
let projectkey = matchlist(getline(projectline), '^\S\+')[0]
let ntests = len(s:tests[projectkey].files[fullpath].tests)
return printf(' %s [%d]', displayname, ntests)
elseif line =~# '^<'
return printf(' Error details (%d lines)', v:foldend - v:foldstart + 1)
elseif line =~# '^>'
return printf(' Results (%d lines)', v:foldend - v:foldstart + 1)
elseif line =~# '^//'
return printf(' Output (%d lines)', v:foldend - v:foldstart + 1)
endif
return printf('%s (%d lines)', line, v:foldend - v:foldstart + 1)
endfunction

function! OmniSharp#testrunner#Log(message) abort
call extend(s:current.log, a:message)
endfunction
Expand All @@ -43,9 +79,9 @@ function! OmniSharp#testrunner#Run() abort
let line = getline('.')
if line =~# '^;'
" Project selected - run all tests
let projectname = matchlist(getline('.'), '^\S\+')[0]
let filenames = filter(keys(s:tests[projectname].files),
\ {_,f -> s:tests[projectname].files[f].visible})
let projectkey = matchlist(getline('.'), '^\S\+')[0]
let filenames = filter(keys(s:tests[projectkey].files),
\ {_,f -> s:tests[projectkey].files[f].visible})
call OmniSharp#actions#test#RunInFile(1, filenames)
elseif line =~# '^ \f'
" File selected
Expand All @@ -66,14 +102,14 @@ function! OmniSharp#testrunner#Remove() abort
let line = getline('.')
if line =~# '^;'
" Project selected - run all tests
let projectname = matchlist(getline('.'), '^\S\+')[0]
let s:tests[projectname].visible = 0
let projectkey = matchlist(getline('.'), '^\S\+')[0]
let s:tests[projectkey].visible = 0
elseif line =~# '^ \f'
" File selected
let filename = fnamemodify(trim(line), ':p')
let projectline = search('^;', 'bcnWz')
let projectname = matchlist(getline(projectline), '^\S\+')[0]
let s:tests[projectname].files[filename].visible = 0
let projectkey = matchlist(getline(projectline), '^\S\+')[0]
let s:tests[projectkey].files[filename].visible = 0
else
let test = s:utils.findTest()
let test.state = 'hidden'
Expand Down Expand Up @@ -487,11 +523,11 @@ function! s:utils.findTest() abort
if testline > 0
let testname = matchlist(getline(testline), '[-|*!] \zs.*$')[0]
let projectline = search('^;', 'bcnWz')
let projectname = matchlist(getline(projectline), '^\S\+')[0]
let projectkey = matchlist(getline(projectline), '^\S\+')[0]
let fileline = search('^ \f', 'bcnWz')
let filename = matchlist(getline(fileline), '^ \zs.*$')[0]
let filename = fnamemodify(filename, ':p')
return s:tests[projectname].files[filename].tests[testname]
return s:tests[projectkey].files[filename].tests[testname]
endif
return {}
endfunction
Expand Down
2 changes: 2 additions & 0 deletions ftplugin/omnisharptest/OmniSharp.vim
Original file line number Diff line number Diff line change
Expand Up @@ -26,3 +26,5 @@ call s:map('n', '<F6>', 'omnisharp_testrunner_debug')
call s:map('n', '<F9>', 'omnisharp_testrunner_set_breakpoints')
call s:map('n', '<CR>', 'omnisharp_testrunner_navigate')
call s:map('n', 'dd', 'omnisharp_testrunner_remove')

set foldtext=OmniSharp#testrunner#FoldText()

0 comments on commit fe8658e

Please sign in to comment.