]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.0.1762: Not able to get the virtual text property v9.0.1762
authorYegappan Lakshmanan <yegappan@yahoo.com>
Sun, 20 Aug 2023 16:27:45 +0000 (18:27 +0200)
committerChristian Brabandt <cb@256bit.org>
Sun, 20 Aug 2023 16:27:45 +0000 (18:27 +0200)
Problem:  Not able to get the virtual text property
Solution: Make prop_list() return virtual text and alignment

closes: #12860

Signed-off-by: Christian Brabandt <cb@256bit.org>
Co-authored-by: Yegappan Lakshmanan <yegappan@yahoo.com>
runtime/doc/textprop.txt
src/testdir/test_textprop.vim
src/textprop.c
src/version.c

index d69355bb1587c3f306e9886e14a2539b4785b264..0d830f66451255e3c23d18ec93db104ec4d261da 100644 (file)
@@ -335,6 +335,10 @@ prop_list({lnum} [, {props}])                              *prop_list()*
                   length       length in bytes, one more if line break is
                                included
                   id           property ID
+                  text         text to be displayed before {col}.  Only
+                               present for |virtual-text| properties.
+                  text_align   alignment property of |virtual-text|.
+                  text_wrap    specifies whether |virtual-text| is wrapped.
                   type         name of the property type, omitted if
                                the type was deleted
                   type_bufnr   buffer number for which this type was defined;
index 9b03d10fbe74c84334cce6e81483dde971700d67..9cf46d7d9b29d1ff953a4742783e2e0c4e017d93 100644 (file)
@@ -4025,4 +4025,39 @@ func Test_text_prop_list_hl_and_sign_highlight()
 
   call StopVimInTerminal(buf)
 endfunc
+
+" Test for getting the virtual text properties
+func Test_virtual_text_get()
+  new foobar
+  call setline(1, '12345678')
+  call prop_type_add('test', #{highlight: 'Search'})
+  call prop_add(1, 2, #{type: 'test', text: ' virtual text1 '})
+  call prop_add(1, 3, #{type: 'test'})
+  call prop_add(1, 0, #{type: 'test', text: ' virtual text2 ',
+        \               text_align: 'right'})
+  call prop_add(1, 5, #{type: 'test'})
+  call prop_add(1, 6, #{type: 'test', text: ' virtual text3 ',
+        \               text_wrap: 'wrap'})
+
+  let p = prop_list(1, #{end_lnum: -1})
+  call assert_equal(
+        \ #{lnum: 1, id: -1, col: 2, type_bufnr: 0, end: 1,
+        \   type: 'test', length: 1, start: 1,
+        \   text: ' virtual text1 '}, p[0])
+  call assert_equal(
+        \ #{lnum: 1, id: 0, col: 3, type_bufnr: 0, end: 1,
+        \   type: 'test', length: 0, start: 1}, p[1])
+  call assert_equal(
+        \ #{lnum: 1, id: 0, col: 5, type_bufnr: 0, end: 1,
+        \   type: 'test', length: 0, start: 1}, p[2])
+  call assert_equal(
+        \ #{lnum: 1, id: -3, col: 6, type_bufnr: 0, end: 1, type: 'test',
+        \   text_wrap: 'wrap', length: 1, start: 1, text: ' virtual text3 '},
+        \  p[3])
+  call assert_equal('right', p[4].text_align)
+
+  call prop_type_delete('test')
+  bwipe!
+endfunc
+
 " vim: shiftwidth=2 sts=2 expandtab
index e8ccfe1e00bc57017d2124e3436e4df4ab26615c..44f7ff0a4198669ea8bf47e8feb950597dde0936 100644 (file)
@@ -990,6 +990,31 @@ prop_fill_dict(dict_T *dict, textprop_T *prop, buf_T *buf)
        dict_add_number(dict, "type_bufnr", buf->b_fnum);
     else
        dict_add_number(dict, "type_bufnr", 0);
+    if (prop->tp_id < 0)
+    {
+       // virtual text property
+       garray_T    *gap = &buf->b_textprop_text;
+       char_u      *text;
+
+       // negate the property id to get the string index
+       text = ((char_u **)gap->ga_data)[-prop->tp_id - 1];
+       dict_add_string(dict, "text", text);
+
+       // text_align
+       char_u      *text_align = NULL;
+       if (prop->tp_flags & TP_FLAG_ALIGN_RIGHT)
+           text_align = (char_u *)"right";
+       else if (prop->tp_flags & TP_FLAG_ALIGN_ABOVE)
+           text_align = (char_u *)"above";
+       else if (prop->tp_flags & TP_FLAG_ALIGN_BELOW)
+           text_align = (char_u *)"below";
+       if (text_align != NULL)
+           dict_add_string(dict, "text_align", text_align);
+
+       // text_wrap
+       if (prop->tp_flags & TP_FLAG_WRAP)
+           dict_add_string(dict, "text_wrap", (char_u *)"wrap");
+    }
 }
 
 /*
index 19509d1ddfde098165a1f26d98da77d3d970e9c3..6455ca6855130c96f4b0863d391482122c3ceb0a 100644 (file)
@@ -695,6 +695,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1762,
 /**/
     1761,
 /**/