]> granicus.if.org Git - vim/commitdiff
patch 8.2.4731: the changelist index is not remembered per buffer v8.2.4731
authorLemonBoy <thatlemon@gmail.com>
Sun, 10 Apr 2022 16:59:26 +0000 (17:59 +0100)
committerBram Moolenaar <Bram@vim.org>
Sun, 10 Apr 2022 16:59:26 +0000 (17:59 +0100)
Problem:    The changelist index is not remembered per buffer.
Solution:   Keep the changelist index per window and buffer. (closes #10135,
            closes #2173)

src/buffer.c
src/evalfunc.c
src/structs.h
src/testdir/test_changelist.vim
src/version.c

index 5f8b1ad1dc2a77f10ecc9b76e7415dbcfca09f78..50aa9e8cc1b03e4cf5c6a6a74311601478dfd512 100644 (file)
@@ -3076,6 +3076,8 @@ buflist_setfpos(
        wip->wi_fpos.lnum = lnum;
        wip->wi_fpos.col = col;
     }
+    if (win != NULL)
+       wip->wi_changelistidx = win->w_changelistidx;
     if (copy_options && win != NULL)
     {
        // Save the window-specific option values.
@@ -3210,6 +3212,8 @@ get_winopts(buf_T *buf)
     }
     else
        copy_winopt(&curwin->w_allbuf_opt, &curwin->w_onebuf_opt);
+    if (wip != NULL)
+       curwin->w_changelistidx = wip->wi_changelistidx;
 
 #ifdef FEAT_FOLDING
     // Set 'foldlevel' to 'foldlevelstart' if it's not negative.
index 482967346495957fd2fe0110bab45f9ad53a747d..e56b505d2be7fe900b8458178aa8cfca9623ca4e 100644 (file)
@@ -4724,6 +4724,7 @@ f_getchangelist(typval_T *argvars, typval_T *rettv)
     int                i;
     list_T     *l;
     dict_T     *d;
+    int                changelistindex;
 
     if (rettv_list_alloc(rettv) != OK)
        return;
@@ -4745,13 +4746,25 @@ f_getchangelist(typval_T *argvars, typval_T *rettv)
     if (list_append_list(rettv->vval.v_list, l) == FAIL)
        return;
     /*
-     * The current window change list index tracks only the position in the
-     * current buffer change list. For other buffers, use the change list
-     * length as the current index.
+     * The current window change list index tracks only the position for the
+     * current buffer. For other buffers use the stored index for the current
+     * window, or, if that's not available, the change list length.
      */
-    list_append_number(rettv->vval.v_list,
-           (varnumber_T)((buf == curwin->w_buffer)
-               ? curwin->w_changelistidx : buf->b_changelistlen));
+    if (buf == curwin->w_buffer)
+    {
+       changelistindex = curwin->w_changelistidx;
+    }
+    else
+    {
+       wininfo_T       *wip;
+
+       FOR_ALL_BUF_WININFO(buf, wip)
+           if (wip->wi_win == curwin)
+               break;
+       changelistindex = wip != NULL ? wip->wi_changelistidx
+                                                       : buf->b_changelistlen;
+    }
+    list_append_number(rettv->vval.v_list, (varnumber_T)changelistindex);
 
     for (i = 0; i < buf->b_changelistlen; ++i)
     {
index 5ad606efe84b57c4ab8550cb4811c5f99c2c70ee..670e0d229aeaec9cd149ef0337e14829c7d45842 100644 (file)
@@ -343,6 +343,7 @@ struct wininfo_S
     int                wi_fold_manual; // copy of w_fold_manual
     garray_T   wi_folds;       // clone of w_folds
 #endif
+    int                wi_changelistidx; // copy of w_changelistidx
 };
 
 /*
index 872b87ae472c707ffbc26e93b6adafdba320504f..f42996821865a6952fc41aa9c0df4a21090feedd 100644 (file)
@@ -1,6 +1,28 @@
 " Tests for the changelist functionality
 
 " Tests for the getchangelist() function
+func Test_changelist_index()
+  edit Xfile1.txt
+  exe "normal iabc\<C-G>u\ndef\<C-G>u\nghi"
+  call assert_equal(3, getchangelist('%')[1])
+  " Move one step back in the changelist.
+  normal 2g;
+
+  hide edit Xfile2.txt
+  exe "normal iabcd\<C-G>u\ndefg\<C-G>u\nghij"
+  call assert_equal(3, getchangelist('%')[1])
+  " Move to the beginning of the changelist.
+  normal 99g;
+
+  " Check the changelist indices.
+  call assert_equal(0, getchangelist('%')[1])
+  call assert_equal(1, getchangelist('#')[1])
+
+  bwipe!
+  call delete('Xfile1.txt')
+  call delete('Xfile2.txt')
+endfunc
+
 func Test_getchangelist()
   bwipe!
   enew
@@ -11,6 +33,7 @@ func Test_getchangelist()
   call writefile(['line1', 'line2', 'line3'], 'Xfile2.txt')
 
   edit Xfile1.txt
+  let buf_1 = bufnr()
   exe "normal 1Goline\<C-G>u1.1"
   exe "normal 3Goline\<C-G>u2.1"
   exe "normal 5Goline\<C-G>u3.1"
@@ -22,6 +45,7 @@ func Test_getchangelist()
              \ getchangelist('%'))
 
   hide edit Xfile2.txt
+  let buf_2 = bufnr()
   exe "normal 1GOline\<C-G>u1.0"
   exe "normal 2Goline\<C-G>u2.0"
   call assert_equal([[
@@ -33,10 +57,12 @@ func Test_getchangelist()
   call assert_equal([[
              \ {'lnum' : 2, 'col' : 4, 'coladd' : 0},
              \ {'lnum' : 4, 'col' : 4, 'coladd' : 0},
-             \ {'lnum' : 6, 'col' : 4, 'coladd' : 0}], 3], getchangelist(2))
+             \ {'lnum' : 6, 'col' : 4, 'coladd' : 0}], 2],
+             \ getchangelist(buf_1))
   call assert_equal([[
              \ {'lnum' : 1, 'col' : 6, 'coladd' : 0},
-             \ {'lnum' : 3, 'col' : 6, 'coladd' : 0}], 2], getchangelist(3))
+             \ {'lnum' : 3, 'col' : 6, 'coladd' : 0}], 2],
+             \ getchangelist(buf_2))
 
   bwipe!
   call delete('Xfile1.txt')
index fdb2e465752025e3672e13d5779415c01f87792b..57e1fedafdb78d23a53a8381d4cbdcb5990aafc2 100644 (file)
@@ -746,6 +746,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    4731,
 /**/
     4730,
 /**/