The process for updating a grammar and releasing the generated code in described in details in this document.
Until we have an automatic process for this and for security reasons, please ask someone at r2c to release the code for the language.
Contact channels:
- your ocaml-tree-sitter pull request
- the r2c Slack channel #dev-discussions
Check that the external source code looks clean, including any dependency used at build time or run time. Source code for a tree-sitter-* grammar is:
grammar.js
and its dependencies.grammar.js
should just define a grammar object. It should not write to the filesystem.src/scanner.c
orsrc/scanner.cc
if such file exists, and any dependency they may have. There should be no dependency other than the standard C or C++ libraries and tree-sitter libraries.
For a language foolang
, the commands are:
make && make install
cd lang
./test-lang foolang
./release foolang
This will push to the git repository for semgrep-foolang
, which will
then be used in semgrep as a git submodule.
The list of languages below should match the languages listed in the
lang
folder of
ocaml-tree-sitter-semgrep.
- apex
- bash
- c
- clojure
- cpp
- c-sharp
- dart
- dockerfile
- elixir
- fsharp
- go
- hack
- hcl
- html
- java
- javascript
- jsonnet
- julia
- kotlin
- lua
- make
- move-on-aptos
- move-on-sui
- ocaml
- php
- promql
- proto
- python
- ql
- r
- ruby
- rust
- solidity
- sqlite
- swift
- tsx
- typescript
- vue
GitHub homepage is: https://github.com/returntocorp/semgrep-$lang
Git URL is: [email protected]:returntocorp/semgrep-$lang.git
or https://github.com/returntocorp/semgrep-$lang.git
The repos above are not conventional source repos. Please talk to someone from the PA team if you're considering making changes to their GitHub settings.