ci: check capture names in queries

This commit is contained in:
Thomas Vigouroux
2020-09-07 12:07:17 +02:00
parent 4b578c52bd
commit 5d2b866518
2 changed files with 70 additions and 25 deletions

View File

@@ -84,19 +84,20 @@ are optional and will not have any effect for now.
```
@embedded
@injection
language
content
@injection.language
@injection.content
```
#### Constants
```
@constant
builtin
macro
@constant.builtin
@constant.macro
@string
regex
escape
@string.regex
@string.escape
@string.special
@character
@number
@boolean
@@ -107,13 +108,13 @@ are optional and will not have any effect for now.
```
@function
builtin
macro
@function.builtin
@function.macro
@parameter
reference references to parameters
@method
@field or @property
@field
@property
@constructor
```
@@ -126,19 +127,20 @@ are optional and will not have any effect for now.
@label for C/Lua-like labels
@operator
@keyword
function
@keyword.function
@exception
@include keywords for including modules (e.g. import/from in Python)
@type
builtin
@type.builtin
@structure
@attribute for e.g. Python decorators
```
#### Variables
```
@variable
builtin
@variable.builtin
```
#### Text
@@ -158,15 +160,19 @@ Mainly for markup languages.
### Locals
```
@definition for various definitions
function
method
var
macro
type
field
namespace for modules or C++ namespaces
import for imported names
doc for documentation adjacent to a definition. E.g.
@definition.function
@definition.method
@definition.var
@definition.parameter
@definition.macro
@definition.type
@definition.field
@definition.enum
@definition.namespace for modules or C++ namespaces
@definition.import for imported names
@definition.associated to determine the type of a variable
@definition.doc for documentation adjacent to a definition. E.g.
```
```scheme
@@ -178,6 +184,7 @@ Mainly for markup languages.
```
@scope
@reference
@constructor
```
#### Definition Scope
@@ -208,7 +215,11 @@ Possible scope values are:
### Folds
You can define folds for a given language by adding a `fold.scm` query.
The `@fold` capture is used to fold a node.
You can define folds for a given language by adding a `fold.scm` query :
```
@fold
```
If the `fold.scm` query is not present, this will fallback to the `@scope` captures in the `locals`
query.

View File

@@ -1,13 +1,47 @@
-- Execute as `nvim --headless -c "luafile ./scripts/check-queries.lua"`
local function extract_captures()
local lines = vim.fn.readfile("CONTRIBUTING.md")
local captures = {}
local current_query
for _, line in ipairs(lines) do
if vim.startswith(line, "### ") then
current_query = vim.fn.tolower(line:sub(5))
elseif vim.startswith(line, "@") and current_query then
if not captures[current_query] then
captures[current_query] = {}
end
table.insert(captures[current_query], vim.split(line:sub(2), " ", true)[1])
end
end
return captures
end
local function do_check()
local parsers = require 'nvim-treesitter.parsers'.available_parsers()
local queries = require 'nvim-treesitter.query'
local query_types = queries.built_in_query_groups
local captures = extract_captures()
for _, lang in pairs(parsers) do
for _, query_type in pairs(query_types) do
print('Checking '..lang..' '..query_type)
queries.get_query(lang, query_type)
local query = queries.get_query(lang, query_type)
if query then
for _, capture in ipairs(query.captures) do
if not vim.startswith(capture, "_") -- We ignore things like _helper
and captures[query_type]
and not capture:find("^[A-Z]") -- Highlight groups
and not vim.tbl_contains(captures[query_type], capture) then
error(string.format("Invalid capture @%s in %s for %s.", capture, query_type, lang))
end
end
end
end
end
end