Git to Go; bindings for libgit2. Like McDonald's but tastier.
Go to file
Carlos Martín Nieto cff71166ec Adjust to the change in the git_odb_open_rstream signature 2018-02-22 09:28:58 +01:00
script Get rid of the with-static.sh script 2016-11-01 00:17:51 +01:00
vendor vendor: bump libgit2 to 809b0ca6b (v0.27.0-rc1) 2018-02-22 09:07:57 +01:00
.gitmodules Remove left-over submodule configuration 2014-06-07 19:29:45 +02:00
.travis.yml travis: include go 1.9 2017-09-03 20:05:05 +02:00
LICENSE Initial commit 2013-03-05 20:53:04 +01:00
Makefile Deduplicate Makefile static target and add thread locking check 2017-07-08 18:24:41 +02:00
README.md README: correct the branches in the testing block 2017-10-16 15:36:57 +02:00
blame.go First round of mass keep-alive additions 2017-07-08 09:11:38 +02:00
blame_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
blob.go fixed typos 2017-07-11 23:52:13 -04:00
blob_test.go Merge pull request #336 from libgit2/cmn/test-parallel 2016-08-27 21:03:29 +02:00
branch.go First round of mass keep-alive additions 2017-07-08 09:11:38 +02:00
branch_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
checkout.go First round of mass keep-alive additions 2017-07-08 09:11:38 +02:00
cherrypick.go First round of mass keep-alive additions 2017-07-08 09:11:38 +02:00
cherrypick_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
clone.go Clone Fix 2016-07-24 14:20:12 +02:00
clone_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
commit.go Add Objecer interface 2017-07-08 22:53:50 +02:00
config.go Bump libgit2 to f1323d9c 2018-01-17 11:43:25 +00:00
config_test.go Fix a couple of issues reported by go-vet 2017-07-06 21:09:01 +02:00
credentials.go Add NewCredSshKeyFromMemory to the credentials helpers. 2016-06-22 14:50:29 -07:00
describe.go First round of mass keep-alive additions 2017-07-08 09:11:38 +02:00
describe_test.go Update libgit2 to df4dfaad 2017-01-20 13:20:30 +00:00
diff.go diff: add two missing options 2018-01-17 11:47:06 +00:00
diff_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
features.go Add Features() to retrieve the compile-time features of libgit2 2016-10-31 21:09:24 +01:00
git.go Second round of keep-alives 2017-07-08 11:38:19 +02:00
git_dynamic.go Switch over the version contraints to v0.27 2018-02-22 09:28:49 +01:00
git_static.go Switch over the version contraints to v0.27 2018-02-22 09:28:49 +01:00
git_test.go Write the index before writing the index tree in seedTestRepo test helper func 2016-09-16 21:49:54 -07:00
graph.go Second round of keep-alives 2017-07-08 11:38:19 +02:00
handles.go handles: use real pointers to keep track of handles 2016-02-18 17:33:44 +01:00
ignore.go Second round of keep-alives 2017-07-08 11:38:19 +02:00
index.go Second round of keep-alives 2017-07-08 11:38:19 +02:00
index_test.go Merge pull request #351 from ezwiebel/index-remove-directory 2016-10-31 20:03:05 +01:00
merge.go Third round of keep-alive aditions 2017-07-08 16:07:51 +02:00
merge_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
note.go Third round of keep-alive aditions 2017-07-08 16:07:51 +02:00
note_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
object.go Add Objecer interface 2017-07-08 22:53:50 +02:00
object_test.go fixed typos 2017-07-11 23:52:13 -04:00
odb.go Adjust to the change in the git_odb_open_rstream signature 2018-02-22 09:28:58 +01:00
odb_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
packbuilder.go Third round of keep-alive aditions 2017-07-08 16:07:51 +02:00
patch.go patch: adjust to new function signature 2017-09-29 09:49:21 +02:00
patch_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
push_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
rebase.go Fix typo in the error message 2017-10-01 21:04:08 -07:00
rebase_test.go rebase: correct the return values for CurrentOperationIndex 2017-07-08 21:34:10 +02:00
refdb.go Third round of keep-alive aditions 2017-07-08 16:07:51 +02:00
reference.go Third round of keep-alive aditions 2017-07-08 16:07:51 +02:00
reference_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
remote.go remote: add keep-alive and references to the repository 2017-07-04 12:53:51 +02:00
remote_test.go Merge remote-tracking branch 'upstream/master' into next 2016-08-27 21:07:44 +02:00
repository.go fixed typos 2017-07-11 23:52:13 -04:00
reset.go ResetDefaultToCommit maps git_reset_default 2016-05-29 14:53:26 +02:00
reset_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
revparse.go Move from an Object interface to a type 2015-08-04 14:47:10 +02:00
revparse_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
settings.go Move the settings into the main git2go 2014-06-07 18:57:46 +02:00
settings_test.go Move the settings into the main git2go 2014-06-07 18:57:46 +02:00
signature.go Third round of keep-alive aditions 2017-07-08 16:07:51 +02:00
stash.go Third round of keep-alive aditions 2017-07-08 16:07:51 +02:00
stash_test.go Add stash support 2015-09-21 14:50:57 +03:00
status.go Third round of keep-alive aditions 2017-07-08 16:07:51 +02:00
status_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
submodule.go clone_checkout_strategy removed 2017-09-03 16:51:11 +02:00
submodule_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
tag.go tag: accept an Objecter for creating a tag 2017-07-08 23:22:33 +02:00
tag_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
tree.go Add Objecer interface 2017-07-08 22:53:50 +02:00
tree_test.go Run the tests in parallel 2016-08-27 19:21:05 +02:00
walk.go Third round of keep-alive aditions 2017-07-08 16:07:51 +02:00
wrapper.c Merge remote-tracking branch 'origin/next' 2017-01-20 00:46:34 +00:00

README.md

git2go

GoDoc Build Status

Go bindings for libgit2.

Which branch to use

The numbered branches work against the version of libgit2 as specified by their number. You can import them in your project via gopkg.in, e.g. if you have libgit2 v0.25 installed you'd import with

import "gopkg.in/libgit2/git2go.v25"

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

The master branch follows the tip of libgit2 itself (with some lag) and as such has no guarantees on its own API nor does it have expectations the stability of libgit2's. Thus this only supports statically linking against libgit2.

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 gopkg.in, e.g. to work against libgit2 v0.25

import "gopkg.in/libgit2/git2go.v25"

Master branch, or static linking

If using master or building a branch 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 master 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.

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 master 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

./script/build-libgit2-static.sh
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)