vim-patch:3d3a9152fa6d

runtime(termdebug): more termdebug fixes and improvements (vim/vim#12892)

- Fix and attempt to simplify :Frame/:Up/:Down documentation.

- Accept a count instead for :Up/:Down/+/-.

- Update the "Last Change" dates.

- Fix a missing :let (caused an error if gdb fails to start).

- Wipe the prompt buffer when ending prompt mode (if it exists and wasn't wiped
  by the user first). Avoids issues with stale prompt buffers (such as E95 when
  starting a new prompt mode session).

- Kill the gdb job if the prompt buffer is unloaded (similar to what's done for
  a terminal buffer). Fixes not being able to start a new termdebug session if
  the buffer was wiped by the user, for example.

3d3a9152fa
This commit is contained in:
Sean Dewar
2023-08-23 17:41:21 +01:00
parent 92ef2b2bcd
commit e3b385bed5
2 changed files with 28 additions and 44 deletions

View File

@@ -317,20 +317,17 @@ This is similar to using "print" in the gdb window.
You can usually shorten `:Evaluate` to `:Ev`. You can usually shorten `:Evaluate` to `:Ev`.
Navigation in the Stack ~ Navigating stack frames ~
*termdebug-variables* *:Frame* *termdebug-frames* *:Frame* *:Up* *:Down*
`:Frame` Select the given frame, using either the frame's `:Frame` [frame] select frame [frame], which is a frame number,
stack number, address, or function name. address, or function name (default: current frame)
`:Up` Select the frame that called the current one with an `:Up` [count] go up [count] frames (default: 1; the frame that
optional argument to say how many frames to go up. called the current)
`+` same (see |termdebug_map_plus| to disable) `+` same (see |termdebug_map_plus| to disable)
`:Down` Select the frame called by the current one with `:Down` [count] go down [count] frames (default: 1; the frame called
an optional argument to say how many frames to go down. by the current)
`-` same (see |termdebug_map_minus| to disable) `-` same (see |termdebug_map_minus| to disable)
This is similar to using "print" in the gdb window.
You can usually shorten `:Evaluate` to `:Ev`.
Other commands ~ Other commands ~
*termdebug-commands* *termdebug-commands*
@@ -403,17 +400,17 @@ If there is no g:termdebug_config you can use: >vim
let g:termdebug_use_prompt = 1 let g:termdebug_use_prompt = 1
< <
*termdebug_map_K* *termdebug_map_K*
The K key is normally mapped to :Evaluate. If you do not want this use: >vim The K key is normally mapped to |:Evaluate|. If you do not want this use: >vim
let g:termdebug_config['map_K'] = 0 let g:termdebug_config['map_K'] = 0
If there is no g:termdebug_config you can use: >vim If there is no g:termdebug_config you can use: >vim
let g:termdebug_map_K = 0 let g:termdebug_map_K = 0
< <
*termdebug_map_minus* *termdebug_map_minus*
The - key is normally mapped to :Down. If you do not want this use: >vim The - key is normally mapped to |:Down|. If you do not want this use: >vim
let g:termdebug_config['map_minus'] = 0 let g:termdebug_config['map_minus'] = 0
< <
*termdebug_map_plus* *termdebug_map_plus*
The + key is normally mapped to :Up. If you do not want this use: >vim The + key is normally mapped to |:Up|. If you do not want this use: >vim
let g:termdebug_config['map_plus'] = 0 let g:termdebug_config['map_plus'] = 0
< <
*termdebug_disasm_window* *termdebug_disasm_window*

View File

@@ -2,7 +2,7 @@
" "
" Author: Bram Moolenaar " Author: Bram Moolenaar
" Copyright: Vim license applies, see ":help license" " Copyright: Vim license applies, see ":help license"
" Last Change: 2023 Jun 24 " Last Change: 2023 Aug 23
" "
" WORK IN PROGRESS - The basics works stable, more to come " WORK IN PROGRESS - The basics works stable, more to come
" Note: In general you need at least GDB 7.12 because this provides the " Note: In general you need at least GDB 7.12 because this provides the
@@ -240,7 +240,7 @@ func s:CloseBuffers()
if s:varbuf > 0 && bufexists(s:varbuf) if s:varbuf > 0 && bufexists(s:varbuf)
exe 'bwipe! ' . s:varbuf exe 'bwipe! ' . s:varbuf
endif endif
s:running = 0 let s:running = 0
unlet! s:gdbwin unlet! s:gdbwin
endfunc endfunc
@@ -476,6 +476,7 @@ func s:StartDebug_prompt(dict)
call s:CloseBuffers() call s:CloseBuffers()
return return
endif endif
exe $'au BufUnload <buffer={s:promptbuf}> ++once call jobstop(s:gdbjob)'
let s:ptybuf = 0 let s:ptybuf = 0
if has('win32') if has('win32')
@@ -819,12 +820,8 @@ func s:EndPromptDebug(job_id, exit_code, event)
doauto <nomodeline> User TermdebugStopPre doauto <nomodeline> User TermdebugStopPre
endif endif
let curwinid = win_getid() if bufexists(s:promptbuf)
call win_gotoid(s:gdbwin) exe 'bwipe! ' . s:promptbuf
set nomodified
close
if curwinid != s:gdbwin
call win_gotoid(curwinid)
endif endif
call s:EndDebugCommon() call s:EndDebugCommon()
@@ -1006,8 +1003,8 @@ func s:InstallCommands()
endif endif
command -nargs=* Frame call s:Frame(<q-args>) command -nargs=* Frame call s:Frame(<q-args>)
command -nargs=* Up call s:Up(<q-args>) command -count=1 Up call s:Up(<count>)
command -nargs=* Down call s:Down(<q-args>) command -count=1 Down call s:Down(<count>)
command -range -nargs=* Evaluate call s:Evaluate(<range>, <q-args>) command -range -nargs=* Evaluate call s:Evaluate(<range>, <q-args>)
command Gdb call win_gotoid(s:gdbwin) command Gdb call win_gotoid(s:gdbwin)
@@ -1034,7 +1031,7 @@ func s:InstallCommands()
endif endif
if map if map
let s:plus_map_saved = maparg('+', 'n', 0, 1) let s:plus_map_saved = maparg('+', 'n', 0, 1)
nnoremap + :Up<CR> nnoremap <expr> + $'<Cmd>{v:count1}Up<CR>'
endif endif
let map = 1 let map = 1
@@ -1043,7 +1040,7 @@ func s:InstallCommands()
endif endif
if map if map
let s:minus_map_saved = maparg('-', 'n', 0, 1) let s:minus_map_saved = maparg('-', 'n', 0, 1)
nnoremap - :Down<CR> nnoremap <expr> - $'<Cmd>{v:count1}Down<CR>'
endif endif
@@ -1270,26 +1267,16 @@ func s:Frame(arg)
endif endif
endfunc endfunc
" :Up - go one frame in the stack "higher" " :Up - go a:count frames in the stack "higher"
func s:Up(arg) func s:Up(count)
if a:arg != ''
let s:cmd = '"up ' . a:arg . '"'
else
let s:cmd = '"up"'
endif
" the 'correct' one would be -stack-select-frame N, but we don't know N " the 'correct' one would be -stack-select-frame N, but we don't know N
call s:SendCommand('-interpreter-exec console ' . s:cmd) call s:SendCommand($'-interpreter-exec console "up {a:count}"')
endfunc endfunc
" :Down - go one frame in the stack "below" " :Down - go a:count frames in the stack "below"
func s:Down(arg) func s:Down(count)
if a:arg != ''
let s:cmd = '"down ' . a:arg . '"'
else
let s:cmd = '"down"'
endif
" the 'correct' one would be -stack-select-frame N, but we don't know N " the 'correct' one would be -stack-select-frame N, but we don't know N
call s:SendCommand('-interpreter-exec console ' . s:cmd) call s:SendCommand($'-interpreter-exec console "down {a:count}"')
endfunc endfunc
func s:SendEval(expr) func s:SendEval(expr)