The go-git project is Apache 2.0 licensed and accepts contributions via GitHub pull requests. This document outlines some of the conventions on development workflow, commit message formatting, contact points, and other resources to make it easier to get your contribution accepted.
The official support channels, for users are:
- StackOverflow go-git tag for user questions.
- GitHub Issues* for bug reports and feature requests.
*Before opening a new issue or submitting a new pull request, it's helpful to search the project - it's likely that another user has already reported the issue you're facing, or it's a known issue that we're already aware of.
In addition to the channels above, contributors are also able to join the go-git discord server.
For substantial changes to go-git's public APIs, architecture, process, or functionality, please consider using our RFC (Request for Comments) process. This includes:
- New public APIs or significant changes to existing APIs
- Changes to storage interfaces or backends
- New plumbing or porcelain operations
- The processes around merging PRs or releasing changes
- Changes that would require migration guides for users
The RFC process helps ensure that major changes are well-designed and have community consensus before implementation begins.
Pull Requests (PRs) are the main and exclusive way to contribute to the official go-git project. In order for a PR to be accepted it needs to pass a list of requirements:
- You should be able to run the same query using
git. We don't accept features that are not implemented in the official git implementation. - The expected behavior must match the official git implementation.
- The actual behavior must be correctly explained with natural language and providing a minimum working example in Go that reproduces it.
- All PRs must be written in idiomatic Go, formatted according to gofmt, and without any warnings from golangci-lint.
- They should in general include tests, and those shall pass.
- If the PR is a bug fix, it has to include a suite of unit tests for the new functionality.
- If the PR is a new feature, it has to come with a suite of unit tests, that tests the new functionality.
- In any case, all the PRs have to pass the personal evaluation of at least one of the maintainers of go-git.
The development branch is main, where all development takes place.
All new features and bug fixes should target it. This was formerly known
as v6-exp or v6-transport. This branch contains all the changes for
v6 - the next major release.
From time to time this branch will contain breaking changes, as the API
for v6 is being refined.
The releases/v5.x branch is the branch for changes to the v5 version,
which is now in maintenance mode. To avoid having to divert efforts from v6,
we will only be accepting bug fixes or CVE related dependency bumps for the
v5 release.
Bug fixes that also impact main, should be fixed there first, and then backported to v5.
Every commit message should describe what was changed, under which context and, if applicable, the GitHub issue it relates to:
plumbing: packp, Skip argument validations for unknown capabilities. Fixes #623
The format can be described more formally as follows:
<package>: <subpackage>, <what changed>. [Fixes #<issue-number>]