diff options
author | Björn Linse <bjorn.linse@gmail.com> | 2020-02-09 10:45:32 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-02-09 10:45:32 +0100 |
commit | 1ece24a329806778230034da73c25cc434b3bc9d (patch) | |
tree | d50cc55fc7face5d8d59c96f3b51f4a0e735f724 /src | |
parent | dd8b29cfe25604c062b76bb3a9347c5d740365ba (diff) | |
parent | 70c212e4808ca36279c65b630ff1d231e75349d3 (diff) | |
download | rneovim-1ece24a329806778230034da73c25cc434b3bc9d.tar.gz rneovim-1ece24a329806778230034da73c25cc434b3bc9d.tar.bz2 rneovim-1ece24a329806778230034da73c25cc434b3bc9d.zip |
Merge pull request #11836 from bfredl/vim-dbe5d361feb6
vim-patch:8.2.0235: draw error when an empty group is removed from 'statusline'
Diffstat (limited to 'src')
-rw-r--r-- | src/nvim/buffer.c | 6 | ||||
-rw-r--r-- | src/nvim/testdir/test_statusline.vim | 21 |
2 files changed, 27 insertions, 0 deletions
diff --git a/src/nvim/buffer.c b/src/nvim/buffer.c index 5083780719..19d0cac2d3 100644 --- a/src/nvim/buffer.c +++ b/src/nvim/buffer.c @@ -3531,6 +3531,12 @@ int build_stl_str_hl( if (n == curitem && group_start_userhl == group_end_userhl) { out_p = t; group_len = 0; + // do not use the highlighting from the removed group + for (n = groupitems[groupdepth] + 1; n < curitem; n++) { + if (items[n].type == Highlight) { + items[n].type = Empty; + } + } } } diff --git a/src/nvim/testdir/test_statusline.vim b/src/nvim/testdir/test_statusline.vim index 48ec777ffd..66b6e6c05c 100644 --- a/src/nvim/testdir/test_statusline.vim +++ b/src/nvim/testdir/test_statusline.vim @@ -369,3 +369,24 @@ func Test_statusline_visual() bwipe! x1 bwipe! x2 endfunc + +func Test_statusline_removed_group() + if !CanRunVimInTerminal() + throw 'Skipped: cannot make screendumps' + endif + + let lines =<< trim END + scriptencoding utf-8 + set laststatus=2 + let &statusline = '%#StatColorHi2#%(✓%#StatColorHi2#%) Q≡' + END + call writefile(lines, 'XTest_statusline') + + let buf = RunVimInTerminal('-S XTest_statusline', {'rows': 10, 'cols': 50}) + call term_wait(buf, 100) + call VerifyScreenDump(buf, 'Test_statusline_1', {}) + + " clean up + call StopVimInTerminal(buf) + call delete('XTest_statusline') +endfunc |