Skip to content

Commit

Permalink
patch 8.2.3088: with 'virtualedit' set to "block" Visual highlight is…
Browse files Browse the repository at this point in the history
… wrong

Problem:    With 'virtualedit' set to "block" Visual highlight is wrong after
            using "$".  (Marco Trosi)
Solution:   Do not set w_old_cursor_lcol to MAXCOL. (closes #8495)
  • Loading branch information
brammool committed Jul 3, 2021
1 parent fcde67c commit 9cee4a1
Show file tree
Hide file tree
Showing 4 changed files with 34 additions and 1 deletion.
4 changes: 3 additions & 1 deletion src/drawscreen.c
Expand Up @@ -2007,7 +2007,9 @@ win_update(win_T *wp)
ve_flags = save_ve_flags;
#endif
++toc;
if (curwin->w_curswant == MAXCOL)
// Highlight to the end of the line, unless 'virtualedit' has
// "block".
if (curwin->w_curswant == MAXCOL && !(ve_flags & VE_BLOCK))
toc = MAXCOL;

if (fromc != wp->w_old_cursor_fcol
Expand Down
8 changes: 8 additions & 0 deletions src/testdir/dumps/Test_visual_block_with_virtualedit.dump
@@ -0,0 +1,8 @@
|a+0&#e0e0e08@5> +0&#ffffff0@43
|b+0&#e0e0e08@3| @2| +0&#ffffff0@42
|c+0&#e0e0e08@1| @4| +0&#ffffff0@42
|~+0#4040ff13&| @48
|~| @48
|~| @48
|~| @48
|-+2#0000000&@1| |V|I|S|U|A|L| |B|L|O|C|K| |-@1| +0&&@3|3|x|7| @6|1|,|7| @10|A|l@1|
21 changes: 21 additions & 0 deletions src/testdir/test_visual.vim
Expand Up @@ -2,6 +2,7 @@

source shared.vim
source check.vim
source screendump.vim

func Test_block_shift_multibyte()
" Uses double-wide character.
Expand Down Expand Up @@ -1241,5 +1242,25 @@ func Test_visual_put_blockedit_zy_and_zp()
bw!
endfunc

func Test_visual_block_with_virtualedit()
CheckScreendump

let lines =<< trim END
call setline(1, ['aaaaaa', 'bbbb', 'cc'])
set virtualedit=block
normal G
END
call writefile(lines, 'XTest_block')

let buf = RunVimInTerminal('-S XTest_block', {'rows': 8, 'cols': 50})
call term_sendkeys(buf, "\<C-V>gg$")
call VerifyScreenDump(buf, 'Test_visual_block_with_virtualedit', {})

" clean up
call term_sendkeys(buf, "\<Esc>")
call StopVimInTerminal(buf)
call delete('XTest_beval')
endfunc


" vim: shiftwidth=2 sts=2 expandtab
2 changes: 2 additions & 0 deletions src/version.c
Expand Up @@ -755,6 +755,8 @@ static char *(features[]) =

static int included_patches[] =
{ /* Add new patch number below this line */
/**/
3088,
/**/
3087,
/**/
Expand Down

0 comments on commit 9cee4a1

Please sign in to comment.