You can participate in Genji in several ways, there is so much to do to make this project awesome!
The goal of this document is to provide guidelines to contributors to make working with Genji a smooth experience. Genji is a complex project that has many moving parts and we want to make sure that everyone's working towards the same goal.
We want to avoid situations where you would put energy on a contribution that gets rejected because it doesn't match the direction this project is taking.
We use Github issues to track bugs. Report a bug by opening an issue, it's that easy!
Make sure you give enough context for us to reproduce the bug:
- The version of Genji you are using
- The observed behavior
- The expected behavior
- Ideally, some code like a main file or a Go playground link
Genji is not a common database because it mixes documents with SQL. Some SQL features that make sense in mainstream relational databases may not be a good fit for this project and vice versa. Every feature can have a big impact on the project, including performance, ordering, encoding, etc. To propose a consistent solution to users, every SQL feature needs to be thoroughly designed and discussed before even starting implementing it.
- Open an issue describing the SQL feature you want Genji to include
- Discuss it with maintainers and contributors
- If necessary, someone will be in charge of writing an RFC
- Once the feature is accepted, someone will be in charge of creating a Pull Request
Depending on the complexity and importance of the feature, the RFC and the PR may or may not be assigned to you. However, we will always do our best to let you contribute code if you are eager to do so and the feature doesn't require too much context.
Anything that can help improve Genji is a welcome contribution. Here are a few examples of things that can be improved:
- CI/Tooling
- Go APIs
- Documentation
- Build targets support
- Performance
In most cases, contributing to Genji must follow these guidelines:
- Open an issue
- Discuss with maintainers and contributors
- Open a PR to propose your solution to the problem
If the change is really small, like correcting a typo or a very obvious bug fix, you may open a PR directly.