nvim: add test runner bind
this (should) mark full completion of migration to nvim-dap
This commit is contained in:
parent
9c82edec56
commit
d6c3fba6d3
@ -108,6 +108,11 @@ function prob_cpp; echo $EDITOR src/(basename (xsel -b)).cpp; end
|
||||
abbr -a cpp --function prob_cpp
|
||||
function prob_py; echo $EDITOR src/(basename (xsel -b)).py; end
|
||||
abbr -a py --function prob_py
|
||||
# see src/.config/nvim/vimspector.vim and search for TestRunner()
|
||||
function prob_testdir; echo \~/.cache/termdebug/tests/src/(basename (xsel -b)); end
|
||||
abbr -a --position anywhere tesd --function prob_testdir
|
||||
|
||||
# creates a debug directory for a file
|
||||
# see src/.config/nvim/lua/debugging.lua
|
||||
function dbgd
|
||||
set -l dir $XDG_CACHE_HOME/nvimdbg(realpath $argv)
|
||||
mkdir -p $dir
|
||||
cd $dir
|
||||
end
|
||||
|
@ -7,7 +7,5 @@ set foldexpr=nvim_treesitter#foldexpr()
|
||||
" unfold by default
|
||||
set foldlevel=99
|
||||
|
||||
" source $XDG_CONFIG_HOME/nvim/vimspector.vim
|
||||
|
||||
" auto-pairs
|
||||
let g:AutoPairsFlyMode = 0
|
||||
|
@ -165,6 +165,29 @@ end
|
||||
keymap("<leader>rw", write_input)
|
||||
keymap("<leader>ri", run_input)
|
||||
|
||||
function run_tests(file)
|
||||
local file = gf(file)
|
||||
local executable
|
||||
if vim.fn.expand("%:e") == "cpp" then
|
||||
executable = M.dbg_dir(file) .. "/binary"
|
||||
else
|
||||
executable = vim.fn.expand("%:p")
|
||||
end
|
||||
|
||||
vim.cmd.vsplit()
|
||||
vim.w.nvimdbg_testdir = M.dbg_dir(file) .. "/tests"
|
||||
vim.w.nvimdbg_exec = executable
|
||||
vim.cmd [[
|
||||
vertical resize 40
|
||||
normal G
|
||||
silent exec "!mkdir -p " .. w:nvimdbg_testdir
|
||||
exec 'terminal ' .. 'testr --exec ' .. w:nvimdbg_exec .. " --testdir " .. w:nvimdbg_testdir
|
||||
exec "norm \<c-w>h"
|
||||
]]
|
||||
end
|
||||
|
||||
keymap("<leader>dt", run_tests)
|
||||
|
||||
|
||||
----------------
|
||||
-- python
|
||||
|
@ -1,102 +0,0 @@
|
||||
" vimspector
|
||||
|
||||
let g:vimspector_sidebar_width = 30
|
||||
let g:vimspector_terminal_maxwidth = 30
|
||||
|
||||
func VimspectorTerminalSetup()
|
||||
endfunc
|
||||
au User VimspectorTerminalOpened call VimspectorTerminalSetup()
|
||||
func VimspectorUISetup()
|
||||
"call win_gotoid(g:vimspector_session_windows.stack_trace)
|
||||
endfunc
|
||||
au User VimspectorUICreated call VimspectorUISetup()
|
||||
|
||||
" compile
|
||||
function Compile()
|
||||
if exists("g:vimspector_session_windows.code")
|
||||
call win_gotoid(g:vimspector_session_windows.code)
|
||||
endif
|
||||
w
|
||||
execute "make ~/.cache/termdebug/bin/" .. expand("%:r") .. " -f ~/.config/nvim/makefile"
|
||||
endfunction
|
||||
nnoremap <silent> <leader>dc :call Compile()<cr>
|
||||
|
||||
" quickfix window (after running make)
|
||||
nnoremap <silent> <leader>dqf :tab cope<cr>
|
||||
nnoremap <silent> <leader>df :tabNext<cr>
|
||||
|
||||
nnoremap <silent> <leader>dd :call vimspector#Launch()<cr>
|
||||
nnoremap <silent> <leader>de :call vimspector#Reset()<cr>
|
||||
|
||||
" write clipboard into input file
|
||||
function WriteInput()
|
||||
let inputfolder=$HOME .. "/.cache/termdebug/input/" .. expand("%:h")
|
||||
silent exec "!mkdir -p " .. inputfolder
|
||||
let inputfile=inputfolder .. "/" .. expand("%:t:r")
|
||||
call writefile(getreg('+', 1, 1), inputfile)
|
||||
" for some reason this line causes a Press Enter to continue
|
||||
"echo "Input written to '" .. inputfile .. "'."
|
||||
endfunction
|
||||
nnoremap <silent> <leader>rw :call WriteInput()<cr>
|
||||
|
||||
" feed from input file into program stdin
|
||||
function RunInput()
|
||||
let l:winid = win_getid()
|
||||
call win_gotoid(g:vimspector_session_windows.code)
|
||||
let l:inputfile=$HOME .. "/.cache/termdebug/input/" .. expand("%:r")
|
||||
let @x = join(readfile(l:inputfile), "\n") .. "\n\n"
|
||||
call win_gotoid(g:vimspector_session_windows.terminal)
|
||||
normal G"xp
|
||||
call win_gotoid(l:winid)
|
||||
endfunction
|
||||
nnoremap <silent> <leader>ri :call RunInput()<cr>
|
||||
|
||||
" use test runner
|
||||
function TestRunner()
|
||||
if expand("%:e") == "cpp"
|
||||
let binary=$HOME .. "/.cache/termdebug/bin/" .. expand("%:r")
|
||||
else
|
||||
let binary=expand("%:p")
|
||||
endif
|
||||
let testfolder=$HOME .. "/.cache/termdebug/tests/" .. expand("%:r")
|
||||
silent exec "!mkdir -p " .. testfolder
|
||||
vsp
|
||||
vertical resize 40
|
||||
normal G
|
||||
exec 'terminal ' .. 'testr --exec ' .. binary .. " --testdir " .. testfolder
|
||||
exec "norm \<c-w>h"
|
||||
endfunction
|
||||
nnoremap <silent> <leader>dt :call TestRunner()<cr>
|
||||
|
||||
" debugging program flow
|
||||
nnoremap <silent> <leader>rs :call vimspector#Restart()<cr>
|
||||
nnoremap <silent> <leader>rr :call vimspector#Stop()<cr>
|
||||
nnoremap <silent> <leader>rf :call vimspector#Continue()<cr>
|
||||
" codelldb breaks if you just restart directly
|
||||
func VimspectorHardRestart()
|
||||
call vimspector#Stop()
|
||||
sleep 100m
|
||||
call vimspector#Restart()
|
||||
endfunc
|
||||
nnoremap <silent> <leader>rt :call VimspectorHardRestart()<cr>
|
||||
|
||||
nnoremap <silent> <c-p> :call vimspector#StepInto()<cr>
|
||||
nnoremap <silent> <c-n> :call vimspector#StepOver()<cr>
|
||||
|
||||
" breakpoints
|
||||
nnoremap <silent> <leader>dsf :call vimspector#ToggleBreakpoint()<cr>
|
||||
nnoremap <silent> <leader>dsF <Plug>VimspectorToggleConditionalBreakpoint
|
||||
nnoremap <silent> <leader>dsc :call vimspector#ClearBreakpoints()<cr>
|
||||
|
||||
" watches
|
||||
au BufEnter vimspector.Watches* nnoremap <silent> <buffer> dd :call vimspector#DeleteWatch()<cr>
|
||||
|
||||
func VimspectorEval()
|
||||
let l:winid = win_getid()
|
||||
normal gv"xy
|
||||
call win_gotoid(g:vimspector_session_windows.output)
|
||||
execute "normal! ip " . @x . "\n\<Esc>"
|
||||
call win_gotoid(l:winid)
|
||||
endfunc
|
||||
vnoremap <silent> K :call VimspectorEval()<cr>
|
||||
nnoremap <silent> K <Plug>VimspectorBalloonEval
|
Loading…
Reference in New Issue
Block a user