]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.2.0206: MS-Window: stripping all CSI sequences v9.2.0206
authorYasuhiro Matsumoto <mattn.jp@gmail.com>
Thu, 19 Mar 2026 21:31:34 +0000 (21:31 +0000)
committerChristian Brabandt <cb@256bit.org>
Thu, 19 Mar 2026 21:31:34 +0000 (21:31 +0000)
Problem:  MS-Window: stripping all CSI sequences
          (Ke Mao, after v9.2.0184)
Solution: Restore vtp_printf() to pass-through DECSUSR codes
          (Yasuhiro Matsumoto).

Patch 9.2.0184 discards all CSI sequences in mch_write() when VTP is
active to prevent unwanted DECRQM responses.  However, this also
removed the existing DECSCUSR pass-through, breaking cursor shape
changes (t_SI/t_SR/t_EI) on Windows Terminal.

Restore vtp_printf() pass-through for DECSCUSR (final byte 'q') while
continuing to discard other CSI sequences.

related: #19694
related: #11532
fixes:   #19750
closes:  #19755

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
src/os_win32.c
src/version.c

index 62fe2ffb7f546f180acc1c640d90ba9b0a9f695a..0174068f01774cf10d8b92525c09a91273f92ec4 100644 (file)
@@ -7443,7 +7443,9 @@ notsgr:
            // When USE_VTP is active, CSI sequences written through
            // write_chars() are interpreted by the console's VTP parser,
            // generating responses (e.g. DECRQM) that end up in the
-           // input buffer as unwanted keystrokes.  Discard them.
+           // input buffer as unwanted keystrokes.  Parse the sequence
+           // and only pass through known safe ones (e.g. DECSCUSR for
+           // cursor shape), discard the rest.
            if (USE_VTP)
            {
                int l = 2;
@@ -7453,7 +7455,12 @@ notsgr:
                    l++;
                // skip the final byte (0x40-0x7E)
                if (s + l < end && s[l] >= 0x40 && s[l] <= 0x7E)
+               {
+                   // DECSCUSR (cursor style): pass through to terminal
+                   if (s[l] == 'q')
+                       vtp_printf("%.*s", l + 1, s);
                    l++;
+               }
                len -= l - 1;
                s += l;
            }
index 439cfd26b4b394ac536c8bce379cf468a1a32e0d..6914a9b5ddc87c16d9efb4abe601eedb8a00957e 100644 (file)
@@ -734,6 +734,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    206,
 /**/
     205,
 /**/