mirror of
https://github.com/vim/vim.git
synced 2025-09-24 03:44:06 -04:00
patch 8.2.4731: the changelist index is not remembered per buffer
Problem: The changelist index is not remembered per buffer. Solution: Keep the changelist index per window and buffer. (closes #10135, closes #2173)
This commit is contained in:
@@ -3076,6 +3076,8 @@ buflist_setfpos(
|
|||||||
wip->wi_fpos.lnum = lnum;
|
wip->wi_fpos.lnum = lnum;
|
||||||
wip->wi_fpos.col = col;
|
wip->wi_fpos.col = col;
|
||||||
}
|
}
|
||||||
|
if (win != NULL)
|
||||||
|
wip->wi_changelistidx = win->w_changelistidx;
|
||||||
if (copy_options && win != NULL)
|
if (copy_options && win != NULL)
|
||||||
{
|
{
|
||||||
// Save the window-specific option values.
|
// Save the window-specific option values.
|
||||||
@@ -3210,6 +3212,8 @@ get_winopts(buf_T *buf)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
copy_winopt(&curwin->w_allbuf_opt, &curwin->w_onebuf_opt);
|
copy_winopt(&curwin->w_allbuf_opt, &curwin->w_onebuf_opt);
|
||||||
|
if (wip != NULL)
|
||||||
|
curwin->w_changelistidx = wip->wi_changelistidx;
|
||||||
|
|
||||||
#ifdef FEAT_FOLDING
|
#ifdef FEAT_FOLDING
|
||||||
// Set 'foldlevel' to 'foldlevelstart' if it's not negative.
|
// Set 'foldlevel' to 'foldlevelstart' if it's not negative.
|
||||||
|
@@ -4724,6 +4724,7 @@ f_getchangelist(typval_T *argvars, typval_T *rettv)
|
|||||||
int i;
|
int i;
|
||||||
list_T *l;
|
list_T *l;
|
||||||
dict_T *d;
|
dict_T *d;
|
||||||
|
int changelistindex;
|
||||||
|
|
||||||
if (rettv_list_alloc(rettv) != OK)
|
if (rettv_list_alloc(rettv) != OK)
|
||||||
return;
|
return;
|
||||||
@@ -4745,13 +4746,25 @@ f_getchangelist(typval_T *argvars, typval_T *rettv)
|
|||||||
if (list_append_list(rettv->vval.v_list, l) == FAIL)
|
if (list_append_list(rettv->vval.v_list, l) == FAIL)
|
||||||
return;
|
return;
|
||||||
/*
|
/*
|
||||||
* The current window change list index tracks only the position in the
|
* The current window change list index tracks only the position for the
|
||||||
* current buffer change list. For other buffers, use the change list
|
* current buffer. For other buffers use the stored index for the current
|
||||||
* length as the current index.
|
* window, or, if that's not available, the change list length.
|
||||||
*/
|
*/
|
||||||
list_append_number(rettv->vval.v_list,
|
if (buf == curwin->w_buffer)
|
||||||
(varnumber_T)((buf == curwin->w_buffer)
|
{
|
||||||
? curwin->w_changelistidx : buf->b_changelistlen));
|
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)
|
for (i = 0; i < buf->b_changelistlen; ++i)
|
||||||
{
|
{
|
||||||
|
@@ -343,6 +343,7 @@ struct wininfo_S
|
|||||||
int wi_fold_manual; // copy of w_fold_manual
|
int wi_fold_manual; // copy of w_fold_manual
|
||||||
garray_T wi_folds; // clone of w_folds
|
garray_T wi_folds; // clone of w_folds
|
||||||
#endif
|
#endif
|
||||||
|
int wi_changelistidx; // copy of w_changelistidx
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@@ -1,6 +1,28 @@
|
|||||||
" Tests for the changelist functionality
|
" Tests for the changelist functionality
|
||||||
|
|
||||||
" Tests for the getchangelist() function
|
" 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()
|
func Test_getchangelist()
|
||||||
bwipe!
|
bwipe!
|
||||||
enew
|
enew
|
||||||
@@ -11,6 +33,7 @@ func Test_getchangelist()
|
|||||||
call writefile(['line1', 'line2', 'line3'], 'Xfile2.txt')
|
call writefile(['line1', 'line2', 'line3'], 'Xfile2.txt')
|
||||||
|
|
||||||
edit Xfile1.txt
|
edit Xfile1.txt
|
||||||
|
let buf_1 = bufnr()
|
||||||
exe "normal 1Goline\<C-G>u1.1"
|
exe "normal 1Goline\<C-G>u1.1"
|
||||||
exe "normal 3Goline\<C-G>u2.1"
|
exe "normal 3Goline\<C-G>u2.1"
|
||||||
exe "normal 5Goline\<C-G>u3.1"
|
exe "normal 5Goline\<C-G>u3.1"
|
||||||
@@ -22,6 +45,7 @@ func Test_getchangelist()
|
|||||||
\ getchangelist('%'))
|
\ getchangelist('%'))
|
||||||
|
|
||||||
hide edit Xfile2.txt
|
hide edit Xfile2.txt
|
||||||
|
let buf_2 = bufnr()
|
||||||
exe "normal 1GOline\<C-G>u1.0"
|
exe "normal 1GOline\<C-G>u1.0"
|
||||||
exe "normal 2Goline\<C-G>u2.0"
|
exe "normal 2Goline\<C-G>u2.0"
|
||||||
call assert_equal([[
|
call assert_equal([[
|
||||||
@@ -33,10 +57,12 @@ func Test_getchangelist()
|
|||||||
call assert_equal([[
|
call assert_equal([[
|
||||||
\ {'lnum' : 2, 'col' : 4, 'coladd' : 0},
|
\ {'lnum' : 2, 'col' : 4, 'coladd' : 0},
|
||||||
\ {'lnum' : 4, '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([[
|
call assert_equal([[
|
||||||
\ {'lnum' : 1, 'col' : 6, 'coladd' : 0},
|
\ {'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!
|
bwipe!
|
||||||
call delete('Xfile1.txt')
|
call delete('Xfile1.txt')
|
||||||
|
@@ -746,6 +746,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
4731,
|
||||||
/**/
|
/**/
|
||||||
4730,
|
4730,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user