diff options
| author | Christian Clason <c.clason@uni-graz.at> | 2024-09-04 09:08:06 +0200 |
|---|---|---|
| committer | Christian Clason <c.clason@uni-graz.at> | 2024-09-04 15:13:41 +0200 |
| commit | 3826d0c42ac635f560479b5b6ab522f6627a3466 (patch) | |
| tree | 449bcaebb042b58b7ee227acb1ca9a0c1b9829a1 /lua | |
| parent | fix(highlights): section headings in ini, git_config editorconfig (#7108) (diff) | |
| download | nvim-treesitter-3826d0c42ac635f560479b5b6ab522f6627a3466.tar nvim-treesitter-3826d0c42ac635f560479b5b6ab522f6627a3466.tar.gz nvim-treesitter-3826d0c42ac635f560479b5b6ab522f6627a3466.tar.bz2 nvim-treesitter-3826d0c42ac635f560479b5b6ab522f6627a3466.tar.lz nvim-treesitter-3826d0c42ac635f560479b5b6ab522f6627a3466.tar.xz nvim-treesitter-3826d0c42ac635f560479b5b6ab522f6627a3466.tar.zst nvim-treesitter-3826d0c42ac635f560479b5b6ab522f6627a3466.zip | |
fix(query): explicitly opt-in to legacy behavior
Diffstat (limited to 'lua')
| -rw-r--r-- | lua/nvim-treesitter/query_predicates.lua | 23 |
1 files changed, 13 insertions, 10 deletions
diff --git a/lua/nvim-treesitter/query_predicates.lua b/lua/nvim-treesitter/query_predicates.lua index 2d61ca6b4..5caaaa8b8 100644 --- a/lua/nvim-treesitter/query_predicates.lua +++ b/lua/nvim-treesitter/query_predicates.lua @@ -15,6 +15,9 @@ local non_filetype_match_injection_language_aliases = { ts = "typescript", } +-- compatibility shim for breaking change on nightly/0.11 +local opts = vim.fn.has "nvim-0.10" == 1 and { force = true, all = false } or true + local function get_parser_from_markdown_info_string(injection_alias) local match = vim.filetype.match { filename = "a." .. injection_alias } return match or non_filetype_match_injection_language_aliases[injection_alias] or injection_alias @@ -57,7 +60,7 @@ query.add_predicate("nth?", function(match, _pattern, _bufnr, pred) end return false -end, true) +end, opts) ---@param match (TSNode|nil)[] ---@param _pattern string @@ -91,9 +94,9 @@ local function has_ancestor(match, _pattern, _bufnr, pred) return false end -query.add_predicate("has-ancestor?", has_ancestor, true) +query.add_predicate("has-ancestor?", has_ancestor, opts) -query.add_predicate("has-parent?", has_ancestor, true) +query.add_predicate("has-parent?", has_ancestor, opts) ---@param match (TSNode|nil)[] ---@param _pattern string @@ -117,7 +120,7 @@ query.add_predicate("is?", function(match, _pattern, bufnr, pred) local _, _, kind = locals.find_definition(node, bufnr) return vim.tbl_contains(types, kind) -end, true) +end, opts) ---@param match (TSNode|nil)[] ---@param _pattern string @@ -137,7 +140,7 @@ query.add_predicate("kind-eq?", function(match, _pattern, _bufnr, pred) end return vim.tbl_contains(types, node:type()) -end, true) +end, opts) ---@param match (TSNode|nil)[] ---@param _ string @@ -158,7 +161,7 @@ query.add_directive("set-lang-from-mimetype!", function(match, _, bufnr, pred, m local parts = vim.split(type_attr_value, "/", {}) metadata["injection.language"] = parts[#parts] end -end, true) +end, opts) ---@param match (TSNode|nil)[] ---@param _ string @@ -173,10 +176,10 @@ query.add_directive("set-lang-from-info-string!", function(match, _, bufnr, pred end local injection_alias = vim.treesitter.get_node_text(node, bufnr):lower() metadata["injection.language"] = get_parser_from_markdown_info_string(injection_alias) -end, true) +end, opts) -- Just avoid some annoying warnings for this directive -query.add_directive("make-range!", function() end, true) +query.add_directive("make-range!", function() end, opts) --- transform node text to lower case (e.g., to make @injection.language case insensitive) --- @@ -197,7 +200,7 @@ query.add_directive("downcase!", function(match, _, bufnr, pred, metadata) metadata[id] = {} end metadata[id].text = string.lower(text) -end, true) +end, opts) -- Trim blank lines from end of the region -- Arguments are the captures to trim. @@ -235,4 +238,4 @@ query.add_directive("trim!", function(match, _, bufnr, pred, metadata) metadata[id].range = { start_row, start_col, end_row, end_col } end end -end, true) +end, opts) |
