aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbfredl <bjorn.linse@gmail.com>2024-07-21 16:29:16 +0200
committerGitHub <noreply@github.com>2024-07-21 16:29:16 +0200
commit7381f0a1d517474dcf8d8d019cbda430ce4bff23 (patch)
tree5d67b3ebf2f380a01976e9efd763795dbfbacb0a
parent80eda9726f9fe0810b8d689a2c9c7821cb95a8d6 (diff)
parent6720bd440f19747585713924de77e6231bdc3e42 (diff)
downloadrneovim-7381f0a1d517474dcf8d8d019cbda430ce4bff23.tar.gz
rneovim-7381f0a1d517474dcf8d8d019cbda430ce4bff23.tar.bz2
rneovim-7381f0a1d517474dcf8d8d019cbda430ce4bff23.zip
Merge pull request #29650 from ruuzia/fix_expression_parser_crash
fix: assert failure in VimL expression parser
-rw-r--r--src/nvim/viml/parser/expressions.c9
-rw-r--r--test/functional/api/vim_spec.lua7
2 files changed, 7 insertions, 9 deletions
diff --git a/src/nvim/viml/parser/expressions.c b/src/nvim/viml/parser/expressions.c
index 3403fb7926..d036d9e8a3 100644
--- a/src/nvim/viml/parser/expressions.c
+++ b/src/nvim/viml/parser/expressions.c
@@ -1264,21 +1264,12 @@ static bool viml_pexpr_handle_bop(const ParserState *const pstate, ExprASTStack
|| bop_node->type == kExprNodeSubscript)
? kEOpLvlSubscript
: node_lvl(*bop_node));
-#ifndef NDEBUG
- const ExprOpAssociativity bop_node_ass = (
- (bop_node->type == kExprNodeCall
- || bop_node->type == kExprNodeSubscript)
- ? kEOpAssLeft
- : node_ass(*bop_node));
-#endif
do {
ExprASTNode **new_top_node_p = kv_last(*ast_stack);
ExprASTNode *new_top_node = *new_top_node_p;
assert(new_top_node != NULL);
const ExprOpLvl new_top_node_lvl = node_lvl(*new_top_node);
const ExprOpAssociativity new_top_node_ass = node_ass(*new_top_node);
- assert(bop_node_lvl != new_top_node_lvl
- || bop_node_ass == new_top_node_ass);
if (top_node_p != NULL
&& ((bop_node_lvl > new_top_node_lvl
|| (bop_node_lvl == new_top_node_lvl
diff --git a/test/functional/api/vim_spec.lua b/test/functional/api/vim_spec.lua
index 035c8f70de..4210b7ecf0 100644
--- a/test/functional/api/vim_spec.lua
+++ b/test/functional/api/vim_spec.lua
@@ -2938,6 +2938,13 @@ describe('API', function()
return ('%s(%s)%s'):format(typ, args, rest)
end
end
+
+ it('does not crash parsing invalid VimL expression #29648', function()
+ api.nvim_input(':<C-r>=')
+ api.nvim_input('1bork/')
+ assert_alive()
+ end)
+
require('test.unit.viml.expressions.parser_tests')(it, _check_parsing, hl, fmtn)
end)