summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2017-06-04 21:06:09 +0200
committerBram Moolenaar <Bram@vim.org>2017-06-04 21:06:09 +0200
commit1615b36b91b094263240d7b555283ddf33208f62 (patch)
treed1b6b239f7e782080587529319455361c23fd11c
parentbf15b8d78b22661db8b19d662b62bb9a061cdd37 (diff)
downloadvim-git-8.0.0616.tar.gz
patch 8.0.0616: not always setting 'background' correctly after :hi Normalv8.0.0616
Problem: When setting the cterm background with ":hi Normal" the value of 'background' may be set wrongly. Solution: Check that the color is less than 16. Don't set 'background' when it was set explicitly. (Lemonboy, closes #1710)
-rw-r--r--src/syntax.c19
-rw-r--r--src/testdir/test_syntax.vim23
-rw-r--r--src/version.c2
3 files changed, 38 insertions, 6 deletions
diff --git a/src/syntax.c b/src/syntax.c
index 42a0bdc3f..10805f4e8 100644
--- a/src/syntax.c
+++ b/src/syntax.c
@@ -7834,18 +7834,25 @@ do_highlight(
must_redraw = CLEAR;
if (color >= 0)
{
+ int dark = -1;
+
if (termcap_active)
term_bg_color(color);
if (t_colors < 16)
- i = (color == 0 || color == 4);
- else
- i = (color < 7 || color == 8);
+ dark = (color == 0 || color == 4);
+ /* Limit the heuristic to the standard 16 colors */
+ else if (color < 16)
+ dark = (color < 7 || color == 8);
/* Set the 'background' option if the value is
* wrong. */
- if (i != (*p_bg == 'd'))
+ if (dark != -1
+ && dark != (*p_bg == 'd')
+ && !option_was_set((char_u *)"bg"))
+ {
set_option_value((char_u *)"bg", 0L,
- i ? (char_u *)"dark"
- : (char_u *)"light", 0);
+ (char_u *)(dark ? "dark" : "light"), 0);
+ reset_option_was_set((char_u *)"bg");
+ }
}
}
}
diff --git a/src/testdir/test_syntax.vim b/src/testdir/test_syntax.vim
index 8d4be00d3..eb093c8ff 100644
--- a/src/testdir/test_syntax.vim
+++ b/src/testdir/test_syntax.vim
@@ -401,3 +401,26 @@ func Test_highlight_invalid_arg()
call assert_fails('hi XXX xxx=White', 'E423:')
endfunc
+func Test_bg_detection()
+ if has('gui_running')
+ return
+ endif
+ " auto-detection of &bg, make sure sure it isn't set anywhere before
+ " this test
+ hi Normal ctermbg=0
+ call assert_equal('dark', &bg)
+ hi Normal ctermbg=4
+ call assert_equal('dark', &bg)
+ hi Normal ctermbg=12
+ call assert_equal('light', &bg)
+ hi Normal ctermbg=15
+ call assert_equal('light', &bg)
+
+ " manually-set &bg takes precendence over auto-detection
+ set bg=light
+ hi Normal ctermbg=4
+ call assert_equal('light', &bg)
+ set bg=dark
+ hi Normal ctermbg=12
+ call assert_equal('dark', &bg)
+endfunc
diff --git a/src/version.c b/src/version.c
index c0711fb84..eb4694859 100644
--- a/src/version.c
+++ b/src/version.c
@@ -765,6 +765,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 616,
+/**/
615,
/**/
614,