diff options
author | Bram Moolenaar <Bram@vim.org> | 2019-05-25 22:57:30 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2019-05-25 22:57:30 +0200 |
commit | 193ffd1d9f4f4d5412ce8d7a46bb2f89d47a56da (patch) | |
tree | 5ee1f8a7ad3ea5cc0621e5cdd5f4b8461298522e | |
parent | adfde115d5c9c9ac4a052874bcf85d2507fe1355 (diff) | |
download | vim-git-193ffd1d9f4f4d5412ce8d7a46bb2f89d47a56da.tar.gz |
patch 8.1.1396: 'wincolor' does not apply to lines below the bufferv8.1.1396
Problem: 'wincolor' does not apply to lines below the buffer.
Solution: Also apply 'wincolor' to the "~" lines and the number column.
-rw-r--r-- | src/screen.c | 53 | ||||
-rw-r--r-- | src/testdir/dumps/Test_wincolor_01.dump | 8 | ||||
-rw-r--r-- | src/testdir/test_highlight.vim | 24 | ||||
-rw-r--r-- | src/version.c | 2 |
4 files changed, 65 insertions, 22 deletions
diff --git a/src/screen.c b/src/screen.c index 447dd411b..00894cead 100644 --- a/src/screen.c +++ b/src/screen.c @@ -2418,6 +2418,14 @@ win_draw_end( hlf_T hl) { int n = 0; + int attr = HL_ATTR(hl); + int wcr_attr = 0; + + if (*wp->w_p_wcr != NUL) + { + wcr_attr = syn_name2attr(wp->w_p_wcr); + attr = hl_combine_attr(wcr_attr, attr); + } if (draw_margin) { @@ -2427,19 +2435,19 @@ win_draw_end( if (fdc > 0) // draw the fold column n = screen_fill_end(wp, ' ', ' ', n, fdc, - row, endrow, HL_ATTR(HLF_FC)); + row, endrow, hl_combine_attr(wcr_attr, HL_ATTR(HLF_FC))); #endif #ifdef FEAT_SIGNS if (signcolumn_on(wp)) // draw the sign column n = screen_fill_end(wp, ' ', ' ', n, 2, - row, endrow, HL_ATTR(HLF_SC)); + row, endrow, hl_combine_attr(wcr_attr, HL_ATTR(HLF_SC))); #endif if ((wp->w_p_nu || wp->w_p_rnu) && vim_strchr(p_cpo, CPO_NUMCOL) == NULL) // draw the number column n = screen_fill_end(wp, ' ', ' ', n, number_width(wp) + 1, - row, endrow, HL_ATTR(HLF_N)); + row, endrow, hl_combine_attr(wcr_attr, HL_ATTR(HLF_N))); } #ifdef FEAT_RIGHTLEFT @@ -2447,17 +2455,17 @@ win_draw_end( { screen_fill(W_WINROW(wp) + row, W_WINROW(wp) + endrow, wp->w_wincol, W_ENDCOL(wp) - 1 - n, - c2, c2, HL_ATTR(hl)); + c2, c2, attr); screen_fill(W_WINROW(wp) + row, W_WINROW(wp) + endrow, W_ENDCOL(wp) - 1 - n, W_ENDCOL(wp) - n, - c1, c2, HL_ATTR(hl)); + c1, c2, attr); } else #endif { screen_fill(W_WINROW(wp) + row, W_WINROW(wp) + endrow, wp->w_wincol + n, (int)W_ENDCOL(wp), - c1, c2, HL_ATTR(hl)); + c1, c2, attr); } set_empty_rows(wp, row); @@ -3100,14 +3108,15 @@ win_line( pos_T pos; long v; - int char_attr = 0; /* attributes for next character */ - int attr_pri = FALSE; /* char_attr has priority */ - int area_highlighting = FALSE; /* Visual or incsearch highlighting - in this line */ - int vi_attr = 0; /* attributes for Visual and incsearch - highlighting */ - int area_attr = 0; /* attributes desired by highlighting */ - int search_attr = 0; /* attributes desired by 'hlsearch' */ + int char_attr = 0; // attributes for next character + int attr_pri = FALSE; // char_attr has priority + int area_highlighting = FALSE; // Visual or incsearch highlighting + // in this line + int vi_attr = 0; // attributes for Visual and incsearch + // highlighting + int wcr_attr = 0; // attributes from 'wincolor' + int area_attr = 0; // attributes desired by highlighting + int search_attr = 0; // attributes desired by 'hlsearch' #ifdef FEAT_SYN_HL int vcol_save_attr = 0; /* saved attr for 'cursorcolumn' */ int syntax_attr = 0; /* attributes desired by syntax */ @@ -3559,12 +3568,12 @@ win_line( if (*wp->w_p_wcr != NUL) { - int attr = syn_name2attr(wp->w_p_wcr); + wcr_attr = syn_name2attr(wp->w_p_wcr); // 'wincolor' highlighting for the whole window - if (attr != 0) + if (wcr_attr != 0) { - win_attr = attr; + win_attr = wcr_attr; area_highlighting = TRUE; } } @@ -3850,7 +3859,7 @@ win_line( n_extra = 1; c_extra = cmdwin_type; c_final = NUL; - char_attr = HL_ATTR(HLF_AT); + char_attr = hl_combine_attr(wcr_attr, HL_ATTR(HLF_AT)); } } #endif @@ -3876,7 +3885,7 @@ win_line( p_extra = p_extra_free; c_extra = NUL; c_final = NUL; - char_attr = HL_ATTR(HLF_FC); + char_attr = hl_combine_attr(wcr_attr, HL_ATTR(HLF_FC)); } } } @@ -3898,7 +3907,7 @@ win_line( /* Draw two cells with the sign value or blank. */ c_extra = ' '; c_final = NUL; - char_attr = HL_ATTR(HLF_SC); + char_attr = hl_combine_attr(wcr_attr, HL_ATTR(HLF_SC)); n_extra = 2; if (row == startrow @@ -4012,7 +4021,7 @@ win_line( c_final = NUL; } n_extra = number_width(wp) + 1; - char_attr = HL_ATTR(HLF_N); + char_attr = hl_combine_attr(wcr_attr, HL_ATTR(HLF_N)); #ifdef FEAT_SYN_HL /* When 'cursorline' is set highlight the line number of * the current line differently. @@ -4020,7 +4029,7 @@ win_line( * when CursorLineNr isn't set? */ if ((wp->w_p_cul || wp->w_p_rnu) && lnum == wp->w_cursor.lnum) - char_attr = HL_ATTR(HLF_CLN); + char_attr = hl_combine_attr(wcr_attr, HL_ATTR(HLF_CLN)); #endif } } diff --git a/src/testdir/dumps/Test_wincolor_01.dump b/src/testdir/dumps/Test_wincolor_01.dump new file mode 100644 index 000000000..0536fd27b --- /dev/null +++ b/src/testdir/dumps/Test_wincolor_01.dump @@ -0,0 +1,8 @@ +| +0#af5f00255#ffd7ff255@1|2| | +0#0000001&@4| +0&#e0e0e08| +0&#ffd7ff255@64 +| +0#af5f00255&@1|1| |1+0#0000001&@4|1+0#0000000#e0e0e08@4| | +0#0000001#ffd7ff255@59 +| +0#af5f00255&@1|0| |2+0#0000000#e0e0e08@4>2+0#0000001#ffd7ff255@5| +8&&@59 +| +0#af5f00255&@1|1| |3+0#0000001&| |h|e|r|e+0&#e0e0e08| +0&#ffd7ff255|3| @62 +| +0#af5f00255&@1|2| | +0#0000001&@4| +0&#e0e0e08| +0&#ffd7ff255@64 +|~+0#4040ff13&| @73 +|~| @73 +|-+2#0000000#ffffff0@1| |V|I|S|U|A|L| |-@1| +0&&@34|2| @8|3|,|6| @10|A|l@1| diff --git a/src/testdir/test_highlight.vim b/src/testdir/test_highlight.vim index 7c6cc64fc..454845700 100644 --- a/src/testdir/test_highlight.vim +++ b/src/testdir/test_highlight.vim @@ -573,6 +573,30 @@ func Test_cursorline_with_visualmode() call delete('Xtest_cursorline_with_visualmode') endfunc +func Test_wincolor() + if !CanRunVimInTerminal() + return + endif + + call writefile([ + \ 'set cursorline cursorcolumn rnu', + \ 'call setline(1, ["","1111111111","22222222222","3 here 3",""])', + \ 'set wincolor=Pmenu', + \ '/here', + \ ], 'Xtest_wincolor') + let buf = RunVimInTerminal('-S Xtest_wincolor', {'rows': 8}) + call term_wait(buf) + call term_sendkeys(buf, "2G5lvj") + call term_wait(buf) + + call VerifyScreenDump(buf, 'Test_wincolor_01', {}) + + " clean up + call term_sendkeys(buf, "\<Esc>") + call StopVimInTerminal(buf) + call delete('Xtest_wincolor') +endfunc + " This test must come before the Test_cursorline test, as it appears this " defines the Normal highlighting group anyway. func Test_1_highlight_Normalgroup_exists() diff --git a/src/version.c b/src/version.c index 3dad14128..65a7b96f4 100644 --- a/src/version.c +++ b/src/version.c @@ -768,6 +768,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 1396, +/**/ 1395, /**/ 1394, |