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. /// @param[in] name Option name.
/// ///
/// @return True if it was set. /// @return True if it was set.
static bool option_was_set(const char *name) bool option_was_set(const char *name)
{ {
int idx; int idx;
@@ -6612,6 +6612,18 @@ static bool option_was_set(const char *name)
return false; 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. * 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()) { if (!ui_rgb_attached()) {
must_redraw = CLEAR; must_redraw = CLEAR;
if (color >= 0) { if (color >= 0) {
int dark = -1;
if (t_colors < 16) { if (t_colors < 16) {
i = (color == 0 || color == 4); dark = (color == 0 || color == 4);
} else { } else if (color < 16) {
i = (color < 7 || color == 8); // Limit the heuristic to the standard 16 colors
dark = (color < 7 || color == 8);
} }
// Set the 'background' option if the value is // Set the 'background' option if the value is
// wrong. // wrong.
if (i != (*p_bg == 'd')) { if (dark != -1
set_option_value("bg", 0L, (i ? "dark" : "light"), 0); && 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! bw!
endfunc 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