diff options
| author | Carlos MartÃn Nieto <[email protected]> | 2017-04-14 13:11:28 +0200 |
|---|---|---|
| committer | GitHub <[email protected]> | 2017-04-14 13:11:28 +0200 |
| commit | 7cd5a4e731e982391b9274e17c7f32050d8e5b15 (patch) | |
| tree | 47478f9d74f7d78cf3a8ac1ee9b2847f380b7267 | |
| parent | 71bdf97227584d5a1e346b0ead8a47c52c7b2c41 (diff) | |
| parent | e7747d31746abadbba6ae986538874b336687f7a (diff) | |
Merge pull request #371 from libgit2/static-dynamic
Allow building statically via the "static" build tag
| -rw-r--r-- | .travis.yml | 6 | ||||
| -rw-r--r-- | Makefile | 16 | ||||
| -rw-r--r-- | git.go | 9 | ||||
| -rw-r--r-- | git_dynamic.go | 14 | ||||
| -rw-r--r-- | git_static.go | 17 |
5 files changed, 46 insertions, 16 deletions
diff --git a/.travis.yml b/.travis.yml index d9130bc..f3b8b46 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,15 +1,13 @@ language: go -sudo: required - -install: ./script/install-libgit2.sh - go: - 1.5 - 1.6 - 1.7 - tip +script: make test-static + matrix: allow_failures: - go: tip @@ -1,11 +1,21 @@ default: test -build-libgit2: - ./script/build-libgit2-static.sh - test: build-libgit2 go run script/check-MakeGitError-thread-lock.go go test ./... install: build-libgit2 go install ./... + +build-libgit2: + ./script/build-libgit2-static.sh + +static: build-libgit2 + go run script/check-MakeGitError-thread-lock.go + go test --tags "static" ./... + +install-static: build-libgit2 + go install --tags "static" ./... + +test-static: build-libgit2 + go test --tags "static" ./... @@ -1,17 +1,8 @@ package git /* -#cgo CFLAGS: -I${SRCDIR}/vendor/libgit2/include -#cgo LDFLAGS: -L${SRCDIR}/vendor/libgit2/build/ -lgit2 -#cgo windows LDFLAGS: -lwinhttp -#cgo !windows pkg-config: --static ${SRCDIR}/vendor/libgit2/build/libgit2.pc #include <git2.h> #include <git2/sys/openssl.h> - -#if LIBGIT2_VER_MAJOR != 0 || LIBGIT2_VER_MINOR != 25 -# error "Invalid libgit2 version; this git2go supports libgit2 v0.25" -#endif - */ import "C" import ( diff --git a/git_dynamic.go b/git_dynamic.go new file mode 100644 index 0000000..f89d509 --- /dev/null +++ b/git_dynamic.go @@ -0,0 +1,14 @@ +// +build !static + +package git + +/* +#include <git2.h> +#cgo pkg-config: libgit2 + +#if LIBGIT2_VER_MAJOR != 0 || LIBGIT2_VER_MINOR != 25 +# error "Invalid libgit2 version; this git2go supports libgit2 v0.25" +#endif + +*/ +import "C" diff --git a/git_static.go b/git_static.go new file mode 100644 index 0000000..d0acb3a --- /dev/null +++ b/git_static.go @@ -0,0 +1,17 @@ +// +build static + +package git + +/* +#cgo CFLAGS: -I${SRCDIR}/vendor/libgit2/include +#cgo LDFLAGS: -L${SRCDIR}/vendor/libgit2/build/ -lgit2 +#cgo windows LDFLAGS: -lwinhttp +#cgo !windows pkg-config: --static ${SRCDIR}/vendor/libgit2/build/libgit2.pc +#include <git2.h> + +#if LIBGIT2_VER_MAJOR != 0 || LIBGIT2_VER_MINOR != 25 +# error "Invalid libgit2 version; this git2go supports libgit2 v0.25" +#endif + +*/ +import "C" |
