Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/faldor20/tree-sitter-roc
https://github.com/faldor20/tree-sitter-roc
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/faldor20/tree-sitter-roc
- Owner: faldor20
- License: mit
- Created: 2023-11-15T23:42:20.000Z (about 1 year ago)
- Default Branch: master
- Last Pushed: 2024-07-31T11:06:08.000Z (5 months ago)
- Last Synced: 2024-11-16T11:33:22.853Z (about 2 months ago)
- Language: JavaScript
- Size: 18.6 MB
- Stars: 28
- Watchers: 6
- Forks: 13
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- roc-awesome - Tree-sitter Grammar
README
# tree-sitter grammar for roc
## installing
Reference it from your editor somehow.
//TODO
### HelixMy full config for roc is below:
```toml
[language-server.roc-ls]
command = "roc_language_server"[[language]]
name = "roc"
scope = "source.roc"
injection-regex = "roc"
file-types = ["roc"]
shebangs = ["roc"]
roots = []
comment-token = "#"
language-servers = ["roc-ls"]
indent = { tab-width = 2, unit = " " }
auto-format = true
formatter = { command = "roc", args =[ "format", "--stdin", "--stdout"]}[language.auto-pairs]
'(' = ')'
'{' = '}'
'[' = ']'
'"' = '"'
[[grammar]]name = "roc"
source = { git = "https://github.com/faldor20/tree-sitter-roc.git", rev = "whateverTheLatestCommitIs" }
```
1. After adding the above to your `languages.toml`, run `hx --grammar fetch` and then `hx --grammar build`
2. Add `~/.config/helix/runtime/queries/roc/` and put the files from this repository's `queries` directory in there.
3. Run `hx --health roc` in a new shell and verify that your changes have been picked up correctly. If things are green, you're good to go.### Neovim
Add the code in `neovim/roc.lua` to your config somewhere.
Copy the folder `neovim/queries` to your neovim config at `after/` or in a custom neovim plugin at its root directory `./`
eg: `after/queries/roc/highlights.lua`or `my_roc_plugin/queries/roc/highlights.lua`
### Emacs
A [package providing a major mode for Roc](https://gitlab.com/tad-lispy/roc-mode "Emacs Roc mode") is under development.
## contributing
### Setup
#### Nix
Currently i use nix for development so to start the dev environment in nix run
```bash
nix develop
```
I've had some odd issues with the system version of libc being incompatible with my version of treesitter. if tree-sitter is spitting out weird errors try running it in an isolated environments
```bash
nix develop -i
````
#### Not Nix
If you are outside of nix.
You will need:
1. The tree-sitter cli, which will be installed when you run `npm install`
2. A c compiler like gcc or clang### Running
Once you've made a change, to test it, run:
```bash
tree-sitter generate
tree-sitter test
```
if you add a new feature you should add a test to one of the test files in `test/corpus/*.txt`
once you are happy with you changes run```bash
tree-sitter test --update
```
and it will update the test files with your new parsed tree