| Crates.io | tree-sitter-javadoc |
| lib.rs | tree-sitter-javadoc |
| version | 0.2.4 |
| created_at | 2025-03-19 09:43:26.556608+00 |
| updated_at | 2025-09-23 01:58:42.118446+00 |
| description | Parser for Javadoc documentation comments |
| homepage | |
| repository | https://github.com/rmuir/tree-sitter-javadoc |
| max_upload_size | |
| id | 1597840 |
| size | 480,108 |
Javadoc grammar for tree-sitter
Features:
/**)///) support@see and @link references@nospell set for javadocs syntax regions, so you don't have to turn spellcheck off anymore@snippet, @valueInstall nvim-treesitter, then from neovim:
:TSInstall java javadoc html css printf comment
It is recommended to install at least these parsers for treesitter support of java code.
Bindings are published to pypi, npm, and crates.io as tree-sitter-javadoc.
Wasm and source code artifacts are published to GitHub releases
You can customize highlighting by creating custom query files in ~/.config/nvim/queries/:
This ;; extends the default queries, and adds additional queries based on standard coding conventions.
Many treesitter parsers do this, including java, but neovim is trying to move away from it.
If you use an LSP with semantic token support, you don't need this. Otherwise, it might be useful to you.
~/.config/nvim/queries/javadoc/highlights.scm:
;; extends
; Capitalized methods in javadoc references are treated as constructors.
(((method
(identifier) @constructor)
(#lua-match? @constructor "^[A-Z]")))
; Screaming-case members are treated as constants.
((member
(identifier) @constant)
(#lua-match? @constant "^[A-Z_][A-Z0-9_]+$"))
; Camel-case members are treated as types.
((member
(identifier) @type)
(#lua-match? @type "^[A-Z].*[a-z]"))
The default highlighting incorporates highlighting of HTML and markdown tags via their respective parsers. For a more minimal approach with just highlighting of block and inline tags, you can override the injections.
~/.config/nvim/queries/javadoc/injections.scm:
; overriding with an empty query file to disable injections