aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/lua
diff options
context:
space:
mode:
authorLewis Russell <lewis6991@gmail.com>2025-01-13 06:58:33 +0000
committerGitHub <noreply@github.com>2025-01-13 06:58:33 +0000
commit99c4bd2f698345fd5706e0ff5d6221b8d3848cfb (patch)
treedbc073be79677c642c11835427ced264b80b547d /src/nvim/lua
parentf4cff3077b21ba110bc498f3e9331c16d3121cb1 (diff)
parentbd4ca22d0334a3323313dfd6975a80218ec65e36 (diff)
downloadrneovim-99c4bd2f698345fd5706e0ff5d6221b8d3848cfb.tar.gz
rneovim-99c4bd2f698345fd5706e0ff5d6221b8d3848cfb.tar.bz2
rneovim-99c4bd2f698345fd5706e0ff5d6221b8d3848cfb.zip
Merge pull request #31631 from ribru17/async_parse_attempt_2
feat(treesitter): async parsing
Diffstat (limited to 'src/nvim/lua')
-rw-r--r--src/nvim/lua/treesitter.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/src/nvim/lua/treesitter.c b/src/nvim/lua/treesitter.c
index 28ad2cf4d3..9bd2baad27 100644
--- a/src/nvim/lua/treesitter.c
+++ b/src/nvim/lua/treesitter.c
@@ -489,7 +489,11 @@ static int parser_parse(lua_State *L)
// Sometimes parsing fails (timeout, or wrong parser ABI)
// In those case, just return an error.
if (!new_tree) {
- return luaL_error(L, "An error occurred when parsing.");
+ if (ts_parser_timeout_micros(p) == 0) {
+ // No timeout set, must have had an error
+ return luaL_error(L, "An error occurred when parsing.");
+ }
+ return 0;
}
// The new tree will be pushed to the stack, without copy, ownership is now to the lua GC.