tunnel: libwg-go: stick go tarball in gradle cache
This way we don't have to build over and over. Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
This commit is contained in:
parent
ed090f7ecb
commit
0fa3fe3d43
@ -30,14 +30,14 @@ android {
|
|||||||
release {
|
release {
|
||||||
externalNativeBuild {
|
externalNativeBuild {
|
||||||
cmake {
|
cmake {
|
||||||
arguments "-DANDROID_PACKAGE_NAME=${groupName}"
|
arguments "-DANDROID_PACKAGE_NAME=${groupName}", "-DGRADLE_USER_HOME=${project.gradle.gradleUserHomeDir}"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
debug {
|
debug {
|
||||||
externalNativeBuild {
|
externalNativeBuild {
|
||||||
cmake {
|
cmake {
|
||||||
arguments "-DANDROID_PACKAGE_NAME=${groupName}.debug"
|
arguments "-DANDROID_PACKAGE_NAME=${groupName}.debug", "-DGRADLE_USER_HOME=${project.gradle.gradleUserHomeDir}"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -24,6 +24,7 @@ add_custom_target(libwg-go.so WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/lib
|
|||||||
ANDROID_LLVM_TRIPLE=${ANDROID_LLVM_TRIPLE}
|
ANDROID_LLVM_TRIPLE=${ANDROID_LLVM_TRIPLE}
|
||||||
ANDROID_SYSROOT=${ANDROID_SYSROOT}
|
ANDROID_SYSROOT=${ANDROID_SYSROOT}
|
||||||
ANDROID_PACKAGE_NAME=${ANDROID_PACKAGE_NAME}
|
ANDROID_PACKAGE_NAME=${ANDROID_PACKAGE_NAME}
|
||||||
|
GRADLE_USER_HOME=${GRADLE_USER_HOME}
|
||||||
CFLAGS=${CMAKE_C_FLAGS}\ -Wno-unused-command-line-argument
|
CFLAGS=${CMAKE_C_FLAGS}\ -Wno-unused-command-line-argument
|
||||||
LDFLAGS=${CMAKE_SHARED_LINKER_FLAGS}\ -fuse-ld=gold
|
LDFLAGS=${CMAKE_SHARED_LINKER_FLAGS}\ -fuse-ld=gold
|
||||||
DESTDIR=${CMAKE_LIBRARY_OUTPUT_DIRECTORY}
|
DESTDIR=${CMAKE_LIBRARY_OUTPUT_DIRECTORY}
|
||||||
|
@ -20,18 +20,28 @@ export GOARCH := $(NDK_GO_ARCH_MAP_$(ANDROID_ARCH_NAME))
|
|||||||
export GOOS := android
|
export GOOS := android
|
||||||
export CGO_ENABLED := 1
|
export CGO_ENABLED := 1
|
||||||
|
|
||||||
DESIRED_GO_VERSION := 1.14.1
|
GO_VERSION := 1.14.1
|
||||||
|
GO_TARBALL := go$(GO_VERSION).$(shell uname -s | tr '[:upper:]' '[:lower:]')-$(NDK_GO_ARCH_MAP_$(shell uname -m)).tar.gz
|
||||||
|
|
||||||
default: $(DESTDIR)/libwg-go.so
|
default: $(DESTDIR)/libwg-go.so
|
||||||
|
|
||||||
$(BUILDDIR)/go-$(DESIRED_GO_VERSION)/.prepared:
|
$(GRADLE_USER_HOME)/caches/golang/$(GO_TARBALL):
|
||||||
mkdir -p "$(dir $@)"
|
mkdir -p "$(dir $@)"
|
||||||
flock -x "$@.lock" -c ' \
|
flock -x "$@.lock" -c ' \
|
||||||
[ -f "$@" ] && exit 0; \
|
[ -f "$@" ] && exit 0; \
|
||||||
curl "https://dl.google.com/go/go$(DESIRED_GO_VERSION).$(shell uname -s | tr '[:upper:]' '[:lower:]')-$(NDK_GO_ARCH_MAP_$(shell uname -m)).tar.gz" | tar -C "$(dir $@)" --strip-components=1 -xzf - && \
|
curl -o "$@.tmp" "https://dl.google.com/go/$(GO_TARBALL)" && \
|
||||||
|
mv "$@.tmp" "$@"'
|
||||||
|
|
||||||
|
$(BUILDDIR)/go-$(GO_VERSION)/.prepared: $(GRADLE_USER_HOME)/caches/golang/$(GO_TARBALL)
|
||||||
|
mkdir -p "$(dir $@)"
|
||||||
|
flock -x "$@.lock" -c ' \
|
||||||
|
[ -f "$@" ] && exit 0; \
|
||||||
|
tar -C "$(dir $@)" --strip-components=1 -xzf "$^" && \
|
||||||
patch -p1 -f -N -r- -d "$(dir $@)" < goruntime-boottime-over-monotonic.diff && \
|
patch -p1 -f -N -r- -d "$(dir $@)" < goruntime-boottime-over-monotonic.diff && \
|
||||||
touch "$@"'
|
touch "$@"'
|
||||||
|
|
||||||
$(DESTDIR)/libwg-go.so: export PATH := $(BUILDDIR)/go-$(DESIRED_GO_VERSION)/bin/:$(PATH)
|
$(DESTDIR)/libwg-go.so: export PATH := $(BUILDDIR)/go-$(GO_VERSION)/bin/:$(PATH)
|
||||||
$(DESTDIR)/libwg-go.so: $(BUILDDIR)/go-$(DESIRED_GO_VERSION)/.prepared go.mod
|
$(DESTDIR)/libwg-go.so: $(BUILDDIR)/go-$(GO_VERSION)/.prepared go.mod
|
||||||
go build -tags linux -ldflags="-X golang.zx2c4.com/wireguard/ipc.socketDirectory=/data/data/$(ANDROID_PACKAGE_NAME)/cache/wireguard" -v -trimpath -o "$@" -buildmode c-shared
|
go build -tags linux -ldflags="-X golang.zx2c4.com/wireguard/ipc.socketDirectory=/data/data/$(ANDROID_PACKAGE_NAME)/cache/wireguard" -v -trimpath -o "$@" -buildmode c-shared
|
||||||
|
|
||||||
|
.DELETE_ON_ERROR:
|
||||||
|
Loading…
Reference in New Issue
Block a user