Clone the repository and run the setup script.
git clone https://github.com/DerekStride/tree-sitter-sql.git
npm install
The Makefile will ensure the parser is generated & compiled when testing changes during development. Use make test
to
run the testsuite.
Before you commit it's a good idea to run make format
to make sure the tests are will formatted & correct. Be careful
to make sure there are no unintended updates to the tests.
Follow the conventional commits guidelines to make reviews easier and to make the git logs more valuable. The general structure of a commit message is:
<type>([optional scope]): <description>
[optional body]
[optional footer(s)]
- Prefix the commit subject with one of these
types:
feat
,build
,fix
,docs
,refactor
,test
- Append optional scope to type such as
(ast)
. - Breaking changes to the syntax tree must be indicated by
- "!" after the type/scope, and
- a "BREAKING CHANGE" footer describing the change.
Example:
refactor(ast)!: remove predicate and merge into binary_expression BREAKING CHANGE: The `(predicate)` node has been replaced with `(binary_expression)`
To run the Github pages server, execute the following commands and open localhost:4000.
$ cd docs/
$ bundle install
$ bundle exec jekyll serve
We use commit-and-tag-version to automate bumping the version number and preparing for a release. Run the following to generate the release:
$ npm run release
Ensure you also bump the version in tree-sitter.json
, Cargo.toml
, pyproject.toml
, & CMakeLists.txt
before pushing the changes.
Verify that all the changes are correct and push the updates to a new branch.
git push
Once that PR is merged, create a new Release on Github. When the release is published Github Actions will publish the new version to npm.