diff options
author | Bram Moolenaar <Bram@vim.org> | 2022-10-15 14:07:48 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2022-10-15 14:07:48 +0100 |
commit | 13cdde39520220bb856cba16626327c706752b51 (patch) | |
tree | ccfce32ead03bcbf9541bd4c50203c1bff8074f8 | |
parent | eb4de629315f2682d8b314462d02422ec98d751a (diff) | |
download | vim-git-13cdde39520220bb856cba16626327c706752b51.tar.gz |
patch 9.0.0758: "precedes" from 'listchars' overwritten by <<<v9.0.0758
Problem: "precedes" from 'listchars' overwritten by <<< for 'smoothscroll'.
Solution: Keep the "precedes" character.
-rw-r--r-- | src/drawline.c | 4 | ||||
-rw-r--r-- | src/testdir/dumps/Test_smooth_list_1.dump | 8 | ||||
-rw-r--r-- | src/testdir/dumps/Test_smooth_list_2.dump | 8 | ||||
-rw-r--r-- | src/testdir/test_scroll_opt.vim | 25 | ||||
-rw-r--r-- | src/version.c | 2 |
5 files changed, 46 insertions, 1 deletions
diff --git a/src/drawline.c b/src/drawline.c index f3024c2fc..8824a0121 100644 --- a/src/drawline.c +++ b/src/drawline.c @@ -766,9 +766,11 @@ wlv_screen_line(win_T *wp, winlinevars_T *wlv, int negative_width) { if (wlv->row == 0 && wp->w_skipcol > 0 #if defined(FEAT_LINEBREAK) + // do not overwrite the 'showbreak' text with "<<<" && *get_showbreak_value(wp) == NUL #endif - ) + // do not overwrite the 'listchars' "precedes" text with "<<<" + && !(wp->w_p_list && wp->w_lcs_chars.prec != 0)) { int off = (int)(current_ScreenLine - ScreenLines); int skip = 0; diff --git a/src/testdir/dumps/Test_smooth_list_1.dump b/src/testdir/dumps/Test_smooth_list_1.dump new file mode 100644 index 000000000..b155df230 --- /dev/null +++ b/src/testdir/dumps/Test_smooth_list_1.dump @@ -0,0 +1,8 @@ +|<+0#4040ff13#ffffff0@2|t+0#0000000&| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| +>l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| +|v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| +|t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |$+0#4040ff13&| +0#0000000&@18 +|t|h|r|e@1|$+0#4040ff13&| +0#0000000&@33 +|~+0#4040ff13&| @38 +|~| @38 +| +0#0000000&@21|2|,|8|1| @9|B|o|t| diff --git a/src/testdir/dumps/Test_smooth_list_2.dump b/src/testdir/dumps/Test_smooth_list_2.dump new file mode 100644 index 000000000..82d17b4e3 --- /dev/null +++ b/src/testdir/dumps/Test_smooth_list_2.dump @@ -0,0 +1,8 @@ +|#+0#4040ff13#ffffff0|e+0#0000000&|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| +>l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| +|v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| +|t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |$+0#4040ff13&| +0#0000000&@18 +|t|h|r|e@1|$+0#4040ff13&| +0#0000000&@33 +|~+0#4040ff13&| @38 +|~| @38 +|:+0#0000000&|s|e|t| |l|i|s|t|c|h|a|r|s|+|=|p|r|e|c|e|d|2|,|8|1| @9|B|o|t| diff --git a/src/testdir/test_scroll_opt.vim b/src/testdir/test_scroll_opt.vim index 19c753d96..aba8603a6 100644 --- a/src/testdir/test_scroll_opt.vim +++ b/src/testdir/test_scroll_opt.vim @@ -155,6 +155,31 @@ func Test_smoothscroll_number() call StopVimInTerminal(buf) endfunc +func Test_smoothscroll_list() + CheckScreendump + + let lines =<< trim END + vim9script + set smoothscroll scrolloff=0 + set list + setline(1, [ + 'one', + 'very long text '->repeat(12), + 'three', + ]) + exe "normal 2Gzt\<C-E>" + END + call writefile(lines, 'XSmoothList', 'D') + let buf = RunVimInTerminal('-S XSmoothList', #{rows: 8, cols: 40}) + + call VerifyScreenDump(buf, 'Test_smooth_list_1', {}) + + call term_sendkeys(buf, ":set listchars+=precedes:#\<CR>") + call VerifyScreenDump(buf, 'Test_smooth_list_2', {}) + + call StopVimInTerminal(buf) +endfunc + func Test_smoothscroll_diff_mode() CheckScreendump diff --git a/src/version.c b/src/version.c index 3211c530c..b5dc88fdb 100644 --- a/src/version.c +++ b/src/version.c @@ -696,6 +696,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 758, +/**/ 757, /**/ 756, |