diff options
| author | Christian Clason <c.clason@uni-graz.at> | 2023-05-31 09:19:16 +0200 |
|---|---|---|
| committer | Christian Clason <c.clason@uni-graz.at> | 2025-05-12 18:43:40 +0200 |
| commit | cd2c826972f7bd6fd8f0c076fb9bfabe3f82209e (patch) | |
| tree | 4b29ae97fb9d7522766ace64bde404ae38facd8f | |
| parent | ci: remove update-lockfile shell script (diff) | |
| download | nvim-treesitter-cd2c826972f7bd6fd8f0c076fb9bfabe3f82209e.tar nvim-treesitter-cd2c826972f7bd6fd8f0c076fb9bfabe3f82209e.tar.gz nvim-treesitter-cd2c826972f7bd6fd8f0c076fb9bfabe3f82209e.tar.bz2 nvim-treesitter-cd2c826972f7bd6fd8f0c076fb9bfabe3f82209e.tar.lz nvim-treesitter-cd2c826972f7bd6fd8f0c076fb9bfabe3f82209e.tar.xz nvim-treesitter-cd2c826972f7bd6fd8f0c076fb9bfabe3f82209e.tar.zst nvim-treesitter-cd2c826972f7bd6fd8f0c076fb9bfabe3f82209e.zip | |
fix: install dependencies
| -rw-r--r-- | SUPPORTED_LANGUAGES.md | 23 | ||||
| -rw-r--r-- | TODO.md | 7 | ||||
| -rw-r--r-- | lua/nvim-treesitter/config.lua | 13 | ||||
| -rw-r--r-- | lua/nvim-treesitter/health.lua | 26 | ||||
| -rw-r--r-- | lua/nvim-treesitter/install.lua | 137 | ||||
| -rw-r--r-- | lua/nvim-treesitter/parsers.lua | 57 | ||||
| -rwxr-xr-x | scripts/update-lockfile.lua | 22 | ||||
| -rwxr-xr-x | scripts/update-readme.lua | 31 |
8 files changed, 196 insertions, 120 deletions
diff --git a/SUPPORTED_LANGUAGES.md b/SUPPORTED_LANGUAGES.md index aef22b34d..18780fd6f 100644 --- a/SUPPORTED_LANGUAGES.md +++ b/SUPPORTED_LANGUAGES.md @@ -58,13 +58,14 @@ Language | Tier | Queries | CLI | NPM | Maintainer [dtd](https://github.com/tree-sitter-grammars/tree-sitter-xml) | stable | `HF JL` | | | @ObserverOfTime [earthfile](https://github.com/glehmann/tree-sitter-earthfile) | community | `H J ` | | | @glehmann [ebnf](https://github.com/RubixDev/ebnf) | unstable | `H ` | | | @RubixDev +ecma (queries only)[^ecma] | | `HFIJL` | | | @steelsojka [eds](https://github.com/uyha/tree-sitter-eds) | community | `HF ` | | | @uyha [eex](https://github.com/connorlay/tree-sitter-eex) | | `H J ` | | | @connorlay [elixir](https://github.com/elixir-lang/tree-sitter-elixir) | | `HFIJL` | | | @connorlay [elm](https://github.com/elm-tooling/tree-sitter-elm) | | `H J ` | | | @zweimach [elsa](https://github.com/glapa-grossklag/tree-sitter-elsa) | | `HFIJL` | | | @glapa-grossklag, @amaanq [elvish](https://github.com/elves/tree-sitter-elvish) | | `H J ` | | | @elves -[embedded_template](https://github.com/tree-sitter/tree-sitter-embedded-template) | | `H J ` | | | +[embedded_template](https://github.com/tree-sitter/tree-sitter-embedded-template) | unstable | `H J ` | | | [erlang](https://github.com/WhatsApp/tree-sitter-erlang) | | `HF ` | | | @filmor [facility](https://github.com/FacilityApi/tree-sitter-facility) | community | `HFIJ ` | | | @bryankenote [faust](https://github.com/khiner/tree-sitter-faust) | community | `H J ` | | | @khiner @@ -100,9 +101,9 @@ Language | Tier | Queries | CLI | NPM | Maintainer [graphql](https://github.com/bkegley/tree-sitter-graphql) | | `H IJ ` | | | @bkegley [groovy](https://github.com/murtaza64/tree-sitter-groovy) | community | `HFIJL` | | | @murtaza64 [gstlaunch](https://github.com/theHamsta/tree-sitter-gstlaunch) | stable | `H ` | | | @theHamsta -[hack](https://github.com/slackhq/tree-sitter-hack) | | `H ` | | | +[hack](https://github.com/slackhq/tree-sitter-hack) | unstable | `H ` | | | [hare](https://github.com/amaanq/tree-sitter-hare) | | `HFIJL` | | | @amaanq -[haskell](https://github.com/tree-sitter/tree-sitter-haskell) | | `HF J ` | | | @mrcjkb +[haskell](https://github.com/tree-sitter/tree-sitter-haskell) | community | `HF J ` | | | @mrcjkb [haskell_persistent](https://github.com/MercuryTechnologies/tree-sitter-haskell-persistent) | | `HF ` | | | @lykahb [hcl](https://github.com/MichaHoffmann/tree-sitter-hcl) | | `HFIJ ` | | | @MichaHoffmann [heex](https://github.com/connorlay/tree-sitter-heex) | | `HFIJL` | | | @connorlay @@ -113,6 +114,7 @@ Language | Tier | Queries | CLI | NPM | Maintainer [hocon](https://github.com/antosha417/tree-sitter-hocon) | | `HF J ` | | ✓ | @antosha417 [hoon](https://github.com/urbit-pilled/tree-sitter-hoon) | unstable | `HF L` | | | @urbit-pilled [html](https://github.com/tree-sitter/tree-sitter-html) | | `HFIJL` | | | @TravonteD +html_tags (queries only)[^html_tags] | | `H IJ ` | | | @TravonteD [htmldjango](https://github.com/interdependence/tree-sitter-htmldjango) | unstable | `HFIJ ` | | | @ObserverOfTime [http](https://github.com/rest-nvim/tree-sitter-http) | | `H J ` | | | @amaanq, @NTBBloodbath [hurl](https://github.com/pfeiferj/tree-sitter-hurl) | community | `HFIJ ` | | | @pfeiferj @@ -128,8 +130,9 @@ Language | Tier | Queries | CLI | NPM | Maintainer [jsdoc](https://github.com/tree-sitter/tree-sitter-jsdoc) | | `H ` | | | @steelsojka [json](https://github.com/tree-sitter/tree-sitter-json) | | `HFI L` | | | @steelsojka [json5](https://github.com/Joakker/tree-sitter-json5) | | `H J ` | | | @Joakker -[jsonc](https://gitlab.com/WhyNotHugo/tree-sitter-jsonc.git)[^jsonc] | | `HFIJL` | | ✓ | @WhyNotHugo +[jsonc](https://gitlab.com/WhyNotHugo/tree-sitter-jsonc.git) | | `HFIJL` | | ✓ | @WhyNotHugo [jsonnet](https://github.com/sourcegraph/tree-sitter-jsonnet) | | `HF L` | | | @nawordar +jsx (queries only)[^jsx] | | `HFIJ ` | | | @steelsojka [julia](https://github.com/tree-sitter/tree-sitter-julia) | community | `HFIJL` | | | @theHamsta [just](https://github.com/IndianBoy42/tree-sitter-just) | community | `HFIJL` | | | @Hubro [kconfig](https://github.com/amaanq/tree-sitter-kconfig) | stable | `HFIJL` | | | @amaanq @@ -160,7 +163,7 @@ Language | Tier | Queries | CLI | NPM | Maintainer [mlir](https://github.com/artagnon/tree-sitter-mlir) | unstable | `H L` | ✓ | | @artagnon [muttrc](https://github.com/neomutt/tree-sitter-muttrc) | community | `H J ` | | | @Freed-Wu [nasm](https://github.com/naclsn/tree-sitter-nasm) | stable | `H J ` | | | @ObserverOfTime -[nickel](https://github.com/nickel-lang/tree-sitter-nickel) | | `H I ` | | | +[nickel](https://github.com/nickel-lang/tree-sitter-nickel) | unstable | `H I ` | | | [nim](https://github.com/alaviss/tree-sitter-nim) | community | `HF JL` | | | @aMOPel [nim_format_string](https://github.com/aMOPel/tree-sitter-nim-format-string) | community | `H J ` | | | @aMOPel [ninja](https://github.com/alemuller/tree-sitter-ninja) | | `HFI ` | | | @alemuller @@ -173,7 +176,7 @@ Language | Tier | Queries | CLI | NPM | Maintainer [ocaml_interface](https://github.com/tree-sitter/tree-sitter-ocaml) | | `HFIJL` | | | @undu [ocamllex](https://github.com/atom-ocaml/tree-sitter-ocamllex) | | `H J ` | ✓ | | @undu [odin](https://github.com/amaanq/tree-sitter-odin) | | `HFIJL` | | | @amaanq -[org](https://github.com/milisims/tree-sitter-org) | | ` ` | | | +[org](https://github.com/milisims/tree-sitter-org) | unstable | ` ` | | | [pascal](https://github.com/Isopod/tree-sitter-pascal.git) | | `HFIJL` | | | @Isopod [passwd](https://github.com/ath3/tree-sitter-passwd) | | `H ` | | | @amaanq [pem](https://github.com/ObserverOfTime/tree-sitter-pem) | stable | `HF J ` | | | @ObserverOfTime @@ -221,7 +224,7 @@ Language | Tier | Queries | CLI | NPM | Maintainer [scala](https://github.com/tree-sitter/tree-sitter-scala) | | `HF JL` | | | @stevanmilic [scfg](https://git.sr.ht/~rockorager/tree-sitter-scfg) | community | `H J ` | ✓ | | @WhyNotHugo [scheme](https://github.com/6cdh/tree-sitter-scheme) | unstable | `HF J ` | | | -[scss](https://github.com/serenadeai/tree-sitter-scss) | | `HFI ` | | | @elianiva +[scss](https://github.com/serenadeai/tree-sitter-scss) | community | `HFI ` | | | @elianiva [slang](https://github.com/theHamsta/tree-sitter-slang)[^slang] | unstable | `HFIJL` | | ✓ | @theHamsta [slint](https://github.com/slint-ui/tree-sitter-slint) | community | `HFIJL` | | | @hunger [smali](https://github.com/tree-sitter-grammars/tree-sitter-smali) | community | `HFIJL` | | | @amaanq @@ -249,7 +252,7 @@ Language | Tier | Queries | CLI | NPM | Maintainer [tcl](https://github.com/tree-sitter-grammars/tree-sitter-tcl) | stable | `HFI ` | | | @lewis6991 [teal](https://github.com/euclidianAce/tree-sitter-teal) | | `HFIJL` | ✓ | | @euclidianAce [templ](https://github.com/vrischmann/tree-sitter-templ) | community | `H J ` | | | @vrischmann -[terraform](https://github.com/MichaHoffmann/tree-sitter-hcl) | | `HFIJ ` | | | @MichaHoffmann +[terraform](https://github.com/MichaHoffmann/tree-sitter-hcl) | community | `HFIJ ` | | | @MichaHoffmann [textproto](https://github.com/PorterAtGoogle/tree-sitter-textproto) | community | `HFI ` | | | @Porter [thrift](https://github.com/duskmoon314/tree-sitter-thrift) | | `HFIJL` | | | @amaanq, @duskmoon314 [tiger](https://github.com/ambroisie/tree-sitter-tiger) | | `HFIJL` | | | @ambroisie @@ -288,11 +291,13 @@ Language | Tier | Queries | CLI | NPM | Maintainer [yuck](https://github.com/Philipp-M/tree-sitter-yuck) | | `HFIJL` | | | @Philipp-M, @amaanq [zathurarc](https://github.com/Freed-Wu/tree-sitter-zathurarc) | community | `H J ` | | | @Freed-Wu [zig](https://github.com/maxxnino/tree-sitter-zig) | | `HFIJL` | | | @maxxnino +[^ecma]: queries required by javascript, typescript, tsx, qmljs [^gdscript]: Godot [^git_config]: git_config [^glimmer]: Glimmer and Ember [^godot_resource]: Godot Resources -[^jsonc]: JSON with comments +[^html_tags]: queries required by html, astro, vue, svelte +[^jsx]: queries required by javascript, tsx [^luap]: Lua patterns [^markdown]: basic highlighting [^markdown_inline]: needed for full highlighting @@ -5,14 +5,9 @@ This document lists the planned and finished changes in this rewrite towards [Nv ## TODO - [ ] **`query_predicates.lua`:** upstream/remove -- [ ] **`parsers.lua`:** add dependencies (and "query-only" langs like ecma, jsx, html_tags, ...) - [ ] **`parsers.lua`:** assign tiers - [ ] **`parsers.lua`:** modularize? -- [ ] **`install.lua`:** simplify compilation: - - hardcode one compiler + args per platform - - provide `install.compile_command` for overriding (function that takes files, ...?) - - allow using repo makefile (norg!)? - - ...or switch to makefile completely? +- [ ] **`install.lua`:** drop norg (and makefile); document c++11 requirement - [ ] **`locals.lua`:** move to `nvim-treesitter-refactor`? - [ ] **update-lockfile:** allow specifying version in addition to commit hash (for Tier 1) - [ ] **update-lockfile:** one commit per parser/tier? diff --git a/lua/nvim-treesitter/config.lua b/lua/nvim-treesitter/config.lua index b8a9f6e91..c77ee1358 100644 --- a/lua/nvim-treesitter/config.lua +++ b/lua/nvim-treesitter/config.lua @@ -74,12 +74,11 @@ end ---@return string[] function M.installed_parsers() - local install_dir = M.get_install_dir('parser') + local install_dir = M.get_install_dir('queries') local installed = {} --- @type string[] for f in vim.fs.dir(install_dir) do - local lang = assert(f:match('(.*)%..*')) - installed[#installed + 1] = lang + installed[#installed + 1] = f end return installed @@ -139,6 +138,14 @@ function M.norm_languages(languages, skip) end, languages) --[[@as string[] ]] end + if not (skip and skip.dependencies) then + for _, lang in pairs(languages) do + if parsers.configs[lang].requires then + vim.list_extend(languages, parsers.configs[lang].requires) + end + end + end + return languages end diff --git a/lua/nvim-treesitter/health.lua b/lua/nvim-treesitter/health.lua index 1e17bb00b..037887c59 100644 --- a/lua/nvim-treesitter/health.lua +++ b/lua/nvim-treesitter/health.lua @@ -1,4 +1,5 @@ local install = require('nvim-treesitter.install') +local parsers = require('nvim-treesitter.parsers') local config = require('nvim-treesitter.config') local util = require('nvim-treesitter.util') local tsq = vim.treesitter.query @@ -123,14 +124,25 @@ function M.check() -- Installation dependency checks install_health() -- Parser installation checks + local languages = config.installed_parsers() local parser_installation = { 'Parser/Features' .. string.rep(' ', 9) .. 'H L F I J' } - for _, parser_name in pairs(config.installed_parsers()) do - local out = ' - ' .. parser_name .. string.rep(' ', 20 - #parser_name) - for _, query_group in pairs(M.bundled_queries) do - local status, err = query_status(parser_name, query_group) - out = out .. status .. ' ' - if err then - table.insert(error_collection, { parser_name, query_group, err }) + for _, lang in pairs(languages) do + local parser = parsers.configs[lang] + local out = ' - ' .. lang .. string.rep(' ', 20 - #lang) + if parser.install_info then + for _, query_group in pairs(M.bundled_queries) do + local status, err = query_status(lang, query_group) + out = out .. status .. ' ' + if err then + table.insert(error_collection, { lang, query_group, err }) + end + end + end + if parser.requires then + for _, p in pairs(parser.requires) do + if not vim.list_contains(languages, p) then + table.insert(error_collection, { lang, 'queries', 'dependency ' .. p .. ' missing' }) + end end end table.insert(parser_installation, vim.fn.trim(out, ' ', 2)) diff --git a/lua/nvim-treesitter/install.lua b/lua/nvim-treesitter/install.lua index ab9543673..3fba73db4 100644 --- a/lua/nvim-treesitter/install.lua +++ b/lua/nvim-treesitter/install.lua @@ -449,74 +449,76 @@ local function install_lang(lang, cache_dir, install_dir, force, generate_from_g end end - local cc = M.select_executable(M.compilers) - if not cc then - cc_err() - return - end + local logger = log.new('install/' .. lang) + local err local repo = get_parser_install_info(lang) + if repo then + local cc = M.select_executable(M.compilers) + if not cc then + cc_err() + return + end - local project_name = 'tree-sitter-' .. lang - - local logger = log.new('install/' .. lang) + local project_name = 'tree-sitter-' .. lang - generate_from_grammar = repo.requires_generate_from_grammar or generate_from_grammar + generate_from_grammar = repo.requires_generate_from_grammar or generate_from_grammar - if generate_from_grammar and vim.fn.executable('tree-sitter') ~= 1 then - logger:error('tree-sitter CLI not found: `tree-sitter` is not executable') - end + if generate_from_grammar and vim.fn.executable('tree-sitter') ~= 1 then + logger:error('tree-sitter CLI not found: `tree-sitter` is not executable') + end - if generate_from_grammar and vim.fn.executable('node') ~= 1 then - logger:error('Node JS not found: `node` is not executable') - end + if generate_from_grammar and vim.fn.executable('node') ~= 1 then + logger:error('Node JS not found: `node` is not executable') + end - local revision = repo.revision or get_target_revision(lang) + local revision = repo.revision or get_target_revision(lang) - local maybe_local_path = fs.normalize(repo.url) - local from_local_path = vim.fn.isdirectory(maybe_local_path) == 1 - if from_local_path then - repo.url = maybe_local_path - end + local maybe_local_path = fs.normalize(repo.url) + local from_local_path = vim.fn.isdirectory(maybe_local_path) == 1 + if from_local_path then + repo.url = maybe_local_path + end - if not from_local_path then - util.delete(fs.joinpath(cache_dir, project_name)) - local project_dir = fs.joinpath(cache_dir, project_name) + if not from_local_path then + util.delete(fs.joinpath(cache_dir, project_name)) + local project_dir = fs.joinpath(cache_dir, project_name) - revision = revision or repo.branch or 'master' + revision = revision or repo.branch or 'master' - if can_download_tar(repo) then - do_download_tar(logger, repo, project_name, cache_dir, revision, project_dir) - else - do_download_git(logger, repo, project_name, cache_dir, revision, project_dir) + if can_download_tar(repo) then + do_download_tar(logger, repo, project_name, cache_dir, revision, project_dir) + else + do_download_git(logger, repo, project_name, cache_dir, revision, project_dir) + end end - end - local compile_location = get_compile_location(repo, cache_dir, project_name, from_local_path) + local compile_location = get_compile_location(repo, cache_dir, project_name, from_local_path) - if generate_from_grammar then - do_generate_from_grammar(logger, repo, compile_location) - end + if generate_from_grammar then + do_generate_from_grammar(logger, repo, compile_location) + end - logger:info('Compiling parser') - local r = do_compile(repo, cc, compile_location) - if r.exit_code > 0 then - logger:error('Error during compilation: ' .. vim.inspect(r.stderr)) - end + logger:info('Compiling parser') + local r = do_compile(repo, cc, compile_location) + if r.exit_code > 0 then + logger:error('Error during compilation: ' .. vim.inspect(r.stderr)) + end - local parser_lib_name = fs.joinpath(install_dir, lang) .. '.so' + local parser_lib_name = fs.joinpath(install_dir, lang) .. '.so' - local err = uv_copyfile(fs.joinpath(compile_location, 'parser.so'), parser_lib_name) - a.main() - if err then - logger:error(err) - end + err = uv_copyfile(fs.joinpath(compile_location, 'parser.so'), parser_lib_name) + a.main() + if err then + logger:error(err) + end - local revfile = fs.joinpath(config.get_install_dir('parser-info') or '', lang .. '.revision') - util.write_file(revfile, revision or '') + local revfile = fs.joinpath(config.get_install_dir('parser-info') or '', lang .. '.revision') + util.write_file(revfile, revision or '') - if not from_local_path then - util.delete(fs.joinpath(cache_dir, project_name)) + if not from_local_path then + util.delete(fs.joinpath(cache_dir, project_name)) + end end local queries = fs.joinpath(config.get_install_dir('queries'), lang) @@ -527,7 +529,7 @@ local function install_lang(lang, cache_dir, install_dir, force, generate_from_g if err then logger:error(err) end - logger:info('Parser installed') + logger:info('Language installed') end --- Throttles a function using the first argument as an ID @@ -617,7 +619,7 @@ local function install(languages, options, _callback) a.join(max_jobs, nil, tasks) if #tasks > 1 then a.main() - log.info('Installed %d/%d parsers', done, #tasks) + log.info('Installed %d/%d languages', done, #tasks) end end @@ -650,34 +652,35 @@ end, 2) local function uninstall_lang(lang, parser, queries) local logger = log.new('uninstall/' .. lang) logger:debug('Uninstalling ' .. lang) - if vim.fn.filereadable(parser) ~= 1 then - return - end - logger:debug('Unlinking ' .. parser) - local perr = uv_unlink(parser) - a.main() + if vim.fn.filereadable(parser) == 1 then + logger:debug('Unlinking ' .. parser) + local perr = uv_unlink(parser) + a.main() - if perr then - log.error(perr) + if perr then + log.error(perr) + end end - logger:debug('Unlinking ' .. queries) - local qerr = uv_unlink(queries) - a.main() + if vim.fn.isdirectory(queries) == 1 then + logger:debug('Unlinking ' .. queries) + local qerr = uv_unlink(queries) + a.main() - if qerr then - logger:error(qerr) + if qerr then + logger:error(qerr) + end end - logger:info('Parser uninstalled') + logger:info('Language uninstalled') end --- @param languages string[]|string --- @param _options? UpdateOptions --- @param _callback fun() M.uninstall = a.sync(function(languages, _options, _callback) - languages = config.norm_languages(languages or 'all', { missing = true }) + languages = config.norm_languages(languages or 'all', { missing = true, dependencies = true }) local parser_dir = config.get_install_dir('parser') local query_dir = config.get_install_dir('queries') @@ -701,7 +704,7 @@ M.uninstall = a.sync(function(languages, _options, _callback) a.join(max_jobs, nil, tasks) if #tasks > 1 then a.main() - log.info('Uninstalled %d/%d parsers', done, #tasks) + log.info('Uninstalled %d/%d languages', done, #tasks) end end, 2) diff --git a/lua/nvim-treesitter/parsers.lua b/lua/nvim-treesitter/parsers.lua index 114ab40c6..3a9a36aaf 100644 --- a/lua/nvim-treesitter/parsers.lua +++ b/lua/nvim-treesitter/parsers.lua @@ -12,6 +12,7 @@ ---@field install_info InstallInfo ---@field filetype string[] ---@field maintainers string[] +---@field requires string[] ---@field tier integer|nil ---@field readme_note string|nil @@ -44,6 +45,7 @@ M.configs = { generate_requires_npm = true, }, maintainers = { '@dlvandenberg' }, + requires = { 'html', 'html_tags' }, tier = 4, }, @@ -63,6 +65,7 @@ M.configs = { files = { 'src/parser.c', 'src/scanner.c' }, }, maintainers = { '@ObserverOfTime' }, + requires = { 'cpp' }, }, asm = { @@ -80,6 +83,7 @@ M.configs = { files = { 'src/parser.c', 'src/scanner.c' }, }, maintainers = { '@virchau13' }, + requires = { 'html', 'html_tags' }, }, authzed = { @@ -309,6 +313,7 @@ M.configs = { generate_requires_npm = true, }, maintainers = { '@theHamsta' }, + requires = { 'c' }, }, css = { @@ -326,6 +331,7 @@ M.configs = { location = 'csv', }, maintainers = { '@amaanq' }, + requires = { 'tsv' }, tier = 2, }, @@ -336,6 +342,7 @@ M.configs = { generate_requires_npm = true, }, maintainers = { '@theHamsta' }, + requires = { 'cpp' }, }, cue = { @@ -476,6 +483,12 @@ M.configs = { tier = 4, }, + ecma = { + maintainers = { '@steelsojka' }, + readme_note = 'queries required by javascript, typescript, tsx, qmljs', + tier = 3, + }, + editorconfig = { install_info = { url = 'https://github.com/ValdezFOmar/tree-sitter-editorconfig', @@ -539,6 +552,7 @@ M.configs = { url = 'https://github.com/tree-sitter/tree-sitter-embedded-template', files = { 'src/parser.c' }, }, + tier = 4, }, enforce = { @@ -796,6 +810,7 @@ M.configs = { generate_requires_npm = true, }, maintainers = { '@theHamsta' }, + requires = { 'c' }, }, gn = { @@ -925,6 +940,7 @@ M.configs = { url = 'https://github.com/slackhq/tree-sitter-hack', files = { 'src/parser.c', 'src/scanner.c' }, }, + tier = 4, }, hare = { @@ -941,6 +957,7 @@ M.configs = { files = { 'src/parser.c', 'src/scanner.c' }, }, maintainers = { '@mrcjkb' }, + tier = 3, }, haskell_persistent = { @@ -985,6 +1002,7 @@ M.configs = { generate_requires_npm = true, }, maintainers = { '@winston0410' }, + requires = { 'json' }, }, hlsl = { @@ -994,6 +1012,7 @@ M.configs = { generate_requires_npm = true, }, maintainers = { '@theHamsta' }, + requires = { 'cpp' }, }, hlsplaylist = { @@ -1023,12 +1042,18 @@ M.configs = { tier = 4, }, + html_tags = { + maintainers = { '@TravonteD' }, + readme_note = 'queries required by html, astro, vue, svelte', + }, + html = { install_info = { url = 'https://github.com/tree-sitter/tree-sitter-html', files = { 'src/parser.c', 'src/scanner.c' }, }, maintainers = { '@TravonteD' }, + requires = { 'html_tags' }, }, htmldjango = { @@ -1118,6 +1143,7 @@ M.configs = { generate_requires_npm = true, }, maintainers = { '@fab4100' }, + requires = { 'c' }, }, janet_simple = { @@ -1151,6 +1177,7 @@ M.configs = { files = { 'src/parser.c', 'src/scanner.c' }, }, maintainers = { '@steelsojka' }, + requires = { 'ecma', 'jsx' }, }, jinja = { @@ -1214,7 +1241,7 @@ M.configs = { generate_requires_npm = true, }, maintainers = { '@WhyNotHugo' }, - readme_note = 'JSON with comments', + requires = { 'json' }, }, jsonnet = { @@ -1225,6 +1252,11 @@ M.configs = { maintainers = { '@nawordar' }, }, + jsx = { + maintainers = { '@steelsojka' }, + readme_note = 'queries required by javascript, tsx', + }, + julia = { install_info = { url = 'https://github.com/tree-sitter/tree-sitter-julia', @@ -1370,8 +1402,8 @@ M.configs = { url = 'https://github.com/MunifTanjim/tree-sitter-lua', files = { 'src/parser.c', 'src/scanner.c' }, }, - tier = 1, maintainers = { '@muniftanjim' }, + tier = 1, }, luadoc = { @@ -1397,6 +1429,7 @@ M.configs = { files = { 'src/parser.c', 'src/scanner.c' }, }, maintainers = { '@amaanq' }, + requires = { 'lua' }, }, m68k = { @@ -1423,6 +1456,7 @@ M.configs = { }, maintainers = { '@MDeiml' }, readme_note = 'basic highlighting', + requires = { 'markdown_inline' }, tier = 1, }, @@ -1475,8 +1509,8 @@ M.configs = { files = { 'src/parser.c' }, requires_generate_from_grammar = true, }, - tier = 4, maintainers = { '@artagnon' }, + tier = 4, }, muttrc = { @@ -1511,6 +1545,7 @@ M.configs = { url = 'https://github.com/nickel-lang/tree-sitter-nickel', files = { 'src/parser.c', 'src/scanner.c' }, }, + tier = 4, }, nim = { @@ -1519,6 +1554,7 @@ M.configs = { files = { 'src/parser.c', 'src/scanner.c' }, }, maintainers = { '@aMOPel' }, + requires = { 'nim_format_string' }, tier = 3, }, @@ -1553,8 +1589,8 @@ M.configs = { files = { 'src/parser.c', 'src/scanner.cc' }, use_makefile = true, }, - tier = 4, maintainers = { '@JoeyGrajciar', '@vhyrro' }, + tier = 4, }, nqc = { @@ -1581,6 +1617,7 @@ M.configs = { files = { 'src/parser.c' }, }, maintainers = { '@amaanq' }, + requires = { 'c' }, }, objdump = { @@ -1608,6 +1645,7 @@ M.configs = { location = 'grammars/interface', }, maintainers = { '@undu' }, + requires = { 'ocaml' }, }, ocamllex = { @@ -1826,6 +1864,7 @@ M.configs = { location = 'psv', }, maintainers = { '@amaanq' }, + requires = { 'tsv' }, tier = 2, }, @@ -1895,6 +1934,7 @@ M.configs = { files = { 'src/parser.c', 'src/scanner.c' }, }, maintainers = { '@Decodetalkers' }, + requires = { 'ecma' }, }, query = { @@ -2120,6 +2160,8 @@ M.configs = { files = { 'src/parser.c', 'src/scanner.c' }, }, maintainers = { '@elianiva' }, + requires = { 'css' }, + tier = 3, }, sflog = { @@ -2314,6 +2356,7 @@ M.configs = { files = { 'src/parser.c', 'src/scanner.c' }, }, maintainers = { '@amaanq' }, + requires = { 'html_tags' }, tier = 2, }, @@ -2421,6 +2464,8 @@ M.configs = { location = 'dialects/terraform', }, maintainers = { '@MichaHoffmann' }, + requires = { 'hcl' }, + tier = 3, }, textproto = { @@ -2501,6 +2546,7 @@ M.configs = { generate_requires_npm = true, }, maintainers = { '@steelsojka' }, + requires = { 'ecma', 'jsx', 'typescript' }, }, turtle = { @@ -2527,6 +2573,7 @@ M.configs = { generate_requires_npm = true, }, maintainers = { '@steelsojka' }, + requires = { 'ecma' }, }, typespec = { @@ -2684,6 +2731,7 @@ M.configs = { branch = 'main', }, maintainers = { '@WhyNotHugo', '@lucario387' }, + requires = { 'html_tags' }, tier = 2, }, @@ -2737,6 +2785,7 @@ M.configs = { location = 'xml', }, maintainers = { '@ObserverOfTime' }, + requires = { 'dtd' }, tier = 2, }, diff --git a/scripts/update-lockfile.lua b/scripts/update-lockfile.lua index dfd3e933f..497f1bc0f 100755 --- a/scripts/update-lockfile.lua +++ b/scripts/update-lockfile.lua @@ -21,21 +21,12 @@ end) -- check for new revisions for _, v in ipairs(sorted_parsers) do - if skip_langs and not vim.list_contains(skip_langs, v.name) then - local sha ---@type string + if not vim.list_contains(skip_langs, v.name) and v.parser.install_info then + local cmd = 'git ls-remote ' .. v.parser.install_info.url if v.parser.install_info.branch then - sha = vim.split( - vim.fn.systemlist( - 'git ls-remote ' - .. v.parser.install_info.url - .. ' | grep refs/heads/' - .. v.parser.install_info.branch - )[1], - '\t' - )[1] - else - sha = vim.split(vim.fn.systemlist('git ls-remote ' .. v.parser.install_info.url)[1], '\t')[1] + cmd = cmd .. ' | grep refs/heads/' .. v.parser.install_info.branch end + local sha = vim.split(vim.fn.systemlist(cmd)[1], '\t')[1] lockfile[v.name] = { revision = sha } print(v.name .. ': ' .. sha) else @@ -43,5 +34,8 @@ for _, v in ipairs(sorted_parsers) do end end -lockfile = vim.fn.system('jq --sort-keys', vim.json.encode(lockfile)) +lockfile = vim.json.encode(lockfile) +if vim.fn.executable('jq') == 1 then + lockfile = vim.fn.system('jq --sort-keys', lockfile) +end util.write_file(filename, lockfile) diff --git a/scripts/update-readme.lua b/scripts/update-readme.lua index ded0d6bcb..2133ad0c6 100755 --- a/scripts/update-readme.lua +++ b/scripts/update-readme.lua @@ -23,14 +23,23 @@ local footnotes = '' for _, v in ipairs(sorted_parsers) do local p = v.parser -- language - generated_text = generated_text - .. '[' - .. v.name - .. '](' - .. p.install_info.url - .. ')' - .. (p.readme_note and '[^' .. v.name .. ']' or '') - .. ' | ' + if p.install_info then + generated_text = generated_text + .. '[' + .. v.name + .. '](' + .. p.install_info.url + .. ')' + .. (p.readme_note and '[^' .. v.name .. ']' or '') + .. ' | ' + else + generated_text = generated_text + .. v.name + .. ' (queries only)' + .. (p.readme_note and '[^' .. v.name .. ']' or '') + .. ' | ' + end + if p.readme_note then footnotes = footnotes .. '[^' .. v.name .. ']: ' .. p.readme_note .. '\n' end @@ -50,11 +59,13 @@ for _, v in ipairs(sorted_parsers) do -- CLI generated_text = generated_text - .. (p.install_info.requires_generate_from_grammar and '✓' or '') + .. (p.install_info and p.install_info.requires_generate_from_grammar and '✓' or '') .. ' | ' -- NPM - generated_text = generated_text .. (p.install_info.generate_requires_npm and '✓' or '') .. ' | ' + generated_text = generated_text + .. (p.install_info and p.install_info.generate_requires_npm and '✓' or '') + .. ' | ' -- Maintainer generated_text = generated_text |
