2022-11-14 00:10:02 +08:00
|
|
|
require "nvim-treesitter.highlight" -- yes, this is necessary to set the hlmap
|
2022-04-14 12:01:23 +08:00
|
|
|
local highlighter = require "vim.treesitter.highlighter"
|
|
|
|
local ts_utils = require "nvim-treesitter.ts_utils"
|
|
|
|
local parsers = require "nvim-treesitter.parsers"
|
|
|
|
|
|
|
|
local COMMENT_NODES = {
|
|
|
|
markdown = "html_block",
|
|
|
|
}
|
|
|
|
|
|
|
|
local function check_assertions(file)
|
|
|
|
local buf = vim.fn.bufadd(file)
|
|
|
|
vim.fn.bufload(file)
|
|
|
|
local lang = parsers.get_buf_lang(buf)
|
|
|
|
assert.same(
|
|
|
|
1,
|
|
|
|
vim.fn.executable "highlight-assertions",
|
|
|
|
'"highlight-assertions" not executable!'
|
|
|
|
.. ' Get it via "cargo install --git https://github.com/theHamsta/highlight-assertions"'
|
|
|
|
)
|
|
|
|
local comment_node = COMMENT_NODES[lang] or "comment"
|
|
|
|
local assertions = vim.fn.json_decode(
|
|
|
|
vim.fn.system(
|
|
|
|
"highlight-assertions -p '"
|
|
|
|
.. vim.api.nvim_get_runtime_file("parser/" .. lang .. ".so", false)[1]
|
|
|
|
.. "' -s '"
|
|
|
|
.. file
|
|
|
|
.. "' -c "
|
|
|
|
.. comment_node
|
|
|
|
)
|
|
|
|
)
|
|
|
|
local parser = parsers.get_parser(buf, lang)
|
|
|
|
|
|
|
|
local self = highlighter.new(parser, {})
|
|
|
|
|
|
|
|
assert.True(#assertions > 0, "No assertions detected!")
|
|
|
|
for _, assertion in ipairs(assertions) do
|
|
|
|
local row = assertion.position.row
|
|
|
|
local col = assertion.position.column
|
|
|
|
|
|
|
|
local captures = {}
|
|
|
|
local highlights = {}
|
|
|
|
self.tree:for_each_tree(function(tstree, tree)
|
|
|
|
if not tstree then
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
local root = tstree:root()
|
|
|
|
local root_start_row, _, root_end_row, _ = root:range()
|
|
|
|
|
|
|
|
-- Only worry about trees within the line range
|
|
|
|
if root_start_row > row or root_end_row < row then
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
local query = self:get_query(tree:lang())
|
|
|
|
|
|
|
|
-- Some injected languages may not have highlight queries.
|
|
|
|
if not query:query() then
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
local iter = query:query():iter_captures(root, self.bufnr, row, row + 1)
|
|
|
|
|
|
|
|
for capture, node, _ in iter do
|
|
|
|
local hl = query.hl_cache[capture]
|
|
|
|
assert.is.truthy(hl)
|
|
|
|
|
|
|
|
assert.Truthy(node)
|
|
|
|
assert.is.number(row)
|
|
|
|
assert.is.number(col)
|
|
|
|
if hl and ts_utils.is_in_node_range(node, row, col) then
|
|
|
|
local c = query._query.captures[capture] -- name of the capture in the query
|
2022-11-14 00:10:02 +08:00
|
|
|
if c ~= nil then
|
2022-04-14 12:01:23 +08:00
|
|
|
captures[c] = true
|
2022-11-14 00:10:02 +08:00
|
|
|
local general_hl = query:_get_hl_from_capture(capture)
|
|
|
|
highlights[general_hl] = true
|
2022-04-14 12:01:23 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end, true)
|
|
|
|
assert.True(
|
|
|
|
captures[assertion.expected_capture_name] or highlights[assertion.expected_capture_name],
|
|
|
|
"Error in at "
|
|
|
|
.. file
|
|
|
|
.. ":"
|
|
|
|
.. (row + 1)
|
|
|
|
.. ":"
|
|
|
|
.. (col + 1)
|
|
|
|
.. ': expected "'
|
|
|
|
.. assertion.expected_capture_name
|
|
|
|
.. '", captures: '
|
|
|
|
.. vim.inspect(vim.tbl_keys(captures))
|
|
|
|
.. '", highlights: '
|
|
|
|
.. vim.inspect(vim.tbl_keys(highlights))
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe("highlight queries", function()
|
|
|
|
local files = vim.fn.split(vim.fn.glob "tests/query/highlights/**/*.*")
|
|
|
|
for _, file in ipairs(files) do
|
|
|
|
it(file, function()
|
|
|
|
check_assertions(file)
|
|
|
|
end)
|
|
|
|
end
|
|
|
|
end)
|