diff options
author | Sam-programs <130783534+Sam-programs@users.noreply.github.com> | 2024-02-29 17:40:29 +0100 |
---|---|---|
committer | Christian Brabandt <cb@256bit.org> | 2024-02-29 17:40:29 +0100 |
commit | 062141b1a70cf5364e6983ec901282e0111745c1 (patch) | |
tree | 91c31448bb213ca46b554e2b9e50931848f20dbc | |
parent | 4d55c54e307c27600c644c6631ff673ed89dd53a (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.c | 1 | ||||
-rw-r--r-- | src/screen.c | 2 | ||||
-rw-r--r-- | src/testdir/test_messages.vim | 6 | ||||
-rw-r--r-- | src/version.c | 2 |
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, |