jinja-lsp
jinja-lsp copied to clipboard
Language Server for jinja
data:image/s3,"s3://crabby-images/17ae9/17ae96d421d30b990dd350719f85848dafa766ab" alt="banner"
jinja-lsp enhances minijinja development experience by providing Helix/Nvim users with advanced features such as autocomplete, syntax highlighting, hover, goto definition, code actions and linting.
Installation
cargo install jinja-lsp
Features
Autocomplete
Intelligent suggestions for variables in current template, as well as variables, templates and filters defined on backend side.
data:image/s3,"s3://crabby-images/50d8f/50d8f37313b44d8842443d2fde3a16a3102bfdb3" alt=""
data:image/s3,"s3://crabby-images/658fe/658fe684db88c8831039db80af289bc2d11beb50" alt=""
data:image/s3,"s3://crabby-images/59703/59703ad9a95ac243f1bb5bd4722afdcbb35d0a03" alt=""
Linting
Highlights errors and potential bugs in your jinja templates.
data:image/s3,"s3://crabby-images/fcdee/fcdee793f165439bdd3172778f90cbd1f7a05a8a" alt=""
data:image/s3,"s3://crabby-images/c9877/c9877b7aefb4e6a5ab9eab5d9e4dc5b98710697c" alt=""
data:image/s3,"s3://crabby-images/90eae/90eae15348bbfe099180d1c4e891247118389ac2" alt=""
Hover Preview
See the complete filter or variable description by hovering over it.
data:image/s3,"s3://crabby-images/86a80/86a80eebc81178ccc0db83f87f0de0f839975095" alt=""
data:image/s3,"s3://crabby-images/4df5f/4df5f5dc8eb90a82478cd6f70243fd91d09e4e35" alt=""
Code Actions
It's recommended to reset variables on server in case you rename/delete file.
data:image/s3,"s3://crabby-images/0f0c9/0f0c92927c1a99a8a3d7fb00e38035fa8b405ce0" alt=""
Goto Definition
Quickly jump to definition. Works for Rust identifiers as well.
https://github.com/uros-5/jinja-lsp/assets/59397844/015e47b4-b6f6-47c0-8504-5ce79ebafb00
Snippets
data:image/s3,"s3://crabby-images/bf34a/bf34a519276fab11a0c660f17614c11b5a9a9878" alt=""
Document symbols
data:image/s3,"s3://crabby-images/43d72/43d722de31a2673882e5fd82f2a98e0e05465396" alt=""
Configuration
Language server configuration
{ "templates": "./TEMPLATES_DIR", "backend": ["./BACKEND_DIR"], "lang": "rust"}
Helix configuration
[language-server.jinja-lsp]
command = "jinja-lsp"
config = { templates = "./templates", backend = ["./src"], lang = "rust"}
timeout = 5
[[language]]
name = "jinja"
language-servers = ["jinja-lsp"]
Supported languages: Python, Rust