summaryrefslogtreecommitdiff
path: root/src/evalfunc.c
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2020-06-07 14:50:50 +0200
committerBram Moolenaar <Bram@vim.org>2020-06-07 14:50:50 +0200
commita9c010494767e43a51c443cac35ebc80d0831d0b (patch)
tree9997eec6cd7eb6da640de26c0ab5d6637ccbbcce /src/evalfunc.c
parente928366de5deca359fad779a4f740db703296302 (diff)
downloadvim-git-a9c010494767e43a51c443cac35ebc80d0831d0b.tar.gz
patch 8.2.0918: duplicate code for evaluating expression argumentv8.2.0918
Problem: Duplicate code for evaluating expression argument. Solution: Merge the code and make the use more flexible.
Diffstat (limited to 'src/evalfunc.c')
-rw-r--r--src/evalfunc.c32
1 files changed, 9 insertions, 23 deletions
diff --git a/src/evalfunc.c b/src/evalfunc.c
index 0a390bf94..2a22f92e2 100644
--- a/src/evalfunc.c
+++ b/src/evalfunc.c
@@ -6399,11 +6399,9 @@ search_cmn(typval_T *argvars, pos_T *match_pos, int *flagsp)
int options = SEARCH_KEEP;
int subpatnum;
searchit_arg_T sia;
- evalarg_T skip;
+ int use_skip = FALSE;
pos_T firstpos;
- CLEAR_FIELD(skip);
-
pat = tv_get_string(&argvars[0]);
dir = get_search_arg(&argvars[1], flagsp); // may set p_ws
if (dir == 0)
@@ -6429,9 +6427,7 @@ search_cmn(typval_T *argvars, pos_T *match_pos, int *flagsp)
if (time_limit < 0)
goto theend;
#endif
- if (argvars[4].v_type != VAR_UNKNOWN
- && evalarg_get(&argvars[4], &skip) == FAIL)
- goto theend;
+ use_skip = eval_expr_valid_arg(&argvars[4]);
}
}
@@ -6471,19 +6467,20 @@ search_cmn(typval_T *argvars, pos_T *match_pos, int *flagsp)
if (firstpos.lnum != 0 && EQUAL_POS(pos, firstpos))
subpatnum = FAIL;
- if (subpatnum == FAIL || !evalarg_valid(&skip))
+ if (subpatnum == FAIL || !use_skip)
// didn't find it or no skip argument
break;
firstpos = pos;
- // If the skip pattern matches, ignore this match.
+ // If the skip expression matches, ignore this match.
{
int do_skip;
int err;
pos_T save_pos = curwin->w_cursor;
curwin->w_cursor = pos;
- do_skip = evalarg_call_bool(&skip, &err);
+ err = FALSE;
+ do_skip = eval_expr_to_bool(&argvars[4], &err);
curwin->w_cursor = save_pos;
if (err)
{
@@ -6523,7 +6520,6 @@ search_cmn(typval_T *argvars, pos_T *match_pos, int *flagsp)
curwin->w_set_curswant = TRUE;
theend:
p_ws = save_p_ws;
- evalarg_clean(&skip);
return retval;
}
@@ -6791,14 +6787,9 @@ searchpair_cmn(typval_T *argvars, pos_T *match_pos)
skip = NULL;
else
{
+ // Type is checked later.
skip = &argvars[4];
- if (skip->v_type != VAR_FUNC && skip->v_type != VAR_PARTIAL
- && skip->v_type != VAR_STRING)
- {
- // Type error
- semsg(_(e_invarg2), tv_get_string(&argvars[4]));
- goto theend;
- }
+
if (argvars[5].v_type != VAR_UNKNOWN)
{
lnum_stop = (long)tv_get_number_chk(&argvars[5], NULL);
@@ -6922,12 +6913,7 @@ do_searchpair(
options |= SEARCH_START;
if (skip != NULL)
- {
- // Empty string means to not use the skip expression.
- if (skip->v_type == VAR_STRING || skip->v_type == VAR_FUNC)
- use_skip = skip->vval.v_string != NULL
- && *skip->vval.v_string != NUL;
- }
+ use_skip = eval_expr_valid_arg(skip);
save_cursor = curwin->w_cursor;
pos = curwin->w_cursor;