diff options
author | Sam Bingner <sam@bingner.com> | 2018-08-03 15:06:38 -1000 |
---|---|---|
committer | Sam Bingner <sam@bingner.com> | 2018-08-03 15:06:38 -1000 |
commit | 135b410607f008d3709a7b1374f3f37924eb9fe4 (patch) | |
tree | f4756ef3a354f6001360db894db010df85177f76 /data/vim/patches/8.1.0091 | |
parent | bd1eb51da0d3f250793e1868d73babdf495c921f (diff) |
Update vim
Diffstat (limited to 'data/vim/patches/8.1.0091')
-rw-r--r-- | data/vim/patches/8.1.0091 | 369 |
1 files changed, 369 insertions, 0 deletions
diff --git a/data/vim/patches/8.1.0091 b/data/vim/patches/8.1.0091 new file mode 100644 index 000000000..2888abf73 --- /dev/null +++ b/data/vim/patches/8.1.0091 @@ -0,0 +1,369 @@ +To: vim_dev@googlegroups.com +Subject: Patch 8.1.0091 +Fcc: outbox +From: Bram Moolenaar <Bram@moolenaar.net> +Mime-Version: 1.0 +Content-Type: text/plain; charset=UTF-8 +Content-Transfer-Encoding: 8bit +------------ + +Patch 8.1.0091 +Problem: MS-Windows: Cannot interrupt gdb when program is running. +Solution: Add debugbreak() and use it in the terminal debugger. + Respect 'modified' in a prompt buffer. +Files: src/evalfunc.c, runtime/doc/eval.txt, src/undo.c, + runtime/pack/dist/opt/termdebug/plugin/termdebug.vim + + +*** ../vim-8.1.0090/src/evalfunc.c 2018-06-17 19:36:30.215317108 +0200 +--- src/evalfunc.c 2018-06-20 21:37:04.384279452 +0200 +*************** +*** 123,128 **** +--- 123,131 ---- + static void f_count(typval_T *argvars, typval_T *rettv); + static void f_cscope_connection(typval_T *argvars, typval_T *rettv); + static void f_cursor(typval_T *argsvars, typval_T *rettv); ++ #ifdef WIN3264 ++ static void f_debugbreak(typval_T *argvars, typval_T *rettv); ++ #endif + static void f_deepcopy(typval_T *argvars, typval_T *rettv); + static void f_delete(typval_T *argvars, typval_T *rettv); + static void f_deletebufline(typval_T *argvars, typval_T *rettv); +*************** +*** 577,582 **** +--- 580,588 ---- + {"count", 2, 4, f_count}, + {"cscope_connection",0,3, f_cscope_connection}, + {"cursor", 1, 3, f_cursor}, ++ #ifdef WIN3264 ++ {"debugbreak", 1, 1, f_debugbreak}, ++ #endif + {"deepcopy", 1, 2, f_deepcopy}, + {"delete", 1, 2, f_delete}, + {"deletebufline", 2, 3, f_deletebufline}, +*************** +*** 2761,2766 **** +--- 2767,2799 ---- + rettv->vval.v_number = 0; + } + ++ #ifdef WIN3264 ++ /* ++ * "debugbreak()" function ++ */ ++ static void ++ f_debugbreak(typval_T *argvars, typval_T *rettv) ++ { ++ int pid; ++ ++ rettv->vval.v_number = FAIL; ++ pid = (int)get_tv_number(&argvars[0]); ++ if (pid == 0) ++ EMSG(_(e_invarg)); ++ else ++ { ++ HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, 0, pid); ++ ++ if (hProcess != NULL) ++ { ++ DebugBreakProcess(hProcess); ++ CloseHandle(hProcess); ++ rettv->vval.v_number = OK; ++ } ++ } ++ } ++ #endif ++ + /* + * "deepcopy()" function + */ +*** ../vim-8.1.0090/runtime/doc/eval.txt 2018-06-17 19:36:30.211317130 +0200 +--- runtime/doc/eval.txt 2018-06-20 20:49:26.069391126 +0200 +*************** +*** 2108,2113 **** +--- 2108,2114 ---- + cursor({lnum}, {col} [, {off}]) + Number move cursor to {lnum}, {col}, {off} + cursor({list}) Number move cursor to position in {list} ++ debugbreak({pid}) Number interrupt process being debugged + deepcopy({expr} [, {noref}]) any make a full copy of {expr} + delete({fname} [, {flags}]) Number delete the file or directory {fname} + deletebufline({expr}, {first}[, {last}]) +*************** +*** 3480,3485 **** +--- 3481,3491 ---- + position within a <Tab> or after the last character. + Returns 0 when the position could be set, -1 otherwise. + ++ debugbreak({pid}) *debugbreak()* ++ Specifically used to interrupt a program being debugged. It ++ will cause process {pid} to get a SIGTRAP. Behavior for other ++ processes is undefined. See |terminal-debugger|. ++ {only available on MS-Windows} + + deepcopy({expr} [, {noref}]) *deepcopy()* *E698* + Make a copy of {expr}. For Numbers and Strings this isn't +*************** +*** 5488,5493 **** +--- 5494,5513 ---- + The returned Job object can be used to get the status with + |job_status()| and stop the job with |job_stop()|. + ++ Note that the job object will be deleted if there are no ++ references to it. This closes the stdin and stderr, which may ++ cause the job to fail with an error. To avoid this keep a ++ reference to the job. Thus instead of: > ++ call job_start('my-command') ++ < use: > ++ let myjob = job_start('my-command') ++ < and unlet "myjob" once the job is not needed or is past the ++ point where it would fail (e.g. when it prints a message on ++ startup). Keep in mind that variables local to a function ++ will cease to exist if the function returns. Use a ++ script-local variable if needed: > ++ let s:myjob = job_start('my-command') ++ < + {options} must be a Dictionary. It can contain many optional + items, see |job-options|. + +*** ../vim-8.1.0090/src/undo.c 2018-04-08 12:53:24.000000000 +0200 +--- src/undo.c 2018-06-20 22:01:18.595276435 +0200 +*************** +*** 3539,3545 **** + int + bufIsChangedNotTerm(buf_T *buf) + { +! return !bt_dontwrite(buf) + && (buf->b_changed || file_ff_differs(buf, TRUE)); + } + +--- 3539,3547 ---- + int + bufIsChangedNotTerm(buf_T *buf) + { +! // In a "prompt" buffer we do respect 'modified', so that we can control +! // closing the window by setting or resetting that option. +! return (!bt_dontwrite(buf) || bt_prompt(buf)) + && (buf->b_changed || file_ff_differs(buf, TRUE)); + } + +*** ../vim-8.1.0090/runtime/pack/dist/opt/termdebug/plugin/termdebug.vim 2018-06-19 22:34:39.608993263 +0200 +--- runtime/pack/dist/opt/termdebug/plugin/termdebug.vim 2018-06-20 22:35:22.126433823 +0200 +*************** +*** 98,103 **** +--- 98,104 ---- + return + endif + let s:ptywin = 0 ++ let s:pid = 0 + + " Uncomment this line to write logging in "debuglog". + " call ch_logfile('debuglog', 'w') +*************** +*** 271,276 **** +--- 272,279 ---- + exe 'bwipe! ' . s:promptbuf + return + endif ++ " Mark the buffer modified so that it's not easy to close. ++ set modified + let s:gdb_channel = job_getchannel(s:gdbjob) + + " Interpret commands while the target is running. This should usualy only +*************** +*** 396,405 **** + call s:SendCommand(a:text) + endfunc + +! " Function called when pressing CTRL-C in the prompt buffer. + func s:PromptInterrupt() +! call ch_log('Interrupting gdb') +! call job_stop(s:gdbjob, 'int') + endfunc + + " Function called when gdb outputs text. +--- 399,414 ---- + call s:SendCommand(a:text) + endfunc + +! " Function called when pressing CTRL-C in the prompt buffer and when placing a +! " breakpoint. + func s:PromptInterrupt() +! if s:pid == 0 +! echoerr 'Cannot interrupt gdb, did not find a process ID' +! else +! call ch_log('Interrupting gdb') +! " Using job_stop(s:gdbjob, 'int') does not work. +! call debugbreak(s:pid) +! endif + endfunc + + " Function called when gdb outputs text. +*************** +*** 430,436 **** + + " Add the output above the current prompt. + call append(line('$') - 1, text) +! set nomodified + + call win_gotoid(curwinid) + endfunc +--- 439,445 ---- + + " Add the output above the current prompt. + call append(line('$') - 1, text) +! set modified + + call win_gotoid(curwinid) + endfunc +*************** +*** 509,514 **** +--- 518,524 ---- + func s:EndPromptDebug(job, status) + let curwinid = win_getid(winnr()) + call win_gotoid(s:gdbwin) ++ set nomodified + close + if curwinid != s:gdbwin + call win_gotoid(curwinid) +*************** +*** 535,540 **** +--- 545,552 ---- + call s:HandleNewBreakpoint(msg) + elseif msg =~ '^=breakpoint-deleted,' + call s:HandleBreakpointDelete(msg) ++ elseif msg =~ '^=thread-group-started' ++ call s:HandleProgramRun(msg) + elseif msg =~ '^\^done,value=' + call s:HandleEvaluate(msg) + elseif msg =~ '^\^error,msg=' +*************** +*** 655,661 **** + for val in s:BreakpointSigns + exe "sign undefine debugBreakpoint" . val + endfor +! unlet s:BreakpointSigns + endfunc + + " :Break - Set a breakpoint at the cursor position. +--- 667,673 ---- + for val in s:BreakpointSigns + exe "sign undefine debugBreakpoint" . val + endfor +! let s:BreakpointSigns = [] + endfunc + + " :Break - Set a breakpoint at the cursor position. +*************** +*** 666,674 **** + if !s:stopped + let do_continue = 1 + if s:way == 'prompt' +! " Need to send a signal to get the UI to listen. Strangely this is only +! " needed once. +! call job_stop(s:gdbjob, 'int') + else + call s:SendCommand('-exec-interrupt') + endif +--- 678,684 ---- + if !s:stopped + let do_continue = 1 + if s:way == 'prompt' +! call s:PromptInterrupt() + else + call s:SendCommand('-exec-interrupt') + endif +*************** +*** 798,810 **** + let wid = win_getid(winnr()) + + if a:msg =~ '^\*stopped' + let s:stopped = 1 + elseif a:msg =~ '^\*running' + let s:stopped = 0 + endif + +- call s:GotoSourcewinOrCreateIt() +- + if a:msg =~ 'fullname=' + let fname = s:GetFullname(a:msg) + else +--- 808,820 ---- + let wid = win_getid(winnr()) + + if a:msg =~ '^\*stopped' ++ call ch_log('program stopped') + let s:stopped = 1 + elseif a:msg =~ '^\*running' ++ call ch_log('program running') + let s:stopped = 0 + endif + + if a:msg =~ 'fullname=' + let fname = s:GetFullname(a:msg) + else +*************** +*** 813,818 **** +--- 823,829 ---- + if a:msg =~ '^\(\*stopped\|=thread-selected\)' && filereadable(fname) + let lnum = substitute(a:msg, '.*line="\([^"]*\)".*', '\1', '') + if lnum =~ '^[0-9]*$' ++ call s:GotoSourcewinOrCreateIt() + if expand('%:p') != fnamemodify(fname, ':p') + if &modified + " TODO: find existing window +*************** +*** 828,834 **** + exe 'sign place ' . s:pc_id . ' line=' . lnum . ' name=debugPC file=' . fname + setlocal signcolumn=yes + endif +! else + exe 'sign unplace ' . s:pc_id + endif + +--- 839,845 ---- + exe 'sign place ' . s:pc_id . ' line=' . lnum . ' name=debugPC file=' . fname + setlocal signcolumn=yes + endif +! elseif !s:stopped || fname != '' + exe 'sign unplace ' . s:pc_id + endif + +*************** +*** 892,897 **** +--- 903,919 ---- + endif + endfunc + ++ " Handle the debugged program starting to run. ++ " Will store the process ID in s:pid ++ func s:HandleProgramRun(msg) ++ let nr = substitute(a:msg, '.*pid="\([0-9]*\)\".*', '\1', '') + 0 ++ if nr == 0 ++ return ++ endif ++ let s:pid = nr ++ call ch_log('Detected process ID: ' . s:pid) ++ endfunc ++ + " Handle a BufRead autocommand event: place any signs. + func s:BufRead() + let fname = expand('<afile>:p') +*** ../vim-8.1.0090/src/version.c 2018-06-20 20:37:32.469561678 +0200 +--- src/version.c 2018-06-20 20:50:45.560821218 +0200 +*************** +*** 763,764 **** +--- 763,766 ---- + { /* Add new patch number below this line */ ++ /**/ ++ 91, + /**/ + +-- +From "know your smileys": + :q vi user saying, "How do I get out of this damn emacs editor?" + + /// Bram Moolenaar -- Bram@Moolenaar.net -- http://www.Moolenaar.net \\\ +/// sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\ +\\\ an exciting new programming language -- http://www.Zimbu.org /// + \\\ help me help AIDS victims -- http://ICCF-Holland.org /// |