]> granicus.if.org Git - vim/commitdiff
patch 9.0.0252: cursor in wrong place after virtual text v9.0.0252
authorBram Moolenaar <Bram@vim.org>
Wed, 24 Aug 2022 11:24:37 +0000 (12:24 +0100)
committerBram Moolenaar <Bram@vim.org>
Wed, 24 Aug 2022 11:24:37 +0000 (12:24 +0100)
Problem:    Cursor in wrong place after virtual text.
Solution:   Do not change the length of a virtual text property.
            (closes #10964)

src/testdir/dumps/Test_prop_text_change_arg_1.dump [new file with mode: 0644]
src/testdir/dumps/Test_prop_text_change_arg_2.dump [new file with mode: 0644]
src/testdir/test_textprop.vim
src/textprop.c
src/version.c

diff --git a/src/testdir/dumps/Test_prop_text_change_arg_1.dump b/src/testdir/dumps/Test_prop_text_change_arg_1.dump
new file mode 100644 (file)
index 0000000..174af07
--- /dev/null
@@ -0,0 +1,5 @@
+>S+0&#ffffff0|e|t|E|r@1|o|r|C|o|d|e|(| |i+0&#ffd7ff255|d|:|-+0#4040ff13#ffffff0|1+0#0000000&|0|,| |i+0&#ffd7ff255|d|:|-+0#4040ff13#ffffff0|2+0#0000000&|0| |)| @29
+|s|e|c|o|n|d| |l|i|n|e| @48
+|~+0#4040ff13&| @58
+|~| @58
+| +0#0000000&@41|1|,|1| @10|A|l@1| 
diff --git a/src/testdir/dumps/Test_prop_text_change_arg_2.dump b/src/testdir/dumps/Test_prop_text_change_arg_2.dump
new file mode 100644 (file)
index 0000000..57e9a46
--- /dev/null
@@ -0,0 +1,5 @@
+|S+0&#ffffff0|e|t|E|r@1|o|r|C|o|d|e|(| |i+0&#ffd7ff255|d|:|-+0#4040ff13#ffffff0|1+0#0000000&|2|3>4|,| |i+0&#ffd7ff255|d|:|-+0#4040ff13#ffffff0|2+0#0000000&|0| |)| @27
+|s|e|c|o|n|d| |l|i|n|e| @48
+|~+0#4040ff13&| @58
+|~| @58
+| +0#0000000&@41|1|,|1|8|-|2@1| @6|A|l@1| 
index 0c7e91d0958b1681bbcea2d9baa509346a9e4992..60bf48c12acaebc43d3b57c4e8995d019f4863ce 100644 (file)
@@ -3091,4 +3091,40 @@ func Test_insert_text_with_padding()
   call delete('XscriptPropsPadded')
 endfunc
 
+func Test_insert_text_change_arg()
+  CheckRunVimInTerminal
+
+  let lines =<< trim END
+      vim9script
+      setline(1, ['SetErrorCode( 10, 20 )', 'second line'])
+      prop_type_add('param', {highlight: 'DiffChange', start_incl: 1})
+      prop_type_add('padd', {highlight: 'NonText', start_incl: 1})
+      prop_add(1, 15, {
+          type: 'param',
+          text: 'id:',
+      })
+      prop_add(1, 15, {
+          type: 'padd',
+          text: '-',
+      })
+      prop_add(1, 19, {
+          type: 'param',
+          text: 'id:',
+      })
+      prop_add(1, 19, {
+          type: 'padd',
+          text: '-',
+      })
+  END
+  call writefile(lines, 'XscriptPropsChange')
+  let buf = RunVimInTerminal('-S XscriptPropsChange', #{rows: 5, cols: 60})
+  call VerifyScreenDump(buf, 'Test_prop_text_change_arg_1', {})
+
+  call term_sendkeys(buf, "ggf1cw1234\<Esc>")
+  call VerifyScreenDump(buf, 'Test_prop_text_change_arg_2', {})
+
+  call StopVimInTerminal(buf)
+  call delete('XscriptPropsChange')
+endfunc
+
 " vim: shiftwidth=2 sts=2 expandtab
index 31e1be3bbf03eebec4fbda3e6f474d804499b5c5..0ba5c20b3dc067b2fc1709698d134dd1ffa01371 100644 (file)
@@ -2127,7 +2127,8 @@ adjust_prop(
        else
            prop->tp_col += added;
     }
-    else if (prop->tp_len > 0 && prop->tp_col + prop->tp_len > col)
+    else if (prop->tp_len > 0 && prop->tp_col + prop->tp_len > col
+           && prop->tp_id >= 0)  // don't change length for virtual text
     {
        int after = col - added - (prop->tp_col - 1 + prop->tp_len);
 
index 1d1de74d97a362a0a297e972c91b1859c5e445f0..2cd1e50ea81dce7505bcbf04d2eb625b7ef31f80 100644 (file)
@@ -731,6 +731,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    252,
 /**/
     251,
 /**/