]> granicus.if.org Git - vim/commitdiff
patch 8.1.1035: prop_remove() second argument is not optional v8.1.1035
authorBram Moolenaar <Bram@vim.org>
Fri, 22 Mar 2019 12:20:43 +0000 (13:20 +0100)
committerBram Moolenaar <Bram@vim.org>
Fri, 22 Mar 2019 12:20:43 +0000 (13:20 +0100)
Problem:    prop_remove() second argument is not optional.
Solution:   Fix argument count.  Use "buf" instead of "curbuf". (closes #4147)

src/evalfunc.c
src/testdir/test_textprop.vim
src/textprop.c
src/version.c

index f5a0bd8b5db4717886c5507f9f7d43abdbcd5096..81264bd560b1e6fe3f87a4bc39c6fe06038d3bb0 100644 (file)
@@ -788,7 +788,7 @@ static struct fst
     {"prop_add",       3, 3, f_prop_add},
     {"prop_clear",     1, 3, f_prop_clear},
     {"prop_list",      1, 2, f_prop_list},
-    {"prop_remove",    2, 3, f_prop_remove},
+    {"prop_remove",    1, 3, f_prop_remove},
     {"prop_type_add",  2, 2, f_prop_type_add},
     {"prop_type_change", 2, 2, f_prop_type_change},
     {"prop_type_delete", 1, 2, f_prop_type_delete},
index 5ea551750545b3efd6dbddbacd9c5a6f6c72d903..eab7aaab7991209a0431c82ab7a6ed116a454d70 100644 (file)
@@ -166,28 +166,64 @@ func Test_prop_add_remove_buf()
   new
   let bufnr = bufnr('')
   call AddPropTypes()
-  call setline(1, 'one two three')
+  for lnum in range(1, 4)
+    call setline(lnum, 'one two three')
+  endfor
   wincmd w
-  call prop_add(1, 1, {'length': 3, 'id': 11, 'type': 'one', 'bufnr': bufnr})
-  call prop_add(1, 5, {'length': 3, 'id': 12, 'type': 'two', 'bufnr': bufnr})
-  call prop_add(1, 11, {'length': 3, 'id': 13, 'type': 'three', 'bufnr': bufnr})
-  
+  for lnum in range(1, 4)
+    call prop_add(lnum, 1, {'length': 3, 'id': 11, 'type': 'one', 'bufnr': bufnr})
+    call prop_add(lnum, 5, {'length': 3, 'id': 12, 'type': 'two', 'bufnr': bufnr})
+    call prop_add(lnum, 11, {'length': 3, 'id': 13, 'type': 'three', 'bufnr': bufnr})
+  endfor
+
   let props = [
        \ {'col': 1, 'length': 3, 'id': 11, 'type': 'one', 'start': 1, 'end': 1},
        \ {'col': 5, 'length': 3, 'id': 12, 'type': 'two', 'start': 1, 'end': 1},
        \ {'col': 11, 'length': 3, 'id': 13, 'type': 'three', 'start': 1, 'end': 1},
        \]
   call assert_equal(props, prop_list(1, {'bufnr': bufnr}))
+
   " remove by id
-  call prop_remove({'id': 12, 'bufnr': bufnr}, 1)
+  let before_props = deepcopy(props)
   unlet props[1]
+
+  call prop_remove({'id': 12, 'bufnr': bufnr}, 1)
   call assert_equal(props, prop_list(1, {'bufnr': bufnr}))
+  call assert_equal(before_props, prop_list(2, {'bufnr': bufnr}))
+  call assert_equal(before_props, prop_list(3, {'bufnr': bufnr}))
+  call assert_equal(before_props, prop_list(4, {'bufnr': bufnr}))
+
+  call prop_remove({'id': 12, 'bufnr': bufnr}, 3, 4)
+  call assert_equal(props, prop_list(1, {'bufnr': bufnr}))
+  call assert_equal(before_props, prop_list(2, {'bufnr': bufnr}))
+  call assert_equal(props, prop_list(3, {'bufnr': bufnr}))
+  call assert_equal(props, prop_list(4, {'bufnr': bufnr}))
+
+  call prop_remove({'id': 12, 'bufnr': bufnr})
+  for lnum in range(1, 4)
+    call assert_equal(props, prop_list(lnum, {'bufnr': bufnr}))
+  endfor
 
   " remove by type
-  call prop_remove({'type': 'one', 'bufnr': bufnr}, 1)
+  let before_props = deepcopy(props)
   unlet props[0]
+
+  call prop_remove({'type': 'one', 'bufnr': bufnr}, 1)
+  call assert_equal(props, prop_list(1, {'bufnr': bufnr}))
+  call assert_equal(before_props, prop_list(2, {'bufnr': bufnr}))
+  call assert_equal(before_props, prop_list(3, {'bufnr': bufnr}))
+  call assert_equal(before_props, prop_list(4, {'bufnr': bufnr}))
+
+  call prop_remove({'type': 'one', 'bufnr': bufnr}, 3, 4)
   call assert_equal(props, prop_list(1, {'bufnr': bufnr}))
+  call assert_equal(before_props, prop_list(2, {'bufnr': bufnr}))
+  call assert_equal(props, prop_list(3, {'bufnr': bufnr}))
+  call assert_equal(props, prop_list(4, {'bufnr': bufnr}))
+
+  call prop_remove({'type': 'one', 'bufnr': bufnr})
+  for lnum in range(1, 4)
+    call assert_equal(props, prop_list(lnum, {'bufnr': bufnr}))
+  endfor
 
   call DeletePropTypes()
   wincmd w
index 674faebe248bc7ec1bd6ec7e837be55455263cdc..34738adc40891df35de556423cc692d30a590183 100644 (file)
@@ -629,7 +629,10 @@ f_prop_remove(typval_T *argvars, typval_T *rettv)
                        mch_memmove(newptr, buf->b_ml.ml_line_ptr,
                                                        buf->b_ml.ml_line_len);
                        buf->b_ml.ml_line_ptr = newptr;
-                       curbuf->b_ml.ml_flags |= ML_LINE_DIRTY;
+                       buf->b_ml.ml_flags |= ML_LINE_DIRTY;
+
+                       cur_prop = buf->b_ml.ml_line_ptr + len
+                                                       + idx * sizeof(textprop_T);
                    }
 
                    taillen = buf->b_ml.ml_line_len - len
index 9114570f87347447693e6ca3789aebe7a839ed35..bee744e87d5595cb66c9c0eefa2f247ac62e4bad 100644 (file)
@@ -779,6 +779,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1035,
 /**/
     1034,
 /**/