vim-patch:8.0.0616: not always setting 'background' correctly after :hi Normal (#8606)

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 vim/vim#1710)
1615b36b91

Restore reset_option_was_set(), removed in 419da839e0

ref #8595
ref #8597
This commit is contained in:
Jan Edmund Lazo
2018-06-21 05:15:11 -04:00
committed by Justin M. Keyes
parent 8794a551bd
commit 52ebe34eeb
3 changed files with 47 additions and 6 deletions

View File

@@ -6599,7 +6599,7 @@ void vimrc_found(char_u *fname, char_u *envname)
/// @param[in] name Option name.
///
/// @return True if it was set.
static bool option_was_set(const char *name)
bool option_was_set(const char *name)
{
int idx;
@@ -6612,6 +6612,18 @@ static bool option_was_set(const char *name)
return false;
}
/// Reset the flag indicating option "name" was set.
///
/// @param[in] name Option name.
void reset_option_was_set(const char *name)
{
const int idx = findoption(name);
if (idx >= 0) {
options[idx].flags &= ~P_WAS_SET;
}
}
/*
* fill_breakat_flags() -- called when 'breakat' changes value.
*/

View File

@@ -6812,15 +6812,21 @@ void do_highlight(const char *line, const bool forceit, const bool init)
if (!ui_rgb_attached()) {
must_redraw = CLEAR;
if (color >= 0) {
int dark = -1;
if (t_colors < 16) {
i = (color == 0 || color == 4);
} else {
i = (color < 7 || color == 8);
dark = (color == 0 || color == 4);
} else if (color < 16) {
// Limit the heuristic to the standard 16 colors
dark = (color < 7 || color == 8);
}
// Set the 'background' option if the value is
// wrong.
if (i != (*p_bg == 'd')) {
set_option_value("bg", 0L, (i ? "dark" : "light"), 0);
if (dark != -1
&& dark != (*p_bg == 'd')
&& !option_was_set("bg")) {
set_option_value("bg", 0L, (dark ? "dark" : "light"), 0);
reset_option_was_set("bg");
}
}
}

View File

@@ -435,3 +435,26 @@ func Test_conceal()
bw!
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