summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSam-programs <130783534+Sam-programs@users.noreply.github.com>2024-02-29 17:40:29 +0100
committerChristian Brabandt <cb@256bit.org>2024-02-29 17:40:29 +0100
commit062141b1a70cf5364e6983ec901282e0111745c1 (patch)
tree91c31448bb213ca46b554e2b9e50931848f20dbc
parent4d55c54e307c27600c644c6631ff673ed89dd53a (diff)
patch 9.1.0145: v:echospace not correct when 'showcmdloc' != lastv9.1.0145
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 <zeertzjq@outlook.com> Signed-off-by: Sam-programs <130783534+Sam-programs@users.noreply.github.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
-rw-r--r--src/optionstr.c1
-rw-r--r--src/screen.c2
-rw-r--r--src/testdir/test_messages.vim6
-rw-r--r--src/version.c2
4 files changed, 9 insertions, 2 deletions
diff --git a/src/optionstr.c b/src/optionstr.c
index 7f6225fd2f..771423c641 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 939a335999..208b182541 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 48f1bab45b..8d0a422809 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 a17f3271e7..5842f46d5a 100644
--- a/src/version.c
+++ b/src/version.c
@@ -705,6 +705,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 145,
+/**/
144,
/**/
143,