Skip to content

Commit

Permalink
vim-patch:8.2.2694: when 'matchpairs' is empty every character beeps (#…
Browse files Browse the repository at this point in the history
…14279)

Problem:    When 'matchpairs' is empty every character beeps. (Marco Hinz)
Solution:   Bail out when no character in 'matchpairs' was found.
            (closes vim/vim#8053)  Add assert_nobeep().
vim/vim@5b8cabf
  • Loading branch information
janlazo committed Apr 3, 2021
1 parent 6db3ba9 commit abdda66
Show file tree
Hide file tree
Showing 6 changed files with 57 additions and 21 deletions.
9 changes: 8 additions & 1 deletion runtime/doc/eval.txt
Original file line number Diff line number Diff line change
Expand Up @@ -2047,6 +2047,7 @@ assert_inrange({lower}, {upper}, {actual} [, {msg}])
Number assert {actual} is inside the range
assert_match({pat}, {text} [, {msg}])
Number assert {pat} matches {text}
assert_nobeep({cmd}) Number assert {cmd} does not cause a beep
assert_notequal({exp}, {act} [, {msg}])
Number assert {exp} is not equal {act}
assert_notmatch({pat}, {text} [, {msg}])
Expand Down Expand Up @@ -2638,7 +2639,8 @@ argv([{nr} [, {winid}])
assert_beeps({cmd}) *assert_beeps()*
Run {cmd} and add an error message to |v:errors| if it does
NOT produce a beep or visual bell.
Also see |assert_fails()| and |assert-return|.
Also see |assert_fails()|, |assert_nobeep()| and
|assert-return|.

*assert_equal()*
assert_equal({expected}, {actual}, [, {msg}])
Expand Down Expand Up @@ -2721,6 +2723,11 @@ assert_match({pattern}, {actual} [, {msg}])
< Will result in a string to be added to |v:errors|:
test.vim line 12: Pattern '^f.*o$' does not match 'foobar' ~

assert_nobeep({cmd}) *assert_nobeep()*
Run {cmd} and add an error message to |v:errors| if it
produces a beep or visual bell.
Also see |assert_beeps()|.

*assert_notequal()*
assert_notequal({expected}, {actual} [, {msg}])
The opposite of `assert_equal()`: add an error message to
Expand Down
29 changes: 29 additions & 0 deletions src/nvim/eval.c
Original file line number Diff line number Diff line change
Expand Up @@ -5981,6 +5981,35 @@ static void assert_append_cmd_or_arg(garray_T *gap, typval_T *argvars,
}
}

int assert_beeps(typval_T *argvars, bool no_beep)
FUNC_ATTR_NONNULL_ALL
{
const char *const cmd = tv_get_string_chk(&argvars[0]);
int ret = 0;

called_vim_beep = false;
suppress_errthrow = true;
emsg_silent = false;
do_cmdline_cmd(cmd);
if (no_beep ? called_vim_beep : !called_vim_beep) {
garray_T ga;
prepare_assert_error(&ga);
if (no_beep) {
ga_concat(&ga, (const char_u *)"command did beep: ");
} else {
ga_concat(&ga, (const char_u *)"command did not beep: ");
}
ga_concat(&ga, (const char_u *)cmd);
assert_error(&ga);
ga_clear(&ga);
ret = 1;
}

suppress_errthrow = false;
emsg_on_display = false;
return ret;
}

int assert_fails(typval_T *argvars)
FUNC_ATTR_NONNULL_ALL
{
Expand Down
3 changes: 2 additions & 1 deletion src/nvim/eval.lua
Original file line number Diff line number Diff line change
Expand Up @@ -26,14 +26,15 @@ return {
arglistid={args={0, 2}},
argv={args={0, 2}},
asin={args=1, func="float_op_wrapper", data="&asin"}, -- WJMc
assert_beeps={args={1, 2}},
assert_beeps={args={1}},
assert_equal={args={2, 3}},
assert_equalfile={args={2, 3}},
assert_exception={args={1, 2}},
assert_fails={args={1, 3}},
assert_false={args={1, 2}},
assert_inrange={args={3, 4}},
assert_match={args={2, 3}},
assert_nobeep={args={1}},
assert_notequal={args={2, 3}},
assert_notmatch={args={2, 3}},
assert_report={args=1},
Expand Down
26 changes: 7 additions & 19 deletions src/nvim/eval/funcs.c
Original file line number Diff line number Diff line change
Expand Up @@ -391,28 +391,16 @@ static void f_argv(typval_T *argvars, typval_T *rettv, FunPtr fptr)
}
}

// "assert_beeps(cmd [, error])" function
static void f_assert_beeps(typval_T *argvars, typval_T *rettv, FunPtr fptr)
{
const char *const cmd = tv_get_string_chk(&argvars[0]);
garray_T ga;
int ret = 0;

called_vim_beep = false;
suppress_errthrow = true;
emsg_silent = false;
do_cmdline_cmd(cmd);
if (!called_vim_beep) {
prepare_assert_error(&ga);
ga_concat(&ga, (const char_u *)"command did not beep: ");
ga_concat(&ga, (const char_u *)cmd);
assert_error(&ga);
ga_clear(&ga);
ret = 1;
}
rettv->vval.v_number = assert_beeps(argvars, false);
}

suppress_errthrow = false;
emsg_on_display = false;
rettv->vval.v_number = ret;
// "assert_nobeep(cmd [, error])" function
static void f_assert_nobeep(typval_T *argvars, typval_T *rettv, FunPtr fptr)
{
rettv->vval.v_number = assert_beeps(argvars, true);
}

// "assert_equal(expected, actual[, msg])" function
Expand Down
3 changes: 3 additions & 0 deletions src/nvim/search.c
Original file line number Diff line number Diff line change
Expand Up @@ -2326,6 +2326,9 @@ showmatch(
return;
}
}
if (*p == NUL) {
return;
}

if ((lpos = findmatch(NULL, NUL)) == NULL) { // no match, so beep
vim_beep(BO_MATCH);
Expand Down
8 changes: 8 additions & 0 deletions src/nvim/testdir/test_textformat.vim
Original file line number Diff line number Diff line change
Expand Up @@ -891,6 +891,14 @@ func Test_mps()
bwipe!
endfunc

func Test_empty_matchpairs()
split
set matchpairs= showmatch
call assert_nobeep('call feedkeys("ax\tx\t\<Esc>", "xt")')
set matchpairs& noshowmatch
bwipe!
endfunc

" Test for ra on multi-byte characters
func Test_ra_multibyte()
new
Expand Down

0 comments on commit abdda66

Please sign in to comment.