diff options
author | Gregory Anders <8965202+gpanders@users.noreply.github.com> | 2024-09-01 13:01:53 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-01 18:01:53 +0000 |
commit | 6913c5e1d975a11262d08b3339d50b579e6b6bb8 (patch) | |
tree | e69809ec7eb0c7cb14b505eaf56f9de19b02a349 /runtime/lua/vim/treesitter/_fold.lua | |
parent | 318c0415d5b10b44fee4afa06994734f1beb7e71 (diff) | |
download | rneovim-6913c5e1d975a11262d08b3339d50b579e6b6bb8.tar.gz rneovim-6913c5e1d975a11262d08b3339d50b579e6b6bb8.tar.bz2 rneovim-6913c5e1d975a11262d08b3339d50b579e6b6bb8.zip |
feat(treesitter)!: default to correct behavior for quantified captures (#30193)
For context, see https://github.com/neovim/neovim/pull/24738. Before
that PR, Nvim did not correctly handle captures with quantifiers. That
PR made the correct behavior opt-in to minimize breaking changes, with
the intention that the correct behavior would eventually become the
default. Users can still opt-in to the old (incorrect) behavior for now,
but this option will eventually be removed completely.
BREAKING CHANGE: Any plugin which uses `Query:iter_matches()` must
update their call sites to expect an array of nodes in the `match`
table, rather than a single node.
Diffstat (limited to 'runtime/lua/vim/treesitter/_fold.lua')
-rw-r--r-- | runtime/lua/vim/treesitter/_fold.lua | 4 |
1 files changed, 1 insertions, 3 deletions
diff --git a/runtime/lua/vim/treesitter/_fold.lua b/runtime/lua/vim/treesitter/_fold.lua index 27590eff5d..7375beaf9d 100644 --- a/runtime/lua/vim/treesitter/_fold.lua +++ b/runtime/lua/vim/treesitter/_fold.lua @@ -131,9 +131,7 @@ local function compute_folds_levels(bufnr, info, srow, erow, parse_injections) -- Collect folds starting from srow - 1, because we should first subtract the folds that end at -- srow - 1 from the level of srow - 1 to get accurate level of srow. - for _, match, metadata in - query:iter_matches(tree:root(), bufnr, math.max(srow - 1, 0), erow, { all = true }) - do + for _, match, metadata in query:iter_matches(tree:root(), bufnr, math.max(srow - 1, 0), erow) do for id, nodes in pairs(match) do if query.captures[id] == 'fold' then local range = ts.get_range(nodes[1], bufnr, metadata[id]) |