]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.0.2133: Cannot detect overstrike mode in Cmdline mode v9.0.2133
authorSam-programs <None>
Mon, 27 Nov 2023 21:22:51 +0000 (22:22 +0100)
committerChristian Brabandt <cb@256bit.org>
Mon, 27 Nov 2023 21:22:51 +0000 (22:22 +0100)
Problem:  Cannot detect overstrike mode in Cmdline mode
Solution: Make mode() return "cr" for overstrike

closes: #13569

Signed-off-by: Sam-programs <None>
Signed-off-by: Christian Brabandt <cb@256bit.org>
runtime/doc/builtin.txt
src/ex_getln.c
src/misc1.c
src/testdir/dumps/Test_mode_1.dump [new file with mode: 0644]
src/testdir/dumps/Test_mode_2.dump [new file with mode: 0644]
src/testdir/test_functions.vim
src/version.c

index 96d7a0dd334cc6cbb8e65f336091595c4fd2c2c0..f7cc8f88a493022058d51ae0e93db943e1fe75b1 100644 (file)
@@ -6413,7 +6413,9 @@ mode([expr])      Return a string that indicates the current mode.
                   Rvx      Virtual Replace mode |i_CTRL-X| completion
                   c        Command-line editing
                   ct       Command-line editing via Terminal-Job mode
+                  cr       Command-line while in overstrike mode |c_<Insert>|
                   cv       Vim Ex mode |gQ|
+                  cvr      Vim Ex while in overstrike mode |c_<Insert>|
                   ce       Normal Ex mode |Q|
                   r        Hit-enter prompt
                   rm       The -- more -- prompt
index 8f0be520886bed3f59b62b2fa5c305541e024a31..52f4feb3f084c6bcacc1c1a325b6936fb5774006 100644 (file)
@@ -2050,6 +2050,9 @@ getcmdline_int(
 #ifdef CURSOR_SHAPE
                ui_cursor_shape();      // may show different cursor shape
 #endif
+               may_trigger_modechanged();
+               status_redraw_curbuf();
+               redraw_statuslines();
                goto cmdline_not_changed;
 
        case Ctrl_HAT:
@@ -3169,8 +3172,6 @@ redraw:
     return (char_u *)line_ga.ga_data;
 }
 
-# if defined(MCH_CURSOR_SHAPE) || defined(FEAT_GUI) \
-       || defined(FEAT_MOUSESHAPE) || defined(PROTO)
 /*
  * Return TRUE if ccline.overstrike is on.
  */
@@ -3180,6 +3181,8 @@ cmdline_overstrike(void)
     return ccline.overstrike;
 }
 
+# if defined(MCH_CURSOR_SHAPE) || defined(FEAT_GUI) \
+        || defined(FEAT_MOUSESHAPE) || defined(PROTO)
 /*
  * Return TRUE if the cursor is at the end of the cmdline.
  */
index a82ef9cd93d594c4bbf19437b7fe0a1afdcff86e..e83ec66f7068820e836b03b5dd226f45b031b280 100644 (file)
@@ -720,6 +720,8 @@ get_mode(char_u *buf)
            buf[i++] = 'v';
        else if (exmode_active == EXMODE_NORMAL)
            buf[i++] = 'e';
+       if ((State & MODE_CMDLINE) && cmdline_overstrike())
+           buf[i++] = 'r';
     }
     else
     {
diff --git a/src/testdir/dumps/Test_mode_1.dump b/src/testdir/dumps/Test_mode_1.dump
new file mode 100644 (file)
index 0000000..866ffd5
--- /dev/null
@@ -0,0 +1,12 @@
+| +0&#ffffff0@74
+|~+0#4040ff13&| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|c+3#0000000&| @73
+|:+0&&> @73
diff --git a/src/testdir/dumps/Test_mode_2.dump b/src/testdir/dumps/Test_mode_2.dump
new file mode 100644 (file)
index 0000000..6cbfe2b
--- /dev/null
@@ -0,0 +1,12 @@
+| +0&#ffffff0@74
+|~+0#4040ff13&| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|c+3#0000000&|r| @72
+|:+0&&> @73
index 0801d2b695b768c01b5807275635f9583ec11494..4cde9e40d615a7fb267019b7b8de24f0f30e57a5 100644 (file)
@@ -916,8 +916,12 @@ func Test_mode()
 
   call feedkeys(":echo \<C-R>=Save_mode()\<C-U>\<CR>", 'xt')
   call assert_equal('c-c', g:current_modes)
+  call feedkeys(":\<insert>\<C-r>=Save_mode()\<CR>",'xt')
+  call assert_equal("c-cr", g:current_modes)
   call feedkeys("gQecho \<C-R>=Save_mode()\<CR>\<CR>vi\<CR>", 'xt')
   call assert_equal('c-cv', g:current_modes)
+  call feedkeys("gQ\<insert>\<C-r>=Save_mode()\<CR>",'xt')
+  call assert_equal("c-cvr", g:current_modes)
   call feedkeys("Qcall Save_mode()\<CR>vi\<CR>", 'xt')
   call assert_equal('c-ce', g:current_modes)
   " How to test Ex mode?
@@ -935,6 +939,18 @@ func Test_mode()
   call assert_equal('n-niR', g:current_modes)
   execute "normal! gR\<C-o>g@l\<Esc>"
   call assert_equal('n-niV', g:current_modes)
+  " Test statusline updates for overstike mode
+  if CanRunVimInTerminal()
+    let buf = RunVimInTerminal('', {'rows': 12})
+    call term_sendkeys(buf, ":set laststatus=2 statusline=%!mode(1)\<CR>")
+    call term_sendkeys(buf, ":")
+    call TermWait(buf)
+    call VerifyScreenDump(buf, 'Test_mode_1', {})
+    call term_sendkeys(buf, "\<insert>")
+    call TermWait(buf)
+    call VerifyScreenDump(buf, 'Test_mode_2', {})
+    call StopVimInTerminal(buf)
+  endif
 
   if has('terminal')
     term
index e5cb3c26126c9e9d4d3350b73e5a7fad92dbc6a9..4a7cf7d3923451f9e2ba884b1df7d272db9f859d 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    2133,
 /**/
     2132,
 /**/