patch 9.1.0145: v:echospace not correct when 'showcmdloc' != last

Commit: 
https://github.com/vim/vim/commit/062141b1a70cf5364e6983ec901282e0111745c1
Author: Sam-programs <[email protected]>
Date:   Thu Feb 29 17:40:29 2024 +0100

    patch 9.1.0145: v:echospace not correct when 'showcmdloc' != last
    
    Problem:  the amount of available space (v:echospace) on the command
              line is not correct when showcmdloc is drawn into the
              statusline or tabline.
    Solution: only add SHOWCMD_COLS to the shown command column when
              'showcmdloc' is set to last (Sam-programs)
    
    closes: #14108
    
    Co-authored-by: zeertzjq <[email protected]>
    Signed-off-by: Sam-programs 
<[email protected]>
    Signed-off-by: Christian Brabandt <[email protected]>

diff --git a/src/optionstr.c b/src/optionstr.c
index 7f6225fd2..771423c64 100644
--- a/src/optionstr.c
+++ b/src/optionstr.c
@@ -3440,6 +3440,7 @@ did_set_showbreak(optset_T *args)
     char *
 did_set_showcmdloc(optset_T *args UNUSED)
 {
+    comp_col();
     return did_set_opt_strings(p_sloc, p_sloc_values, FALSE);
 }
 
diff --git a/src/screen.c b/src/screen.c
index 939a33599..208b18254 100644
--- a/src/screen.c
+++ b/src/screen.c
@@ -4536,7 +4536,7 @@ comp_col(void)
        if (!last_has_status)
            sc_col = ru_col;
     }
-    if (p_sc)
+    if (p_sc && *p_sloc == 'l')
     {
        sc_col += SHOWCMD_COLS;
        if (!p_ru || last_has_status)       // no need for separating space
diff --git a/src/testdir/test_messages.vim b/src/testdir/test_messages.vim
index 48f1bab45..8d0a42280 100644
--- a/src/testdir/test_messages.vim
+++ b/src/testdir/test_messages.vim
@@ -162,8 +162,12 @@ func Test_echospace()
   call assert_equal(&columns - 12, v:echospace)
   set showcmd ruler
   call assert_equal(&columns - 29, v:echospace)
+  set showcmdloc=statusline
+  call assert_equal(&columns - 19, v:echospace)
+  set showcmdloc=tabline
+  call assert_equal(&columns - 19, v:echospace)
 
-  set ruler& showcmd&
+  set ruler& showcmd& showcmdloc&
 endfunc
 
 func Test_warning_scroll()
diff --git a/src/version.c b/src/version.c
index a17f3271e..5842f46d5 100644
--- a/src/version.c
+++ b/src/version.c
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    145,
 /**/
     144,
 /**/

-- 
-- 
You received this message from the "vim_dev" maillist.
Do not top-post! Type your reply below the text you are replying to.
For more information, visit http://www.vim.org/maillist.php

--- 
You received this message because you are subscribed to the Google Groups 
"vim_dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
To view this discussion on the web visit 
https://groups.google.com/d/msgid/vim_dev/E1rfjlM-0095GL-CC%40256bit.org.

Raspunde prin e-mail lui