summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2019-04-20 15:10:13 +0200
committerBram Moolenaar <Bram@vim.org>2019-04-20 15:10:13 +0200
commitabc7c7fc5a098374f5543a237e6c9dd918848b34 (patch)
treef1716b9f03139e8535a113e20a2f3b05b91f5915
parentd2e716e6dfd50b605867c7c684373384c8edf707 (diff)
patch 8.1.1189: mode is not cleared when leaving Insert modev8.1.1189
Problem: Mode is not cleared when leaving Insert mode. Solution: Clear the mode when got_int is set. (Ozaki Kiichi, closes #4270)
-rw-r--r--src/edit.c2
-rw-r--r--src/testdir/test_bufline.vim2
-rw-r--r--src/testdir/test_messages.vim33
-rw-r--r--src/version.c2
4 files changed, 37 insertions, 2 deletions
diff --git a/src/edit.c b/src/edit.c
index d378cd16f2..43c8a8b63b 100644
--- a/src/edit.c
+++ b/src/edit.c
@@ -4564,7 +4564,7 @@ ins_esc(
*/
if (reg_recording != 0 || restart_edit != NUL)
showmode();
- else if (p_smd && !skip_showmode())
+ else if (p_smd && (got_int || !skip_showmode()))
msg("");
return TRUE; /* exit Insert mode */
diff --git a/src/testdir/test_bufline.vim b/src/testdir/test_bufline.vim
index 524144d5b9..d2d692922c 100644
--- a/src/testdir/test_bufline.vim
+++ b/src/testdir/test_bufline.vim
@@ -18,7 +18,7 @@ func Test_setbufline_getbufline()
let b = bufnr('%')
wincmd w
call assert_equal(1, setbufline(b, 5, ['x']))
- call assert_equal(1, setbufline(1234, 1, ['x']))
+ call assert_equal(1, setbufline(bufnr('$') + 1, 1, ['x']))
call assert_equal(0, setbufline(b, 4, ['d', 'e']))
call assert_equal(['c'], getbufline(b, 3))
call assert_equal(['d'], getbufline(b, 4))
diff --git a/src/testdir/test_messages.vim b/src/testdir/test_messages.vim
index 4bdc1365e1..2d1d6d9b97 100644
--- a/src/testdir/test_messages.vim
+++ b/src/testdir/test_messages.vim
@@ -1,5 +1,7 @@
" Tests for :messages, :echomsg, :echoerr
+source shared.vim
+
function Test_messages()
let oldmore = &more
try
@@ -92,3 +94,34 @@ func Test_echoerr()
call assert_match("function('<lambda>\\d*')", execute(':echoerr {-> 1234}'))
call test_ignore_error('RESET')
endfunc
+
+func Test_mode_message_at_leaving_insert_by_ctrl_c()
+ if !has('terminal') || has('gui_running')
+ return
+ endif
+
+ " Set custom statusline built by user-defined function.
+ let testfile = 'Xtest.vim'
+ call writefile([
+ \ 'func StatusLine() abort',
+ \ ' return ""',
+ \ 'endfunc',
+ \ 'set statusline=%!StatusLine()',
+ \ 'set laststatus=2',
+ \ ], testfile)
+
+ let rows = 10
+ let buf = term_start([GetVimProg(), '--clean', '-S', testfile], {'term_rows': rows})
+ call term_wait(buf, 200)
+ call assert_equal('run', job_status(term_getjob(buf)))
+
+ call term_sendkeys(buf, "i")
+ call WaitForAssert({-> assert_match('^-- INSERT --\s*$', term_getline(buf, rows))})
+ call term_sendkeys(buf, "\<C-C>")
+ call WaitForAssert({-> assert_match('^\s*$', term_getline(buf, rows))})
+
+ call term_sendkeys(buf, ":qall!\<CR>")
+ call WaitForAssert({-> assert_equal('dead', job_status(term_getjob(buf)))})
+ exe buf . 'bwipe!'
+ call delete(testfile)
+endfunc
diff --git a/src/version.c b/src/version.c
index 27614587ff..4e88823a5d 100644
--- a/src/version.c
+++ b/src/version.c
@@ -772,6 +772,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1189,
+/**/
1188,
/**/
1187,