aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2023-05-06 20:00:17 +0800
committerGitHub <noreply@github.com>2023-05-06 20:00:17 +0800
commitca5a810c4a67c9c3f482d0c015270c26aee2c943 (patch)
treea8f2de41d37f356fd075996a9bc439b6cf4946c3
parenta67b76943a1e823e710be382f6e57fb0eff2c1a8 (diff)
downloadrneovim-ca5a810c4a67c9c3f482d0c015270c26aee2c943.tar.gz
rneovim-ca5a810c4a67c9c3f482d0c015270c26aee2c943.tar.bz2
rneovim-ca5a810c4a67c9c3f482d0c015270c26aee2c943.zip
vim-patch:9.0.1511: crash when using wrong arg types to assert_match() (#23507)
Problem: Crash when using wrong arg types to assert_match(). Solution: Check for NULL pointer. (closes vim/vim#12349) https://github.com/vim/vim/commit/12e7a1fe7527e9e59adbe248a95b4b532e3ec58c
-rw-r--r--src/nvim/testing.c10
-rw-r--r--test/old/testdir/test_assert.vim17
2 files changed, 22 insertions, 5 deletions
diff --git a/src/nvim/testing.c b/src/nvim/testing.c
index 430d6713ff..5483a58525 100644
--- a/src/nvim/testing.c
+++ b/src/nvim/testing.c
@@ -287,11 +287,10 @@ static int assert_match_common(typval_T *argvars, assert_type_T atype)
{
char buf1[NUMBUFLEN];
char buf2[NUMBUFLEN];
- const int called_emsg_before = called_emsg;
const char *const pat = tv_get_string_buf_chk(&argvars[0], buf1);
const char *const text = tv_get_string_buf_chk(&argvars[1], buf2);
- if (called_emsg == called_emsg_before
+ if (pat != NULL && text != NULL
&& pattern_match(pat, text, false) != (atype == ASSERT_MATCH)) {
garray_T ga;
prepare_assert_error(&ga);
@@ -393,12 +392,10 @@ static int assert_equalfile(typval_T *argvars)
{
char buf1[NUMBUFLEN];
char buf2[NUMBUFLEN];
- const int called_emsg_before = called_emsg;
const char *const fname1 = tv_get_string_buf_chk(&argvars[0], buf1);
const char *const fname2 = tv_get_string_buf_chk(&argvars[1], buf2);
- garray_T ga;
- if (called_emsg > called_emsg_before) {
+ if (fname1 == NULL || fname2 == NULL) {
return 0;
}
@@ -451,7 +448,9 @@ static int assert_equalfile(typval_T *argvars)
fclose(fd2);
}
}
+
if (IObuff[0] != NUL) {
+ garray_T ga;
prepare_assert_error(&ga);
if (argvars[2].v_type != VAR_UNKNOWN) {
char *const tofree = encode_tv2echo(&argvars[2], NULL);
@@ -475,6 +474,7 @@ static int assert_equalfile(typval_T *argvars)
ga_clear(&ga);
return 1;
}
+
return 0;
}
diff --git a/test/old/testdir/test_assert.vim b/test/old/testdir/test_assert.vim
index 57d11d0e3a..bc4e07e7c6 100644
--- a/test/old/testdir/test_assert.vim
+++ b/test/old/testdir/test_assert.vim
@@ -324,6 +324,23 @@ func Test_assert_fail_fails()
call remove(v:errors, 0)
endfunc
+func Test_assert_wrong_arg_emsg_off()
+ CheckFeature folding
+
+ new
+ call setline(1, ['foo', 'bar'])
+ 1,2fold
+
+ " This used to crash Vim
+ let &l:foldtext = 'assert_match({}, {})'
+ redraw!
+
+ let &l:foldtext = 'assert_equalfile({}, {})'
+ redraw!
+
+ bwipe!
+endfunc
+
func Test_assert_fails_in_try_block()
try
call assert_equal(0, assert_fails('throw "error"'))