patch 8.2.0648: semicolon search does not work in first line

Problem:    Semicolon search does not work in first line.
Solution:   Allow the cursor to be in line zero. (Christian Brabandt,
            closes #5996)
This commit is contained in:
Bram Moolenaar
2020-04-27 19:29:01 +02:00
parent bc970da807
commit 0e71704b77
3 changed files with 17 additions and 2 deletions

View File

@ -3069,8 +3069,10 @@ parse_cmd_address(exarg_T *eap, char **errormsg, int silent)
if (!eap->skip) if (!eap->skip)
{ {
curwin->w_cursor.lnum = eap->line2; curwin->w_cursor.lnum = eap->line2;
// don't leave the cursor on an illegal line or column // Don't leave the cursor on an illegal line or column, but do
check_cursor(); // accept zero as address, so 0;/PATTERN/ works correctly.
if (eap->line2 > 0)
check_cursor();
} }
} }
else if (*eap->cmd != ',') else if (*eap->cmd != ',')

View File

@ -1471,4 +1471,15 @@ func Test_cmdwin_insert_mode_close()
call assert_equal(1, winnr('$')) call assert_equal(1, winnr('$'))
endfunc endfunc
" test that ";" works to find a match at the start of the first line
func Test_zero_line_search()
new
call setline(1, ["1, pattern", "2, ", "3, pattern"])
call cursor(1,1)
0;/pattern/d
call assert_equal(["2, ", "3, pattern"], getline(1,'$'))
q!
endfunc
" vim: shiftwidth=2 sts=2 expandtab " vim: shiftwidth=2 sts=2 expandtab

View File

@ -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 */
/**/
648,
/**/ /**/
647, 647,
/**/ /**/