patch 8.0.1725: terminal debugger doesn't handle command arguments
Problem:    Terminal debugger doesn't handle command arguments.
Solution:   Add the :TermdebugCommand command.  Use a ! to execute right away.
            (Christian Brabandt)
			
			
This commit is contained in:
		| @ -623,7 +623,8 @@ Starting ~ | |||||||
| Load the plugin with this command: > | Load the plugin with this command: > | ||||||
| 	packadd termdebug | 	packadd termdebug | ||||||
| <							*:Termdebug* | <							*:Termdebug* | ||||||
| To start debugging use `:Termdebug` followed by the command name, for example: > | To start debugging use `:Termdebug` or `:TermdebugCommand`` followed by the | ||||||
|  | command name, for example: > | ||||||
| 	:Termdebug vim | 	:Termdebug vim | ||||||
|  |  | ||||||
| This opens two windows: | This opens two windows: | ||||||
| @ -641,7 +642,8 @@ source file location will be displayed, if possible.  A sign is used to | |||||||
| highlight the current position, using highlight group debugPC.	  | highlight the current position, using highlight group debugPC.	  | ||||||
|  |  | ||||||
| If the buffer in the current window is modified, another window will be opened | If the buffer in the current window is modified, another window will be opened | ||||||
| to display the current gdb position. | to display the current gdb position.  You can use `:Winbar` to add a window | ||||||
|  | toolbar there. | ||||||
|  |  | ||||||
| Focus the terminal of the executed program to interact with it.  This works | Focus the terminal of the executed program to interact with it.  This works | ||||||
| the same as any command running in a terminal window. | the same as any command running in a terminal window. | ||||||
| @ -650,12 +652,25 @@ When the debugger ends, typically by typing "quit" in the gdb window, the two | |||||||
| opened windows are closed. | opened windows are closed. | ||||||
|  |  | ||||||
| Only one debugger can be active at a time. | Only one debugger can be active at a time. | ||||||
|  | 							*:TermdebugCommand* | ||||||
|  | If you want to give specific commands to the command being debugged, you can | ||||||
|  | use the `:TermdebugCommand` command followed by the command name and | ||||||
|  | additional parameters. > | ||||||
|  | 	:TermdebugCommand vim --clean -c ':set nu' | ||||||
|  |  | ||||||
| To attach gdb to an already running executable, or use a core file, pass extra | Both the `:Termdebug` and `:TermdebugCommand` support an optional "!" bang | ||||||
|  | argument to start the command right away, without pausing at the gdb window | ||||||
|  | (and cursor will be in the debugged window).  For example: > | ||||||
|  | 	:TermdebugCommand! vim --clean | ||||||
|  |  | ||||||
|  | To attach gdb to an already running executable or use a core file, pass extra | ||||||
| arguments.  E.g.: > | arguments.  E.g.: > | ||||||
| 	:Termdebug vim core | 	:Termdebug vim core | ||||||
| 	:Termdebug vim 98343 | 	:Termdebug vim 98343 | ||||||
|  |  | ||||||
|  | If no argument is given, you'll end up in a gdb window, in which you need to | ||||||
|  | specify which command to run using e.g. the gdb `file` command. | ||||||
|  |  | ||||||
|  |  | ||||||
| Example session ~ | Example session ~ | ||||||
| 							*termdebug-example* | 							*termdebug-example* | ||||||
| @ -728,18 +743,20 @@ Put focus on the gdb window to type commands there.  Some common ones are: | |||||||
| - frame N	go to the Nth stack frame | - frame N	go to the Nth stack frame | ||||||
| - continue	continue execution | - continue	continue execution | ||||||
|  |  | ||||||
| In the window showing the source code these commands can be used to control gdb: | 						*:Run* *:Arguments* | ||||||
|  | In the window showing the source code these commands can be used to control | ||||||
|  | gdb: | ||||||
|  `:Run` [args]	    run the program with [args] or the previous arguments |  `:Run` [args]	    run the program with [args] or the previous arguments | ||||||
|  `:Arguments` {args}  set arguments for the next `:Run` |  `:Arguments` {args}  set arguments for the next `:Run` | ||||||
|  |  | ||||||
|  `:Break`	set a breakpoint at the current line; a sign will be displayed |  *:Break*	set a breakpoint at the current line; a sign will be displayed | ||||||
|  `:Clear`	delete the breakpoint at the current line |  *:Clear*	delete the breakpoint at the current line | ||||||
|  |  | ||||||
|  `:Step`	execute the gdb "step" command |  *:Step*	execute the gdb "step" command | ||||||
|  `:Over`	execute the gdb "next" command (`:Next` is a Vim command) |  *:Over*	execute the gdb "next" command (`:Next` is a Vim command) | ||||||
|  `:Finish`	execute the gdb "finish" command |  *:Finish*	execute the gdb "finish" command | ||||||
|  `:Continue`	execute the gdb "continue" command |  *:Continue*	execute the gdb "continue" command | ||||||
|  `:Stop`	interrupt the program |  *:Stop*	interrupt the program | ||||||
|  |  | ||||||
| If 'mouse' is set the plugin adds a window toolbar with these entries: | If 'mouse' is set the plugin adds a window toolbar with these entries: | ||||||
|   Step		`:Step` |   Step		`:Step` | ||||||
| @ -750,7 +767,7 @@ If 'mouse' is set the plugin adds a window toolbar with these entries: | |||||||
|   Eval		`:Evaluate` |   Eval		`:Evaluate` | ||||||
| This way you can use the mouse to perform the most common commands.  You need | This way you can use the mouse to perform the most common commands.  You need | ||||||
| to have the 'mouse' option set to enable mouse clicks. | to have the 'mouse' option set to enable mouse clicks. | ||||||
|  | 								*:Winbar* | ||||||
| You can add the window toolbar in other windows you open with: > | You can add the window toolbar in other windows you open with: > | ||||||
|   :Winbar |   :Winbar | ||||||
|  |  | ||||||
| @ -761,7 +778,7 @@ abandoned. | |||||||
|  |  | ||||||
|  |  | ||||||
| Inspecting variables ~ | Inspecting variables ~ | ||||||
| 							*termdebug-variables* | 					*termdebug-variables* *:Evaluate* | ||||||
|  `:Evaluate`	    evaluate the expression under the cursor |  `:Evaluate`	    evaluate the expression under the cursor | ||||||
|  `K`		    same |  `K`		    same | ||||||
|  `:Evaluate` {expr}   evaluate {expr} |  `:Evaluate` {expr}   evaluate {expr} | ||||||
| @ -773,9 +790,9 @@ You can usually shorten `:Evaluate` to `:Ev`. | |||||||
|  |  | ||||||
| Other commands ~ | Other commands ~ | ||||||
| 							*termdebug-commands* | 							*termdebug-commands* | ||||||
|  :Gdb	     jump to the gdb window |  *:Gdb*	     jump to the gdb window | ||||||
|  :Program    jump to the window with the running program |  *:Program*    jump to the window with the running program | ||||||
|  :Source     jump to the window with the source code, create it if there |  *:Source*     jump to the window with the source code, create it if there | ||||||
| 	     isn't one | 	     isn't one | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -25,7 +25,8 @@ endif | |||||||
|  |  | ||||||
| " The command that starts debugging, e.g. ":Termdebug vim". | " The command that starts debugging, e.g. ":Termdebug vim". | ||||||
| " To end type "quit" in the gdb window. | " To end type "quit" in the gdb window. | ||||||
| command -nargs=* -complete=file Termdebug call s:StartDebug(<f-args>) | command -nargs=* -complete=file -bang Termdebug call s:StartDebug(<bang>0, <f-args>) | ||||||
|  | command -nargs=+ -complete=file -bang TermdebugCommand call s:StartDebugCommand(<bang>0, <f-args>) | ||||||
|  |  | ||||||
| " Name of the gdb command, defaults to "gdb". | " Name of the gdb command, defaults to "gdb". | ||||||
| if !exists('termdebugger') | if !exists('termdebugger') | ||||||
| @ -43,7 +44,17 @@ else | |||||||
| endif | endif | ||||||
| hi default debugBreakpoint term=reverse ctermbg=red guibg=red | hi default debugBreakpoint term=reverse ctermbg=red guibg=red | ||||||
|  |  | ||||||
| func s:StartDebug(...) | func s:StartDebug(bang, ...) | ||||||
|  |   " First argument is the command to debug, second core file or process ID. | ||||||
|  |   call s:StartDebug_internal({'gdb_args': a:000, 'bang': a:bang}) | ||||||
|  | endfunc | ||||||
|  |  | ||||||
|  | func s:StartDebugCommand(bang, ...) | ||||||
|  |   " First argument is the command to debug, rest are run arguments. | ||||||
|  |   call s:StartDebug_internal({'gdb_args': [a:1], 'proc_args': a:000[1:], 'bang': a:bang}) | ||||||
|  | endfunc | ||||||
|  |  | ||||||
|  | func s:StartDebug_internal(dict) | ||||||
|   if exists('s:gdbwin') |   if exists('s:gdbwin') | ||||||
|     echoerr 'Terminal debugger already running' |     echoerr 'Terminal debugger already running' | ||||||
|     return |     return | ||||||
| @ -95,7 +106,10 @@ func s:StartDebug(...) | |||||||
|  |  | ||||||
|   " Open a terminal window to run the debugger. |   " Open a terminal window to run the debugger. | ||||||
|   " Add -quiet to avoid the intro message causing a hit-enter prompt. |   " Add -quiet to avoid the intro message causing a hit-enter prompt. | ||||||
|   let cmd = [g:termdebugger, '-quiet', '-tty', pty] + a:000 |   let gdb_args = get(a:dict, 'gdb_args', []) | ||||||
|  |   let proc_args = get(a:dict, 'proc_args', []) | ||||||
|  |  | ||||||
|  |   let cmd = [g:termdebugger, '-quiet', '-tty', pty] + gdb_args | ||||||
|   echomsg 'executing "' . join(cmd) . '"' |   echomsg 'executing "' . join(cmd) . '"' | ||||||
|   let s:gdbbuf = term_start(cmd, { |   let s:gdbbuf = term_start(cmd, { | ||||||
| 	\ 'exit_cb': function('s:EndDebug'), | 	\ 'exit_cb': function('s:EndDebug'), | ||||||
| @ -109,6 +123,11 @@ func s:StartDebug(...) | |||||||
|   endif |   endif | ||||||
|   let s:gdbwin = win_getid(winnr()) |   let s:gdbwin = win_getid(winnr()) | ||||||
|  |  | ||||||
|  |   " Set arguments to be run | ||||||
|  |   if len(proc_args) | ||||||
|  |     call term_sendkeys(s:gdbbuf, 'set args ' . join(proc_args) . "\r") | ||||||
|  |   endif | ||||||
|  |  | ||||||
|   " Connect gdb to the communication pty, using the GDB/MI interface |   " Connect gdb to the communication pty, using the GDB/MI interface | ||||||
|   call term_sendkeys(s:gdbbuf, 'new-ui mi ' . commpty . "\r") |   call term_sendkeys(s:gdbbuf, 'new-ui mi ' . commpty . "\r") | ||||||
|  |  | ||||||
| @ -182,6 +201,14 @@ func s:StartDebug(...) | |||||||
|     au BufRead * call s:BufRead() |     au BufRead * call s:BufRead() | ||||||
|     au BufUnload * call s:BufUnloaded() |     au BufUnload * call s:BufUnloaded() | ||||||
|   augroup END |   augroup END | ||||||
|  |  | ||||||
|  |   " Run the command if the bang attribute was given | ||||||
|  |   " and got to the window | ||||||
|  |   if get(a:dict, 'bang', 0) | ||||||
|  |     call s:SendCommand('-exec-run') | ||||||
|  |     call win_gotoid(s:ptywin) | ||||||
|  |   endif | ||||||
|  |  | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
| func s:EndDebug(job, status) | func s:EndDebug(job, status) | ||||||
|  | |||||||
| @ -762,6 +762,8 @@ static char *(features[]) = | |||||||
|  |  | ||||||
| static int included_patches[] = | static int included_patches[] = | ||||||
| {   /* Add new patch number below this line */ | {   /* Add new patch number below this line */ | ||||||
|  | /**/ | ||||||
|  |     1725, | ||||||
| /**/ | /**/ | ||||||
|     1724, |     1724, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user