Skip to content

Commit

Permalink
patch 9.0.0489: using "end_lnum" with virtual text causes problems
Browse files Browse the repository at this point in the history
Problem:    Using "end_lnum" with virtual text causes problems.
Solution:   Disallow using "end_lnum" with virtual text. (closes #11151)
            Also disallow "end_col" and "length".
  • Loading branch information
brammool committed Sep 17, 2022
1 parent 4c7fd4d commit fb593c5
Show file tree
Hide file tree
Showing 4 changed files with 25 additions and 2 deletions.
4 changes: 4 additions & 0 deletions src/errors.h
Expand Up @@ -3338,3 +3338,7 @@ EXTERN char e_custom_list_completion_function_does_not_return_list_but_str[]
EXTERN char e_cannot_use_type_with_this_variable_str[]
INIT(= N_("E1304: Cannot use type with this variable: %s"));
#endif
#ifdef FEAT_PROP_POPUP
EXTERN char e_cannot_use_length_endcol_and_endlnum_with_text[]
INIT(= N_("E1305: Cannot use \"length\", \"end_col\" and \"end_lnum\" with \"text\""));
#endif
13 changes: 11 additions & 2 deletions src/testdir/test_textprop.vim
Expand Up @@ -2578,13 +2578,22 @@ func Test_prop_inserts_text_highlight()
call delete('XscriptPropsWithHighlight')
endfunc

func Test_prop_add_with_text_fails()
call prop_type_add('failing', #{highlight: 'ErrorMsg'})
call assert_fails("call prop_add(1, 0, #{type: 'failing', text: 'X', end_lnum: 1})", 'E1305:')
call assert_fails("call prop_add(1, 0, #{type: 'failing', text: 'X', end_col: 1})", 'E1305:')
call assert_fails("call prop_add(1, 0, #{type: 'failing', text: 'X', length: 1})", 'E1305:')

call prop_type_delete('failing')
endfunc

func Test_props_with_text_right_align_twice()
CheckRunVimInTerminal

let lines =<< trim END
call setline(1, ["some text some text some text some text", 'line two'])
call prop_type_add('MyErrorText', #{ highlight: 'ErrorMsg'})
call prop_type_add('MyPadding', #{ highlight: 'DiffChange'})
call prop_type_add('MyErrorText', #{highlight: 'ErrorMsg'})
call prop_type_add('MyPadding', #{highlight: 'DiffChange'})
call prop_add(1, 0, #{type: 'MyPadding', text: ' nothing here', text_wrap: 'wrap'})
call prop_add(1, 0, #{type: 'MyErrorText', text: 'Some error', text_wrap: 'wrap', text_align: 'right'})
call prop_add(1, 0, #{type: 'MyErrorText', text: 'Another error', text_wrap: 'wrap', text_align: 'right'})
Expand Down
8 changes: 8 additions & 0 deletions src/textprop.c
Expand Up @@ -488,6 +488,14 @@ prop_add_common(

if (dict_has_key(dict, "text"))
{
if (dict_has_key(dict, "length")
|| dict_has_key(dict, "end_col")
|| dict_has_key(dict, "end_lnum"))
{
emsg(_(e_cannot_use_length_endcol_and_endlnum_with_text));
goto theend;
}

text = dict_get_string(dict, "text", TRUE);
if (text == NULL)
goto theend;
Expand Down
2 changes: 2 additions & 0 deletions src/version.c
Expand Up @@ -703,6 +703,8 @@ static char *(features[]) =

static int included_patches[] =
{ /* Add new patch number below this line */
/**/
489,
/**/
488,
/**/
Expand Down

0 comments on commit fb593c5

Please sign in to comment.