]> granicus.if.org Git - vim/commitdiff
patch 9.0.0741: cannot specify an ID for each item with prop_add_list() v9.0.0741
authorBram Moolenaar <Bram@vim.org>
Thu, 13 Oct 2022 13:35:24 +0000 (14:35 +0100)
committerBram Moolenaar <Bram@vim.org>
Thu, 13 Oct 2022 13:35:24 +0000 (14:35 +0100)
Problem:    Cannot specify an ID for each item with prop_add_list(). (Sergey
            Vlasov)
Solution:   Add an optional fifth number to the item. (closes #11360)

runtime/doc/textprop.txt
src/testdir/test_textprop.vim
src/textprop.c
src/version.c

index 5a849fed6918ac351079c278db8445edce06fecc..4aa00acaee1d4965ae4dae55ccf00188cbd58519 100644 (file)
@@ -225,7 +225,7 @@ prop_add({lnum}, {col}, {props})
                        GetLnum()->prop_add(col, props)
 <
                                                *prop_add_list()*
-prop_add_list({props}, [[{lnum}, {col}, {end-lnum}, {end-col}], ...])
+prop_add_list({props}, [{item}, ...])
                Similar to prop_add(), but attaches a text property at
                multiple positions in a buffer.
 
@@ -237,12 +237,18 @@ prop_add_list({props}, [[{lnum}, {col}, {end-lnum}, {end-col}], ...])
                   type         name of the text property type
                All fields except "type" are optional.
 
-               The second argument is a List of Lists where each list
-               specifies the starting and ending position of the text.  The
-               first two items {lnum} and {col} specify the starting position
-               of the text where the property will be attached and the last
-               two items {end-lnum} and {end-col} specify the position just
-               after the text.
+               The second argument is a List of items, where each {item} is a
+               list that specifies the starting and ending position of the
+               text: [{lnum}, {col}, {end-lnum}, {end-col}]
+               or:   [{lnum}, {col}, {end-lnum}, {end-col}, {id}]
+
+               The first two items {lnum} and {col} specify the starting
+               position of the text where the property will be attached.
+               The next two items {end-lnum} and {end-col} specify the
+               position just after the text.
+               An optional fifth item {id} can be used to give a different ID
+               to a property.  When omitted the ID from {props} is used,
+               falling back to zero if none are present.
 
                It is not possible to add a text property with a "text" field
                here.
index 34c719d9642c626be33547367359181792746c08..39898eb4a77dd1ce39325d0028071d5c6b40682f 100644 (file)
@@ -367,6 +367,16 @@ func Test_prop_add_list()
         \ length: 7, start: 1}], prop_list(3))
   call assert_equal([#{id: 2, col: 1, type_bufnr: 0, end: 1, type: 'one',
         \ length: 5, start: 0}], prop_list(4))
+  call prop_remove(#{id: 2})
+  call assert_equal([], prop_list(1))
+
+  call prop_add_list(#{type: 'one', id: 3},
+        \ [[1, 1, 1, 3], [2, 5, 2, 7, 9]])
+  call assert_equal([#{id: 3, col: 1, type_bufnr: 0, end: 1, type: 'one',
+        \ length: 2, start: 1}], prop_list(1))
+  call assert_equal([#{id: 9, col: 5, type_bufnr: 0, end: 1, type: 'one',
+        \ length: 2, start: 1}], prop_list(2))
+
   call assert_fails('call prop_add_list([1, 2], [[1, 1, 3]])', 'E1206:')
   call assert_fails('call prop_add_list({}, {})', 'E1211:')
   call assert_fails('call prop_add_list({}, [[1, 1, 3]])', 'E965:')
index 9256368125a354d8d7d56db1a1ffa4dc6260e3be..808d1e639ea118d51798798a2d74eef8208476f0 100644 (file)
@@ -396,6 +396,9 @@ f_prop_add_list(typval_T *argvars, typval_T *rettv UNUSED)
            end_lnum = list_find_nr(pos_list, 2L, &error);
        if (!error)
            end_col = list_find_nr(pos_list, 3L, &error);
+       int this_id = id;
+       if (!error && pos_list->lv_len > 4)
+           this_id = list_find_nr(pos_list, 4L, &error);
        if (error || start_lnum <= 0 || start_col <= 0
                  || end_lnum <= 0 || end_col <= 0)
        {
@@ -403,8 +406,8 @@ f_prop_add_list(typval_T *argvars, typval_T *rettv UNUSED)
                emsg(_(e_invalid_argument));
            return;
        }
-       if (prop_add_one(buf, type_name, id, NULL, 0, 0, start_lnum, end_lnum,
-                                               start_col, end_col) == FAIL)
+       if (prop_add_one(buf, type_name, this_id, NULL, 0, 0,
+                            start_lnum, end_lnum, start_col, end_col) == FAIL)
            return;
     }
 
index 3076cb0db8b84daaafc1f281fe83b45d8373b432..6570ac52a8a983621204b7ede087e4fffe330912 100644 (file)
@@ -699,6 +699,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    741,
 /**/
     740,
 /**/