mirror of
https://github.com/vim/vim.git
synced 2025-09-27 04:14:06 -04:00
patch 8.0.1768: SET_NO_HLSEARCH() used in a wrong way
Problem: SET_NO_HLSEARCH() used in a wrong way. Solution: Make it a function. (suggested by Dominique Pelle, closes #2850)
This commit is contained in:
@@ -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);
|
||||
}
|
||||
|
||||
|
@@ -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. */
|
||||
|
@@ -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
|
||||
|
||||
|
@@ -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 : */
|
||||
|
@@ -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;
|
||||
|
12
src/search.c
12
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
|
||||
}
|
||||
}
|
||||
|
@@ -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!). */
|
||||
|
@@ -761,6 +761,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
1768,
|
||||
/**/
|
||||
1767,
|
||||
/**/
|
||||
|
@@ -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
|
||||
|
Reference in New Issue
Block a user