mirror of
https://github.com/neovim/neovim.git
synced 2025-11-25 03:30:37 +00:00
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:
committed by
Justin M. Keyes
parent
8794a551bd
commit
52ebe34eeb
@@ -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.
|
||||
*/
|
||||
|
||||
@@ -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");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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
|
||||
|
||||
Reference in New Issue
Block a user