From: Bram Moolenaar Date: Wed, 22 Sep 2021 14:43:59 +0000 (+0200) Subject: patch 8.2.3455: using a count with "gp" leaves '] in wrong position X-Git-Tag: v8.2.3455 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=56858e4ed4e338e15821767b8303b06099e40384;p=vim 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 #8899) --- diff --git a/src/register.c b/src/register.c index 3ddacb8ee..f034c645b 100644 --- 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 index f03433628..f3a320f46 100644 --- a/src/testdir/test_put.vim +++ b/src/testdir/test_put.vim @@ -126,8 +126,10 @@ func Test_gp_with_count_leaves_cursor_at_end() 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 index fb36b14a1..6865fa5c5 100644 --- a/src/version.c +++ b/src/version.c @@ -757,6 +757,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 3455, /**/ 3454, /**/