diff options
author | Bram Moolenaar <Bram@vim.org> | 2020-06-05 19:36:57 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2020-06-05 19:36:57 +0200 |
commit | ea563cc22be043ff91dcbdf2878c3d1fd944e573 (patch) | |
tree | b6c9d2a302d2d74ee22235a880a0148ddb5b47aa /src | |
parent | e0c3c3d6cbb6f356058f28ecbdf3438411222083 (diff) |
patch 8.2.0906: when setting 'termguicolors' SpellBad is no longer redv8.2.0906
Problem: When setting 'termguicolors' SpellBad is no longer red.
Solution: Only use the RGB guisp color for cterm when using the "underline"
or "undercurl" attributes to avoid the background color to be
cleared. Also make t_8u empty when the termresponse indicates a
real xterm. (closes #6207)
Diffstat (limited to 'src')
-rw-r--r-- | src/highlight.c | 7 | ||||
-rw-r--r-- | src/term.c | 5 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 13 insertions, 1 deletions
diff --git a/src/highlight.c b/src/highlight.c index 9ce610293c..6291f24aca 100644 --- a/src/highlight.c +++ b/src/highlight.c @@ -2929,7 +2929,12 @@ set_hl_attr( # endif at_en.ae_u.cterm.fg_rgb = GUI_MCH_GET_RGB2(sgp->sg_gui_fg); at_en.ae_u.cterm.bg_rgb = GUI_MCH_GET_RGB2(sgp->sg_gui_bg); - at_en.ae_u.cterm.ul_rgb = GUI_MCH_GET_RGB2(sgp->sg_gui_sp); + // Only use the underline/undercurl color when used, it may clear the + // background color if not supported. + if (sgp->sg_cterm & (HL_UNDERLINE | HL_UNDERCURL)) + at_en.ae_u.cterm.ul_rgb = GUI_MCH_GET_RGB2(sgp->sg_gui_sp); + else + at_en.ae_u.cterm.ul_rgb = INVALCOLOR; if (at_en.ae_u.cterm.fg_rgb == INVALCOLOR && at_en.ae_u.cterm.bg_rgb == INVALCOLOR) { diff --git a/src/term.c b/src/term.c index c024fcece3..b4b5c091a8 100644 --- a/src/term.c +++ b/src/term.c @@ -4819,6 +4819,11 @@ not_enough: if (version < 95) is_not_xterm = TRUE; + // With the real Xterm setting the underline RGB color + // clears the background color, disable "t_8u". + if (!is_not_xterm && *T_8U != NUL) + T_8U = empty_option; + // Only request the cursor style if t_SH and t_RS are // set. Only supported properly by xterm since version // 279 (otherwise it returns 0x18). diff --git a/src/version.c b/src/version.c index 377928c1a0..0530106827 100644 --- a/src/version.c +++ b/src/version.c @@ -747,6 +747,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 906, +/**/ 905, /**/ 904, |