]> granicus.if.org Git - vim/commitdiff
patch 9.0.0636: underline color may not work in some terminals v9.0.0636
authorBram Moolenaar <Bram@vim.org>
Sat, 1 Oct 2022 20:22:17 +0000 (21:22 +0100)
committerBram Moolenaar <Bram@vim.org>
Sat, 1 Oct 2022 20:22:17 +0000 (21:22 +0100)
Problem:    Underline color does not work in terminals that don't send a
            termresponse.
Solution:   Do output t_8u if it was set explicitly. (closes #11253)

src/term.c
src/version.c

index 9c287417f96e6ebf24f2d3801351ba952d1e343c..b7e3facdb1c1c8251330247b9bde2078fff22786 100644 (file)
@@ -153,7 +153,7 @@ static termrequest_T *all_termrequests[] = {
 
 // The t_8u code may default to a value but get reset when the term response is
 // received.  To avoid redrawing too often, only redraw when t_8u is not reset
-// and it was supposed to be written.
+// and it was supposed to be written.  Unless t_8u was set explicitly.
 // FALSE -> don't output t_8u yet
 // MAYBE -> tried outputing t_8u while FALSE
 // OK    -> can write t_8u
@@ -3011,7 +3011,10 @@ term_bg_rgb_color(guicolor_T rgb)
 term_ul_rgb_color(guicolor_T rgb)
 {
 # ifdef FEAT_TERMRESPONSE
-    if (write_t_8u_state != OK)
+    // If the user explicitly sets t_8u then use it.  Otherwise wait for
+    // termresponse to be received, which is when t_8u would be set and a
+    // redraw is needed if it was used.
+    if (!option_was_set((char_u *)"t_8u") && write_t_8u_state != OK)
        write_t_8u_state = MAYBE;
     else
 # endif
index 571eef2e5cf84dfd325d0117359d4f46ddb5cb29..2534e069a349369cf6a0c03bcc10a825587bd43f 100644 (file)
@@ -699,6 +699,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    636,
 /**/
     635,
 /**/