We have good first issues for new contributors and help wanted issues for our other contributors.
good first issue
has extra information to help you make your first contribution.help wanted
are issues suitable for someone who isn't a core maintainer.
Maintainers will do their best regularly make new issues for you to solve and then help out as you work on them. 💖
PRs are most welcome!
- If there isn't an issue for your PR, please make an issue first and explain the problem or motivation for
the change you are proposing. When the solution isn't straightforward, for example "Implement missing command X",
then also outline your proposed solution. Your PR will go smoother if the solution is agreed upon before you've
spent a lot of time implementing it.
- It's OK to submit a PR directly for problems such as misspellings or other things where the motivation/problem is unambiguous.
- If you aren't sure about your solution yet, put WIP in the title or open as a draft PR so that people know to be nice and wait for you to finish before commenting.
- Try to keep your PRs to a single task. Please don't tackle multiple things in a single PR if possible. Otherwise, grouping related changes into commits will help us out a bunch when reviewing!
- We encourage "follow-on PRs". If the core of your changes are good, and it won't hurt to do more of the changes later, we like to merge early, and keep working on it in another PR so that others can build on top of your work.
When you're ready to get started, we recommend the following workflow:
$ go build ./...
$ go test ./...
$ golangci-lint run --config ./golangci.yml
We currently use dep for dependency management.
When you are asked to cut a new release, here is the process:
-
Figure out the correct version number, we follow semver and have a funny [release naming scheme][release-name]:
- Bump the major segment if there are any breaking changes.
- Bump the minor segment if there are new features only.
- Bump the patch segment if there are bug fixes only.
- Bump the build segment (version-prerelease.BUILDTAG+releasename) if you only fixed something in the build, but the final binaries are the same.
-
Ensure that the CI build is passing, then make the tag and push it.
git checkout main git pull git tag VERSION -a -m "" git push --tags