summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristopher Plewright <chris@createng.com>2023-01-23 12:33:23 +0000
committerBram Moolenaar <Bram@vim.org>2023-01-23 12:33:23 +0000
commitdc7179f9a4cc74d864d1f6414e691d25bac8f831 (patch)
tree4ae1b75eed477cbdad0f92cb241c6c12b52f689b
parentebfec1c531f32d424bb2aca6e7391ef3bfcbfe20 (diff)
patch 9.0.1235: MS-Windows console: not flushing termguicolorsv9.0.1235
Problem: MS-Windows console: not flushing termguicolors. Solution: Flush termguicolors. (Christopher Plewright, closes #11871)
-rw-r--r--src/os_win32.c28
-rw-r--r--src/proto/os_win32.pro1
-rw-r--r--src/term.c2
-rw-r--r--src/version.c2
4 files changed, 19 insertions, 14 deletions
diff --git a/src/os_win32.c b/src/os_win32.c
index ba5d228b84..e80533b017 100644
--- a/src/os_win32.c
+++ b/src/os_win32.c
@@ -6776,20 +6776,30 @@ visual_bell(void)
WORD attrFlash = ~g_attrCurrent & 0xff;
DWORD dwDummy;
- LPWORD oldattrs = ALLOC_MULT(WORD, Rows * Columns);
+ LPWORD oldattrs = NULL;
- if (oldattrs == NULL)
- return;
- ReadConsoleOutputAttribute(g_hConOut, oldattrs, Rows * Columns,
+# ifdef FEAT_TERMGUICOLORS
+ if (!(p_tgc || t_colors >= 256))
+# endif
+ {
+ oldattrs = ALLOC_MULT(WORD, Rows * Columns);
+ if (oldattrs == NULL)
+ return;
+ ReadConsoleOutputAttribute(g_hConOut, oldattrs, Rows * Columns,
coordOrigin, &dwDummy);
+ }
+
FillConsoleOutputAttribute(g_hConOut, attrFlash, Rows * Columns,
coordOrigin, &dwDummy);
Sleep(15); // wait for 15 msec
- if (!vtp_working)
+
+ if (oldattrs != NULL)
+ {
WriteConsoleOutputAttribute(g_hConOut, oldattrs, Rows * Columns,
coordOrigin, &dwDummy);
- vim_free(oldattrs);
+ vim_free(oldattrs);
+ }
}
@@ -8665,12 +8675,6 @@ wt_init(void)
wt_working = mch_getenv("WT_SESSION") != NULL;
}
- int
-use_wt(void)
-{
- return USE_WT;
-}
-
# ifdef FEAT_TERMGUICOLORS
static int
ctermtoxterm(
diff --git a/src/proto/os_win32.pro b/src/proto/os_win32.pro
index 6673c7878d..9f8b969583 100644
--- a/src/proto/os_win32.pro
+++ b/src/proto/os_win32.pro
@@ -73,7 +73,6 @@ void set_alist_count(void);
void fix_arg_enc(void);
int mch_setenv(char *var, char *value, int x);
int vtp_printf(char *format, ...);
-int use_wt(void);
void get_default_console_color(int *cterm_fg, int *cterm_bg, guicolor_T *gui_fg, guicolor_T *gui_bg);
void control_console_color_rgb(void);
int use_vtp(void);
diff --git a/src/term.c b/src/term.c
index 54da3d7f8e..042b6a6819 100644
--- a/src/term.c
+++ b/src/term.c
@@ -3222,7 +3222,7 @@ term_rgb_color(char_u *s, guicolor_T rgb)
vim_snprintf(buf, MAX_COLOR_STR_LEN,
(char *)s, RED(rgb), GREEN(rgb), BLUE(rgb));
#ifdef FEAT_VTP
- if (use_wt())
+ if (use_vtp() && (p_tgc || t_colors >= 256))
{
out_flush();
buf[1] = '[';
diff --git a/src/version.c b/src/version.c
index 831b643739..3e853b3093 100644
--- a/src/version.c
+++ b/src/version.c
@@ -696,6 +696,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1235,
+/**/
1234,
/**/
1233,