Git to Go; bindings for libgit2. Like McDonald's but tastier.
Go to file
github-actions[bot] 206c5a356c
Make ssh commands used in the git smart transport compatible with libgit2 (#852) (#854)
* Fix ssh commands used in go SmartSubtransport

Before the fix, the commands sent were of the form:

```
git-upload-pack "/bar/test-reponame"
```

This resulted in the git server returning error:
`error parsing command: invalid git command`

This change replaces the double quotes with single quotes:

```
git-upload-pack '/bar/test-reponame'
```

* Update ssh.go

Co-authored-by: lhchavez <lhchavez@lhchavez.com>
(cherry picked from commit 6cea7a7a59)

Co-authored-by: Sunny <darkowlzz@protonmail.com>
Co-authored-by: lhchavez <lhchavez@lhchavez.com>
2021-11-09 06:26:51 -08:00
.github/workflows Declare forward-compatibility with libgit2 v1.3.0 #minor (#844) 2021-10-16 04:54:53 -07:00
script Allow building libgit2 with Chromium zlib (#831) (#833) 2021-09-06 05:26:10 -07:00
testdata/TestGitRepository.git Add `NewCredentialSSHKeyFromSigner` (#706) 2020-12-06 11:55:04 -08:00
vendor Create v31 to support libgit2 v1.1.x (#668) 2020-10-26 18:09:26 -07:00
.gitignore Update CI configuration 2020-02-22 18:21:38 -08:00
.gitmodules Remove left-over submodule configuration 2014-06-07 19:29:45 +02:00
Build_bundled_static.go Declare forward-compatibility with libgit2 v1.3.0 #minor (#844) 2021-10-16 04:54:53 -07:00
Build_system_dynamic.go Declare forward-compatibility with libgit2 v1.3.0 #minor (#844) 2021-10-16 04:54:53 -07:00
Build_system_static.go Declare forward-compatibility with libgit2 v1.3.0 #minor (#844) 2021-10-16 04:54:53 -07:00
LICENSE Initial commit 2013-03-05 20:53:04 +01:00
Makefile Build improvements (#707) 2020-12-06 06:13:38 -08:00
README.md Rename the default branch to `main` (#786) 2021-09-04 13:33:34 -07:00
blame.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
blame_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
blob.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
blob_test.go Add support for git_blob_is_binary (#625) 2020-07-30 05:07:05 -07:00
branch.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
branch_test.go Mark some symbols to be deprecated #minor (#698) 2020-12-05 07:23:44 -08:00
checkout.go More callback refactoring (#713) 2020-12-10 07:19:41 -08:00
cherrypick.go More callback refactoring (#713) 2020-12-10 07:19:41 -08:00
cherrypick_test.go Mark some symbols to be deprecated #minor (#698) 2020-12-05 07:23:44 -08:00
clone.go Add support for custom smart transports (#806) 2021-09-05 15:44:18 -07:00
clone_test.go bugfix: HTTPS Clone fails with remote pointer not found using Go transport (#836) (#842) (#848) 2021-11-09 06:22:47 -08:00
commit.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
config.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
config_test.go add wrapper for git_config_open_default (#758) 2021-04-03 18:45:55 -07:00
credentials.go Add support for managed SSH transport #minor (#814) 2021-09-05 17:04:40 -07:00
delta_string.go make Delta and DiffLineType stringers 2019-08-27 10:02:12 -07:00
deprecated.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
describe.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
describe_test.go Update libgit2 to df4dfaad 2017-01-20 13:20:30 +00:00
diff.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
diff_test.go Refactor all callbacks (#700) 2020-12-05 13:13:59 -08:00
difflinetype_string.go make Delta and DiffLineType stringers 2019-08-27 10:02:12 -07:00
errorclass_string.go Mark some symbols to be deprecated #minor (#698) 2020-12-05 07:23:44 -08:00
errorcode_string.go Mark some symbols to be deprecated #minor (#698) 2020-12-05 07:23:44 -08:00
features.go Mark some symbols to be deprecated #minor (#698) 2020-12-05 07:23:44 -08:00
git.go Add support for managed SSH transport #minor (#814) 2021-09-05 17:04:40 -07:00
git_test.go Add support for managed HTTP/S transports (#810) 2021-09-05 16:39:07 -07:00
go.mod Add `NewCredentialSSHKeyFromSigner` (#706) 2020-12-06 11:55:04 -08:00
go.sum Add `NewCredentialSSHKeyFromSigner` (#706) 2020-12-06 11:55:04 -08:00
graph.go Second round of keep-alives 2017-07-08 11:38:19 +02:00
handles.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
http.go Add support for managed HTTP/S transports (#810) 2021-09-05 16:39:07 -07:00
ignore.go Second round of keep-alives 2017-07-08 11:38:19 +02:00
index.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
index_test.go Merge remote-tracking branch 'upstream/master' into git_index_add_frombuffer 2020-02-23 13:53:17 +00:00
indexer.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
indexer_test.go Mark some symbols to be deprecated #minor (#698) 2020-12-05 07:23:44 -08:00
mempack.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
mempack_test.go Mark some symbols to be deprecated #minor (#698) 2020-12-05 07:23:44 -08:00
merge.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
merge_test.go Support git_repository_message, git_repository_message_remove (#734) 2021-02-02 19:42:21 -08:00
message.go Add support for parsing git trailers (#614) 2020-06-02 10:30:42 -07:00
message_test.go Add support for parsing git trailers (#614) 2020-06-02 10:30:42 -07:00
note.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
note_test.go Mark some symbols to be deprecated #minor (#698) 2020-12-05 07:23:44 -08:00
object.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
object_test.go Mark some symbols to be deprecated #minor (#698) 2020-12-05 07:23:44 -08:00
odb.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
odb_test.go fix: Use `err` instead of error as a variable name for errors (#746) 2021-02-15 07:26:19 -08:00
packbuilder.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
patch.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
patch_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
push_test.go Ensure that no pointer handles leak during the test (#712) 2020-12-10 05:35:40 -08:00
rebase.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
rebase_test.go Mark some symbols to be deprecated #minor (#698) 2020-12-05 07:23:44 -08:00
refdb.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
reference.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
reference_test.go Mark some symbols to be deprecated #minor (#698) 2020-12-05 07:23:44 -08:00
remote.go bugfix: HTTPS Clone fails with remote pointer not found using Go transport (#836) (#842) (#848) 2021-11-09 06:22:47 -08:00
remote_test.go Add support for managed HTTP/S transports (#810) 2021-09-05 16:39:07 -07:00
repository.go Add support for custom smart transports (#806) 2021-09-05 15:44:18 -07:00
repository_test.go Add `Repository.CreateCommitBuffer` (#781) 2021-09-04 13:04:58 -07:00
reset.go More callback refactoring (#713) 2020-12-10 07:19:41 -08:00
reset_test.go Mark some symbols to be deprecated #minor (#698) 2020-12-05 07:23:44 -08:00
revert.go More callback refactoring (#713) 2020-12-10 07:19:41 -08:00
revert_test.go Add revert functionality 2020-02-22 19:39:50 -08:00
revparse.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
revparse_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
settings.go feat: Implement an option to control hash verification (#671) 2020-11-02 18:36:20 -08:00
settings_test.go feat: Implement an option to control hash verification (#671) 2020-11-02 18:36:20 -08:00
signature.go Check nil signature 2020-04-23 16:26:35 -07:00
ssh.go Make ssh commands used in the git smart transport compatible with libgit2 (#852) (#854) 2021-11-09 06:26:51 -08:00
stash.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
stash_test.go Mark some symbols to be deprecated #minor (#698) 2020-12-05 07:23:44 -08:00
status.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
status_test.go Fix null pointer dereference in status.ByIndex (#628) 2020-08-14 11:19:21 -07:00
submodule.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
submodule_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
tag.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
tag_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
transport.go bugfix: HTTPS Clone fails with remote pointer not found using Go transport (#836) (#842) (#848) 2021-11-09 06:22:47 -08:00
transport_test.go Add support for custom smart transports (#806) 2021-09-05 15:44:18 -07:00
tree.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
tree_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
walk.go Make all non-user-creatable structures non-comparable (#802) 2021-09-05 13:59:36 -07:00
wrapper.c Add support for custom smart transports (#806) 2021-09-05 15:44:18 -07:00

README.md

git2go

GoDoc Build Status

Go bindings for libgit2.

Which Go version to use

Due to the fact that Go 1.11 module versions have semantic meaning and don't necessarily align with libgit2's release schedule, please consult the following table for a mapping between libgit2 and git2go module versions:

libgit2 git2go
main (will be v32)
1.1 v31
1.0 v30
0.99 v29
0.28 v28
0.27 v27

You can import them in your project with the version's major number as a suffix. For example, if you have libgit2 v1.1 installed, you'd import git2go v31 with:

go get github.com/libgit2/git2go/v31
import "github.com/libgit2/git2go/v31"

which will ensure there are no sudden changes to the API.

The main branch follows the tip of libgit2 itself (with some lag) and as such has no guarantees on the stability of libgit2's API. Thus this only supports statically linking against libgit2.

Which branch to send Pull requests to

If there's something version-specific that you'd want to contribute to, you can send them to the release-${MAJOR}.${MINOR} branches, which follow libgit2's releases.

Installing

This project wraps the functionality provided by libgit2. It thus needs it in order to perform the work.

This project wraps the functionality provided by libgit2. If you're using a versioned branch, install it to your system via your system's package manager and then install git2go.

Versioned branch, dynamic linking

When linking dynamically against a released version of libgit2, install it via your system's package manager. CGo will take care of finding its pkg-config file and set up the linking. Import via Go modules, e.g. to work against libgit2 v1.1

import "github.com/libgit2/git2go/v31"

Versioned branch, static linking

Follow the instructions for Versioned branch, dynamic linking, but pass the -tags static,system_libgit2 flag to all go commands that build any binaries. For instance:

go build -tags static,system_libgit2 github.com/my/project/...
go test -tags static,system_libgit2 github.com/my/project/...
go install -tags static,system_libgit2 github.com/my/project/...

main branch, or vendored static linking

If using main or building a branch with the vendored libgit2 statically, we need to build libgit2 first. In order to build it, you need cmake, pkg-config and a C compiler. You will also need the development packages for OpenSSL (outside of Windows or macOS) and LibSSH2 installed if you want libgit2 to support HTTPS and SSH respectively. Note that even if libgit2 is included in the resulting binary, its dependencies will not be.

Run go get -d github.com/libgit2/git2go to download the code and go to your $GOPATH/src/github.com/libgit2/git2go directory. From there, we need to build the C code and put it into the resulting go binary.

git submodule update --init # get libgit2
make install-static

will compile libgit2, link it into git2go and install it. The main branch is set up to follow the specific libgit2 version that is vendored, so trying dynamic linking may or may not work depending on the exact versions involved.

In order to let Go pass the correct flags to pkg-config, -tags static needs to be passed to all go commands that build any binaries. For instance:

go build -tags static github.com/my/project/...
go test -tags static github.com/my/project/...
go install -tags static github.com/my/project/...

One thing to take into account is that since Go expects the pkg-config file to be within the same directory where make install-static was called, so the go.mod file may need to have a replace directive so that the correct setup is achieved. So if git2go is checked out at $GOPATH/src/github.com/libgit2/git2go and your project at $GOPATH/src/github.com/my/project, the go.mod file of github.com/my/project might need to have a line like

replace github.com/libgit2/git2go/v31 ../../libgit2/git2go

Parallelism and network operations

libgit2 may use OpenSSL and LibSSH2 for performing encrypted network connections. For now, git2go asks libgit2 to set locking for OpenSSL. This makes HTTPS connections thread-safe, but it is fragile and will likely stop doing it soon. This may also make SSH connections thread-safe if your copy of libssh2 is linked against OpenSSL. Check libgit2's THREADSAFE.md for more information.

Running the tests

For the stable version, go test will work as usual. For the main branch, similarly to installing, running the tests requires building a local libgit2 library, so the Makefile provides a wrapper that makes sure it's built

make test-static

Alternatively, you can build the library manually first and then run the tests

make install-static
go test -v -tags static ./...

License

M to the I to the T. See the LICENSE file if you've never seen an MIT license before.

Authors

  • Carlos Martín (@carlosmn)
  • Vicent Martí (@vmg)