summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/search.c4
-rw-r--r--src/testdir/test_gn.vim5
-rw-r--r--src/version.c2
3 files changed, 9 insertions, 2 deletions
diff --git a/src/search.c b/src/search.c
index a1f8998df7..18f7905e58 100644
--- a/src/search.c
+++ b/src/search.c
@@ -4677,7 +4677,7 @@ abort_search:
#endif /* FEAT_TEXTOBJ */
/*
- * Check if the pattern is one character long or zero-width.
+ * Check if the pattern is zero-width.
* If move is TRUE, check from the beginning of the buffer, else from position
* "cur".
* "direction" is FORWARD or BACKWARD.
@@ -4851,7 +4851,7 @@ current_search(
// put cursor on last character of match
curwin->w_cursor = end_pos;
- if (LT_POS(VIsual, end_pos))
+ if (LT_POS(VIsual, end_pos) && forward)
dec_cursor();
else if (VIsual_active && LT_POS(curwin->w_cursor, VIsual))
curwin->w_cursor = pos; // put the cursor on the start of the match
diff --git a/src/testdir/test_gn.vim b/src/testdir/test_gn.vim
index ecf9b82899..9edf0a21ea 100644
--- a/src/testdir/test_gn.vim
+++ b/src/testdir/test_gn.vim
@@ -148,6 +148,11 @@ func Test_gn_command()
norm! gg0f7vhhhhgnd
call assert_equal(['12348'], getline(1,'$'))
sil! %d _
+ call setline('.', ['12345678'])
+ let @/ = '5'
+ norm! gg0f2vf7gNd
+ call assert_equal(['1678'], getline(1,'$'))
+ sil! %d _
set wrapscan&vim
endfu
diff --git a/src/version.c b/src/version.c
index 71d8959741..af29302522 100644
--- a/src/version.c
+++ b/src/version.c
@@ -742,6 +742,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 2218,
+/**/
2217,
/**/
2216,