summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2018-09-15 15:42:40 +0200
committerBram Moolenaar <Bram@vim.org>2018-09-15 15:42:40 +0200
commit50eb16c3b23235b21ce4494673a7741a9a196176 (patch)
tree3b0fde54dd33ed6f20c3755c6860309f60012cf6
parentac49f61a206217e94438b7b51bbfcae79b8a2a19 (diff)
downloadvim-git-50eb16c3b23235b21ce4494673a7741a9a196176.tar.gz
patch 8.1.0392: error while typing :/foo/s// with 'incsearch' enabledv8.1.0392
Problem: Error while typing :/foo/s// with 'incsearch' enabled. Solution: Do not give search errors when highlighting matches.
-rw-r--r--src/ex_docmd.c53
-rw-r--r--src/ex_getln.c2
-rw-r--r--src/proto/ex_docmd.pro2
-rw-r--r--src/testdir/test_search.vim4
-rw-r--r--src/version.c2
5 files changed, 35 insertions, 28 deletions
diff --git a/src/ex_docmd.c b/src/ex_docmd.c
index e9f661bca..82904eeaf 100644
--- a/src/ex_docmd.c
+++ b/src/ex_docmd.c
@@ -117,7 +117,7 @@ static int getargopt(exarg_T *eap);
#endif
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);
#if !defined(FEAT_PERL) \
|| !defined(FEAT_PYTHON) || !defined(FEAT_PYTHON3) \
@@ -1853,7 +1853,7 @@ do_one_cmd(
}
ea.cmd = cmd;
- if (parse_cmd_address(&ea, &errormsg) == FAIL)
+ if (parse_cmd_address(&ea, &errormsg, FALSE) == FAIL)
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))
{
long tabnr = get_address(eap, &eap->cmd, ADDR_TABS,
- eap->skip, FALSE, 1);
+ eap->skip, skip_only, FALSE, 1);
if (tabnr == MAXLNUM)
cmdmod.tab = tabpage_index(curtab) + 1;
else
@@ -2911,11 +2911,11 @@ free_cmdmod(void)
/*
* 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.
*/
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;
linenr_T lnum;
@@ -2955,7 +2955,7 @@ parse_cmd_address(exarg_T *eap, char_u **errormsg)
#endif
}
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++);
if (eap->cmd == NULL) // error detected
return FAIL;
@@ -4450,10 +4450,11 @@ skip_range(
get_address(
exarg_T *eap UNUSED,
char_u **ptr,
- int addr_type, /* flag: one of ADDR_LINES, ... */
- int skip, /* only skip the address, don't use it */
- int to_other_file, /* flag: may jump to other file */
- int address_count UNUSED) /* 1 for first address, >1 after comma */
+ int addr_type, // flag: one of ADDR_LINES, ...
+ int skip, // only skip the address, don't use it
+ int silent, // no errors or side effects
+ int to_other_file, // flag: may jump to other file
+ int address_count UNUSED) // 1 for first address, >1 after comma
{
int c;
int i;
@@ -4599,28 +4600,28 @@ get_address(
}
else
{
- pos = curwin->w_cursor; /* save curwin->w_cursor */
- /*
- * When '/' or '?' follows another address, start
- * from there.
- */
+ int flags;
+
+ pos = curwin->w_cursor; // save curwin->w_cursor
+
+ // When '/' or '?' follows another address, start from
+ // there.
if (lnum != MAXLNUM)
curwin->w_cursor.lnum = lnum;
- /*
- * Start a forward search at the end of the line (unless
- * before the first line).
- * Start a backward search at the start of the line.
- * This makes sure we never match in the current
- * line, and can match anywhere in the
- * next/previous line.
- */
+
+ // Start a forward search at the end of the line (unless
+ // before the first line).
+ // Start a backward search at the start of the line.
+ // This makes sure we never match in the current
+ // line, and can match anywhere in the
+ // next/previous line.
if (c == '/' && curwin->w_cursor.lnum > 0)
curwin->w_cursor.col = MAXCOL;
else
curwin->w_cursor.col = 0;
searchcmdlen = 0;
- if (!do_search(NULL, c, cmd, 1L,
- SEARCH_HIS | SEARCH_MSG, NULL, NULL))
+ flags = silent ? 0 : SEARCH_HIS | SEARCH_MSG;
+ if (!do_search(NULL, c, cmd, 1L, flags, NULL, NULL))
{
curwin->w_cursor = pos;
cmd = NULL;
@@ -9529,7 +9530,7 @@ ex_copymove(exarg_T *eap)
{
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 */
{
eap->nextcmd = NULL;
diff --git a/src/ex_getln.c b/src/ex_getln.c
index a72b9a409..8f3833162 100644
--- a/src/ex_getln.c
+++ b/src/ex_getln.c
@@ -388,7 +388,7 @@ do_incsearch_highlighting(int firstc, incsearch_state_T *is_state,
// parse the address range
save_cursor = curwin->w_cursor;
curwin->w_cursor = is_state->search_start;
- parse_cmd_address(&ea, &dummy);
+ parse_cmd_address(&ea, &dummy, TRUE);
if (ea.addr_count > 0)
{
// Allow for reverse match.
diff --git a/src/proto/ex_docmd.pro b/src/proto/ex_docmd.pro
index 04bc0c3ab..8baf953b7 100644
--- a/src/proto/ex_docmd.pro
+++ b/src/proto/ex_docmd.pro
@@ -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));
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_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 modifier_len(char_u *cmd);
int cmd_exists(char_u *name);
diff --git a/src/testdir/test_search.vim b/src/testdir/test_search.vim
index 79f864502..56e0bf28e 100644
--- a/src/testdir/test_search.vim
+++ b/src/testdir/test_search.vim
@@ -1055,6 +1055,10 @@ func Test_keep_last_search_pattern()
call feedkeys(":/foo/s//\<Esc>", 'ntx')
call assert_equal('bar', @/)
+ " no error message if pattern not found
+ call feedkeys(":/xyz/s//\<Esc>", 'ntx')
+ call assert_equal('bar', @/)
+
bwipe!
call test_override("ALL", 0)
set noincsearch
diff --git a/src/version.c b/src/version.c
index 3a2b065bc..d04bdab68 100644
--- a/src/version.c
+++ b/src/version.c
@@ -795,6 +795,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 392,
+/**/
391,
/**/
390,