Typst official page https://typst.app
TreeSitter documentation page https://tree-sitter.github.io
Typst doesn't have yet an official TreeSitter grammar. This grammar is complete but may contains bug as it is very recent.
I publish this grammar because I hope for help from other involved enthousiasts. You don't have to know anything about tree-sitter to help. I need you to find bugs!
Find a bug by using this grammar. If you find an incorrect highlighting of your Typst files, then you found a bug. You can open an issue or simply send me by mail the Typst code causing the bug. See below installation instructions for this grammar.
Any inconsistance between this syntax and Typst's one is considered a bug. In Helix editor, the syntax tree of selected text can be displayed with :tree-sitter-subtree
command.
Don't hesitate to contact me: eddie.gerbais-nief@proton.me
The documentation of this implementation is available in DOC.
- More tests, objectif 1000, current 347
- Documentation
- Update 0.8.0
- Fixme
- Optimization
- Parser size
- Math ident
- Extras
- Code
- Indentation
- Comments
- Math mode
- Precedence
- Call
- Tagged
- Separator
- Symbol
- Code
- Markups
- Strong
- Emph
- Heading
- Url
- List
- Label
- Reference
- Symbol
- Quote
- Unicode characters
- Ident and label
- White spaces
- Math ident
- Anti markup
To generate this grammar from source, the tree-sitter
command line tool is required. Installation instructions are available here https://github.com/tree-sitter/tree-sitter/tree/master/cli. Then, generate the grammar with tree-sitter generate
. To "generate" the grammar means the tool will generate C source as parser.c
from grammar.js
.
The already generated grammar is available here https://github.com/uben0/tree-sitter-typst/releases/download/v0.7.0-beta.1/tree-sitter-typst.tar.xz. You will only need a C compiler.
Locate the installation directory:
- Global
/usr/share/helix
- Local
/.config/helix
Copy the content of the queries
directory inside your corresponding runtime/queries/typst
directory. This will provide hightlight indications.
Append the following configuration to the languages.toml
file. And indicate the path to this grammar. This will make the text editor able to recognized the Typst source files and offer the desired functionalities.
[[language]]
name = "typst"
scope = "source.typst"
file-types = ["typst", "typ"]
indent = { tab-width = 2, unit = " " }
comment-token = "//"
injection-regex = "typ(st)?"
[language.auto-pairs]
'(' = ')'
'{' = '}'
'[' = ']'
'$' = '$'
'"' = '"'
[[grammar]]
name = "typst"
source = { path = "path/to/the/tree-sitter's/grammar" }
And finally execute:
tree-sitter generate
hx --grammar fetch
hx --grammar build
If you downloaded the already generated grammar, the tree-sitter generate
step is unecessary. If syntax highlighting doesn't work, you may open Helix's log file with the :log-open
command and obtain helpful error message.