# HG changeset patch # User Christian Brabandt # Date 1692549007 -7200 # Node ID 98db7b3b4827e9cf1e12a27aecff75ffef42b9db # Parent 20237d0faf6661fa287a2e428f5ffa5cc3b5bee7 patch 9.0.1762: Not able to get the virtual text property Commit: https://github.com/vim/vim/commit/f9037f186ad45b56c84f1efdc131480bec159e4f Author: Yegappan Lakshmanan Date: Sun Aug 20 18:27:45 2023 +0200 patch 9.0.1762: Not able to get the virtual text property 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 Co-authored-by: Yegappan Lakshmanan diff --git a/runtime/doc/textprop.txt b/runtime/doc/textprop.txt --- a/runtime/doc/textprop.txt +++ b/runtime/doc/textprop.txt @@ -335,6 +335,10 @@ prop_list({lnum} [, {props}]) *prop_l 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; diff --git a/src/testdir/test_textprop.vim b/src/testdir/test_textprop.vim --- a/src/testdir/test_textprop.vim +++ b/src/testdir/test_textprop.vim @@ -4025,4 +4025,39 @@ func Test_text_prop_list_hl_and_sign_hig 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 diff --git a/src/textprop.c b/src/textprop.c --- a/src/textprop.c +++ b/src/textprop.c @@ -990,6 +990,31 @@ prop_fill_dict(dict_T *dict, textprop_T 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"); + } } /* diff --git a/src/version.c b/src/version.c --- 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 */ /**/ + 1762, +/**/ 1761, /**/ 1760,