]> granicus.if.org Git - vim/commitdiff
patch 8.1.0030: stoping Vim running in a terminal may not work v8.1.0030
authorBram Moolenaar <Bram@vim.org>
Sun, 3 Jun 2018 15:10:40 +0000 (17:10 +0200)
committerBram Moolenaar <Bram@vim.org>
Sun, 3 Jun 2018 15:10:40 +0000 (17:10 +0200)
Problem:    Stoping Vim running in a terminal may not work.
Solution:   Instead of sending <Esc> send CTRL-O.

src/testdir/screendump.vim
src/testdir/test_prompt_buffer.vim
src/version.c

index 80d51c336d857e005409d757082511e6a4b679fa..58966458a4cd76e3b09a672c3fc50e910bea54cb 100644 (file)
@@ -81,7 +81,11 @@ endfunc
 " Stop a Vim running in terminal buffer "buf".
 func StopVimInTerminal(buf)
   call assert_equal("running", term_getstatus(a:buf))
-  call term_sendkeys(a:buf, "\<Esc>:qa!\<cr>")
+
+  " CTRL-O : works both in Normal mode and Insert mode to start a command line.
+  " In Command-line it's inserted, the CTRL-U removes it again.
+  call term_sendkeys(a:buf, "\<C-O>\<C-U>:qa!\<cr>")
+
   call WaitForAssert({-> assert_equal("finished", term_getstatus(a:buf))})
   only!
 endfunc
index 3a0469da6389a87011e1ce25f8e0be3bec4215e7..f7363d9ad5ac3e5f10ae9dcea6e4a25ff2000345 100644 (file)
@@ -34,9 +34,12 @@ func Test_prompt_basic()
        \ 'func TimerFunc(text)',
        \ '  " Add the output above the current prompt.',
        \ '  call append(line("$") - 1, "Result: \"" . a:text . "\"")',
+       \ '  " Reset &modified to allow the buffer to be closed.',
+       \ '  set nomodified',
        \ 'endfunc',
        \ '',
        \ 'call setline(1, "other buffer")',
+       \ 'set nomodified',
        \ 'new',
        \ 'set buftype=prompt',
        \ 'call prompt_setcallback(bufnr(""), function("TextEntered"))',
index 70fd603354a06715ac706e2b1b9f3c541b1da21a..d13bcfdb5ca5d917745258a19964b892b68c4560 100644 (file)
@@ -761,6 +761,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    30,
 /**/
     29,
 /**/