neovim

Neovim text editor
git clone https://git.dasho.dev/neovim.git
Log | Files | Refs | README

commit 921e634119c14b03f9611f1602df171c9ffc9559
parent 0fd59f0121bbf8906203689c790eeba6f501600e
Author: ii14 <59243201+ii14@users.noreply.github.com>
Date:   Thu, 12 Jan 2023 16:25:44 +0100

fix(api): nvim_create_autocmd crash on invalid types inside pattern array

Co-authored-by: ii14 <ii14@users.noreply.github.com>
Diffstat:
Msrc/nvim/api/autocmd.c | 2+-
Mtest/functional/api/autocmd_spec.lua | 14++++++++++++++
2 files changed, 15 insertions(+), 1 deletion(-)

diff --git a/src/nvim/api/autocmd.c b/src/nvim/api/autocmd.c @@ -940,7 +940,7 @@ static bool get_patterns_from_pattern_or_buf(Array *patterns, Object pattern, Ob patlen = aucmd_pattern_length(pat); } } else if (v->type == kObjectTypeArray) { - if (!check_autocmd_string_array(*patterns, "pattern", err)) { + if (!check_autocmd_string_array(v->data.array, "pattern", err)) { return false; } diff --git a/test/functional/api/autocmd_spec.lua b/test/functional/api/autocmd_spec.lua @@ -613,6 +613,20 @@ describe('autocmd api', function() eq(false, success) matches("'group' must be a string or an integer", code) end) + + it('raises error for invalid pattern array', function() + local success, code = unpack(meths.exec_lua([[ + return {pcall(function() + vim.api.nvim_create_autocmd("FileType", { + pattern = {{}}, + command = "echo 'hello'", + }) + end)} + ]], {})) + + eq(false, success) + matches("All entries in 'pattern' must be strings", code) + end) end) describe('patterns', function()