summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2018-04-27 22:53:07 +0200
committerBram Moolenaar <Bram@vim.org>2018-04-27 22:53:07 +0200
commit451fc7b954906069f1830a8092ad85616049a828 (patch)
tree5d39c1b58d958de9a81c08805b3c0673415d22c8
parent9d34d90210ba52ebaf45973282e5921f5af364c7 (diff)
downloadvim-git-8.0.1768.tar.gz
patch 8.0.1768: SET_NO_HLSEARCH() used in a wrong wayv8.0.1768
Problem: SET_NO_HLSEARCH() used in a wrong way. Solution: Make it a function. (suggested by Dominique Pelle, closes #2850)
-rw-r--r--src/ex_docmd.c13
-rw-r--r--src/ex_getln.c4
-rw-r--r--src/option.c2
-rw-r--r--src/proto/ex_docmd.pro1
-rw-r--r--src/screen.c2
-rw-r--r--src/search.c12
-rw-r--r--src/tag.c4
-rw-r--r--src/version.c2
-rw-r--r--src/vim.h6
9 files changed, 24 insertions, 22 deletions
diff --git a/src/ex_docmd.c b/src/ex_docmd.c
index 046ef3cf5..29270ad48 100644
--- a/src/ex_docmd.c
+++ b/src/ex_docmd.c
@@ -12193,14 +12193,23 @@ ex_set(exarg_T *eap)
(void)do_set(eap->arg, flags);
}
-#ifdef FEAT_SEARCH_EXTRA
+#if defined(FEAT_SEARCH_EXTRA) || defined(PROTO)
+ void
+set_no_hlsearch(int flag)
+{
+ no_hlsearch = flag;
+# ifdef FEAT_EVAL
+ set_vim_var_nr(VV_HLSEARCH, !no_hlsearch && p_hls);
+# endif
+}
+
/*
* ":nohlsearch"
*/
static void
ex_nohlsearch(exarg_T *eap UNUSED)
{
- SET_NO_HLSEARCH(TRUE);
+ set_no_hlsearch(TRUE);
redraw_all_later(SOME_VALID);
}
diff --git a/src/ex_getln.c b/src/ex_getln.c
index 5a1bdc0ea..ef8b4bdac 100644
--- a/src/ex_getln.c
+++ b/src/ex_getln.c
@@ -1976,7 +1976,7 @@ cmdline_changed:
if (ccline.cmdlen == 0)
{
i = 0;
- SET_NO_HLSEARCH(TRUE); /* turn off previous highlight */
+ set_no_hlsearch(TRUE); /* turn off previous highlight */
redraw_all_later(SOME_VALID);
}
else
@@ -2045,7 +2045,7 @@ cmdline_changed:
/* Disable 'hlsearch' highlighting if the pattern matches
* everything. Avoids a flash when typing "foo\|". */
if (empty_pattern(ccline.cmdbuff))
- SET_NO_HLSEARCH(TRUE);
+ set_no_hlsearch(TRUE);
validate_cursor();
/* May redraw the status line to show the cursor position. */
diff --git a/src/option.c b/src/option.c
index 31aec7e78..807b1e043 100644
--- a/src/option.c
+++ b/src/option.c
@@ -8359,7 +8359,7 @@ set_bool_option(
/* when 'hlsearch' is set or reset: reset no_hlsearch */
else if ((int *)varp == &p_hls)
{
- SET_NO_HLSEARCH(FALSE);
+ set_no_hlsearch(FALSE);
}
#endif
diff --git a/src/proto/ex_docmd.pro b/src/proto/ex_docmd.pro
index 0eace6222..acd6b08ed 100644
--- a/src/proto/ex_docmd.pro
+++ b/src/proto/ex_docmd.pro
@@ -66,6 +66,7 @@ void dialog_msg(char_u *buff, char *format, char_u *fname);
char_u *get_behave_arg(expand_T *xp, int idx);
char_u *get_messages_arg(expand_T *xp, int idx);
char_u *get_mapclear_arg(expand_T *xp, int idx);
+void set_no_hlsearch(int flag);
int get_pressedreturn(void);
void set_pressedreturn(int val);
/* vim: set ft=c : */
diff --git a/src/screen.c b/src/screen.c
index d1f17b51b..06dc30439 100644
--- a/src/screen.c
+++ b/src/screen.c
@@ -7945,7 +7945,7 @@ next_search_hl(
{
/* don't free regprog in the match list, it's a copy */
vim_regfree(shl->rm.regprog);
- SET_NO_HLSEARCH(TRUE);
+ set_no_hlsearch(TRUE);
}
shl->rm.regprog = NULL;
shl->lnum = 0;
diff --git a/src/search.c b/src/search.c
index a34636227..726013e62 100644
--- a/src/search.c
+++ b/src/search.c
@@ -293,7 +293,7 @@ save_re_pat(int idx, char_u *pat, int magic)
/* If 'hlsearch' set and search pat changed: need redraw. */
if (p_hls)
redraw_all_later(SOME_VALID);
- SET_NO_HLSEARCH(FALSE);
+ set_no_hlsearch(FALSE);
#endif
}
}
@@ -336,7 +336,7 @@ restore_search_patterns(void)
spats[1] = saved_spats[1];
#ifdef FEAT_SEARCH_EXTRA
last_idx = saved_last_idx;
- SET_NO_HLSEARCH(saved_no_hlsearch);
+ set_no_hlsearch(saved_no_hlsearch);
#endif
}
}
@@ -387,7 +387,7 @@ restore_last_search_pattern(void)
set_vv_searchforward();
# endif
last_idx = saved_last_idx;
- SET_NO_HLSEARCH(saved_no_hlsearch);
+ set_no_hlsearch(saved_no_hlsearch);
}
char_u *
@@ -1282,7 +1282,7 @@ do_search(
if (no_hlsearch && !(options & SEARCH_KEEP))
{
redraw_all_later(SOME_VALID);
- SET_NO_HLSEARCH(FALSE);
+ set_no_hlsearch(FALSE);
}
#endif
@@ -5757,9 +5757,7 @@ read_viminfo_search_pattern(vir_T *virp, int force)
spats[idx].off.off = off;
#ifdef FEAT_SEARCH_EXTRA
if (setlast)
- {
- SET_NO_HLSEARCH(!hlsearch_on);
- }
+ set_no_hlsearch(!hlsearch_on);
#endif
}
}
diff --git a/src/tag.c b/src/tag.c
index ca1f2f365..92ed2a7c4 100644
--- a/src/tag.c
+++ b/src/tag.c
@@ -3409,9 +3409,7 @@ jumpto_tag(
#ifdef FEAT_SEARCH_EXTRA
/* restore no_hlsearch when keeping the old search pattern */
if (search_options)
- {
- SET_NO_HLSEARCH(save_no_hlsearch);
- }
+ set_no_hlsearch(save_no_hlsearch);
#endif
/* Return OK if jumped to another file (at least we found the file!). */
diff --git a/src/version.c b/src/version.c
index 428ae28f3..773e4b477 100644
--- a/src/version.c
+++ b/src/version.c
@@ -762,6 +762,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1768,
+/**/
1767,
/**/
1766,
diff --git a/src/vim.h b/src/vim.h
index df396ec05..985a4926d 100644
--- a/src/vim.h
+++ b/src/vim.h
@@ -2458,12 +2458,6 @@ typedef enum {
/* Character used as separated in autoload function/variable names. */
#define AUTOLOAD_CHAR '#'
-#ifdef FEAT_EVAL
-# define SET_NO_HLSEARCH(flag) no_hlsearch = (flag); set_vim_var_nr(VV_HLSEARCH, !no_hlsearch && p_hls)
-#else
-# define SET_NO_HLSEARCH(flag) no_hlsearch = (flag)
-#endif
-
#ifdef FEAT_JOB_CHANNEL
# define MAX_OPEN_CHANNELS 10
#else