forked from aniani/vim
patch 8.1.0392: error while typing :/foo/s// with 'incsearch' enabled
Problem: Error while typing :/foo/s// with 'incsearch' enabled. Solution: Do not give search errors when highlighting matches.
This commit is contained in:
@@ -117,7 +117,7 @@ static int getargopt(exarg_T *eap);
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
static int check_more(int, int);
|
static int check_more(int, int);
|
||||||
static linenr_T get_address(exarg_T *, char_u **, int addr_type, int skip, int to_other_file, int address_count);
|
static linenr_T get_address(exarg_T *, char_u **, int addr_type, int skip, int silent, int to_other_file, int address_count);
|
||||||
static void get_flags(exarg_T *eap);
|
static void get_flags(exarg_T *eap);
|
||||||
#if !defined(FEAT_PERL) \
|
#if !defined(FEAT_PERL) \
|
||||||
|| !defined(FEAT_PYTHON) || !defined(FEAT_PYTHON3) \
|
|| !defined(FEAT_PYTHON) || !defined(FEAT_PYTHON3) \
|
||||||
@@ -1853,7 +1853,7 @@ do_one_cmd(
|
|||||||
}
|
}
|
||||||
|
|
||||||
ea.cmd = cmd;
|
ea.cmd = cmd;
|
||||||
if (parse_cmd_address(&ea, &errormsg) == FAIL)
|
if (parse_cmd_address(&ea, &errormsg, FALSE) == FAIL)
|
||||||
goto doend;
|
goto doend;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -2836,7 +2836,7 @@ parse_command_modifiers(exarg_T *eap, char_u **errormsg, int skip_only)
|
|||||||
case 't': if (checkforcmd(&p, "tab", 3))
|
case 't': if (checkforcmd(&p, "tab", 3))
|
||||||
{
|
{
|
||||||
long tabnr = get_address(eap, &eap->cmd, ADDR_TABS,
|
long tabnr = get_address(eap, &eap->cmd, ADDR_TABS,
|
||||||
eap->skip, FALSE, 1);
|
eap->skip, skip_only, FALSE, 1);
|
||||||
if (tabnr == MAXLNUM)
|
if (tabnr == MAXLNUM)
|
||||||
cmdmod.tab = tabpage_index(curtab) + 1;
|
cmdmod.tab = tabpage_index(curtab) + 1;
|
||||||
else
|
else
|
||||||
@@ -2911,11 +2911,11 @@ free_cmdmod(void)
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Parse the address range, if any, in "eap".
|
* Parse the address range, if any, in "eap".
|
||||||
* May set the last search pattern.
|
* May set the last search pattern, unless "silent" is TRUE.
|
||||||
* Return FAIL and set "errormsg" or return OK.
|
* Return FAIL and set "errormsg" or return OK.
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
parse_cmd_address(exarg_T *eap, char_u **errormsg)
|
parse_cmd_address(exarg_T *eap, char_u **errormsg, int silent)
|
||||||
{
|
{
|
||||||
int address_count = 1;
|
int address_count = 1;
|
||||||
linenr_T lnum;
|
linenr_T lnum;
|
||||||
@@ -2955,7 +2955,7 @@ parse_cmd_address(exarg_T *eap, char_u **errormsg)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
eap->cmd = skipwhite(eap->cmd);
|
eap->cmd = skipwhite(eap->cmd);
|
||||||
lnum = get_address(eap, &eap->cmd, eap->addr_type, eap->skip,
|
lnum = get_address(eap, &eap->cmd, eap->addr_type, eap->skip, silent,
|
||||||
eap->addr_count == 0, address_count++);
|
eap->addr_count == 0, address_count++);
|
||||||
if (eap->cmd == NULL) // error detected
|
if (eap->cmd == NULL) // error detected
|
||||||
return FAIL;
|
return FAIL;
|
||||||
@@ -4450,10 +4450,11 @@ skip_range(
|
|||||||
get_address(
|
get_address(
|
||||||
exarg_T *eap UNUSED,
|
exarg_T *eap UNUSED,
|
||||||
char_u **ptr,
|
char_u **ptr,
|
||||||
int addr_type, /* flag: one of ADDR_LINES, ... */
|
int addr_type, // flag: one of ADDR_LINES, ...
|
||||||
int skip, /* only skip the address, don't use it */
|
int skip, // only skip the address, don't use it
|
||||||
int to_other_file, /* flag: may jump to other file */
|
int silent, // no errors or side effects
|
||||||
int address_count UNUSED) /* 1 for first address, >1 after comma */
|
int to_other_file, // flag: may jump to other file
|
||||||
|
int address_count UNUSED) // 1 for first address, >1 after comma
|
||||||
{
|
{
|
||||||
int c;
|
int c;
|
||||||
int i;
|
int i;
|
||||||
@@ -4599,28 +4600,28 @@ get_address(
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
pos = curwin->w_cursor; /* save curwin->w_cursor */
|
int flags;
|
||||||
/*
|
|
||||||
* When '/' or '?' follows another address, start
|
pos = curwin->w_cursor; // save curwin->w_cursor
|
||||||
* from there.
|
|
||||||
*/
|
// When '/' or '?' follows another address, start from
|
||||||
|
// there.
|
||||||
if (lnum != MAXLNUM)
|
if (lnum != MAXLNUM)
|
||||||
curwin->w_cursor.lnum = lnum;
|
curwin->w_cursor.lnum = lnum;
|
||||||
/*
|
|
||||||
* Start a forward search at the end of the line (unless
|
// Start a forward search at the end of the line (unless
|
||||||
* before the first line).
|
// before the first line).
|
||||||
* Start a backward search at the start of the line.
|
// Start a backward search at the start of the line.
|
||||||
* This makes sure we never match in the current
|
// This makes sure we never match in the current
|
||||||
* line, and can match anywhere in the
|
// line, and can match anywhere in the
|
||||||
* next/previous line.
|
// next/previous line.
|
||||||
*/
|
|
||||||
if (c == '/' && curwin->w_cursor.lnum > 0)
|
if (c == '/' && curwin->w_cursor.lnum > 0)
|
||||||
curwin->w_cursor.col = MAXCOL;
|
curwin->w_cursor.col = MAXCOL;
|
||||||
else
|
else
|
||||||
curwin->w_cursor.col = 0;
|
curwin->w_cursor.col = 0;
|
||||||
searchcmdlen = 0;
|
searchcmdlen = 0;
|
||||||
if (!do_search(NULL, c, cmd, 1L,
|
flags = silent ? 0 : SEARCH_HIS | SEARCH_MSG;
|
||||||
SEARCH_HIS | SEARCH_MSG, NULL, NULL))
|
if (!do_search(NULL, c, cmd, 1L, flags, NULL, NULL))
|
||||||
{
|
{
|
||||||
curwin->w_cursor = pos;
|
curwin->w_cursor = pos;
|
||||||
cmd = NULL;
|
cmd = NULL;
|
||||||
@@ -9529,7 +9530,7 @@ ex_copymove(exarg_T *eap)
|
|||||||
{
|
{
|
||||||
long n;
|
long n;
|
||||||
|
|
||||||
n = get_address(eap, &eap->arg, eap->addr_type, FALSE, FALSE, 1);
|
n = get_address(eap, &eap->arg, eap->addr_type, FALSE, FALSE, FALSE, 1);
|
||||||
if (eap->arg == NULL) /* error detected */
|
if (eap->arg == NULL) /* error detected */
|
||||||
{
|
{
|
||||||
eap->nextcmd = NULL;
|
eap->nextcmd = NULL;
|
||||||
|
|||||||
@@ -388,7 +388,7 @@ do_incsearch_highlighting(int firstc, incsearch_state_T *is_state,
|
|||||||
// parse the address range
|
// parse the address range
|
||||||
save_cursor = curwin->w_cursor;
|
save_cursor = curwin->w_cursor;
|
||||||
curwin->w_cursor = is_state->search_start;
|
curwin->w_cursor = is_state->search_start;
|
||||||
parse_cmd_address(&ea, &dummy);
|
parse_cmd_address(&ea, &dummy, TRUE);
|
||||||
if (ea.addr_count > 0)
|
if (ea.addr_count > 0)
|
||||||
{
|
{
|
||||||
// Allow for reverse match.
|
// Allow for reverse match.
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ int do_cmdline(char_u *cmdline, char_u *(*fgetline)(int, void *, int), void *coo
|
|||||||
int getline_equal(char_u *(*fgetline)(int, void *, int), void *cookie, char_u *(*func)(int, void *, int));
|
int getline_equal(char_u *(*fgetline)(int, void *, int), void *cookie, char_u *(*func)(int, void *, int));
|
||||||
void *getline_cookie(char_u *(*fgetline)(int, void *, int), void *cookie);
|
void *getline_cookie(char_u *(*fgetline)(int, void *, int), void *cookie);
|
||||||
int parse_command_modifiers(exarg_T *eap, char_u **errormsg, int skip_only);
|
int parse_command_modifiers(exarg_T *eap, char_u **errormsg, int skip_only);
|
||||||
int parse_cmd_address(exarg_T *eap, char_u **errormsg);
|
int parse_cmd_address(exarg_T *eap, char_u **errormsg, int silent);
|
||||||
int checkforcmd(char_u **pp, char *cmd, int len);
|
int checkforcmd(char_u **pp, char *cmd, int len);
|
||||||
int modifier_len(char_u *cmd);
|
int modifier_len(char_u *cmd);
|
||||||
int cmd_exists(char_u *name);
|
int cmd_exists(char_u *name);
|
||||||
|
|||||||
@@ -1055,6 +1055,10 @@ func Test_keep_last_search_pattern()
|
|||||||
call feedkeys(":/foo/s//\<Esc>", 'ntx')
|
call feedkeys(":/foo/s//\<Esc>", 'ntx')
|
||||||
call assert_equal('bar', @/)
|
call assert_equal('bar', @/)
|
||||||
|
|
||||||
|
" no error message if pattern not found
|
||||||
|
call feedkeys(":/xyz/s//\<Esc>", 'ntx')
|
||||||
|
call assert_equal('bar', @/)
|
||||||
|
|
||||||
bwipe!
|
bwipe!
|
||||||
call test_override("ALL", 0)
|
call test_override("ALL", 0)
|
||||||
set noincsearch
|
set noincsearch
|
||||||
|
|||||||
@@ -794,6 +794,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 */
|
||||||
|
/**/
|
||||||
|
392,
|
||||||
/**/
|
/**/
|
||||||
391,
|
391,
|
||||||
/**/
|
/**/
|
||||||
|
|||||||
Reference in New Issue
Block a user