# HG changeset patch # User Bram Moolenaar # Date 1632321904 -7200 # Node ID 196f75cf69835cd03272d2f7533deb3610e01115 # Parent f3fc9c20b2b3c0ea00b2765c2ab0c4aa2fec1e0c patch 8.2.3455: using a count with "gp" leaves '] in wrong position Commit: https://github.com/vim/vim/commit/56858e4ed4e338e15821767b8303b06099e40384 Author: Bram Moolenaar Date: Wed Sep 22 16:43:59 2021 +0200 patch 8.2.3455: using a count with "gp" leaves '] in wrong position Problem: Using a count with "gp" leaves '] in wrong position. (Naohiro Ono) Solution: Correct the mark position. (closes https://github.com/vim/vim/issues/8899) diff --git a/src/register.c b/src/register.c --- a/src/register.c +++ b/src/register.c @@ -2205,6 +2205,9 @@ error: { curwin->w_cursor.lnum = new_lnum; curwin->w_cursor.col = col; + curbuf->b_op_end = curwin->w_cursor; + if (col > 1) + curbuf->b_op_end.col = col - 1; } } else if (y_type == MLINE) diff --git a/src/testdir/test_put.vim b/src/testdir/test_put.vim --- a/src/testdir/test_put.vim +++ b/src/testdir/test_put.vim @@ -126,8 +126,10 @@ func Test_gp_with_count_leaves_cursor_at new call setline(1, '<---->') call setreg('@', "foo\nbar", 'c') - exe "normal 1G3|3gpix\" - call assert_equal(['<--foo', 'barfoo', 'barfoo', 'barx-->'], getline(1, '$')) + normal 1G3|3gp + call assert_equal([0, 4, 4, 0], getpos(".")) + call assert_equal(['<--foo', 'barfoo', 'barfoo', 'bar-->'], getline(1, '$')) + call assert_equal([0, 4, 3, 0], getpos("']")) bwipe! endfunc diff --git a/src/version.c b/src/version.c --- a/src/version.c +++ b/src/version.c @@ -758,6 +758,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 3455, +/**/ 3454, /**/ 3453,